/* ===== Base ===== */
:root {
  --primary:         #0a874c;
  --primary-dark:    #076637;
  --primary-darker:  #054d2a;
  --primary-light:   #e6f7ee;
  --primary-hover:   #f0faf4;
  --accent:          #f8ec39;
  --accent-dark:     #e0d400;
  --accent-light:    #fffde7;
  --bg:              #f8faf9;
}
body {
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: #1c1917;
}

/* ===== Lucide Icons Default Sizing ===== */
.lucide {
  display: inline-block;
  vertical-align: -0.125em;
  flex-shrink: 0;
}

/* ===== Glass Navbar ===== */
.glass-nav {
  background: rgba(5, 50, 30, .92);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border-bottom: 1px solid rgba(255,255,255,.08);
  transition: background .3s ease;
}
.glass-nav .navbar-brand,
.glass-nav .nav-link,
.glass-nav .navbar-text { color: rgba(255,255,255,.9) !important; }
.glass-nav .nav-link:hover { color: var(--accent) !important; }
.glass-nav .navbar-toggler-icon {
  filter: invert(1);
}
.glass-nav .nav-link { display: inline-flex; align-items: center; }
.glass-nav .nav-link .badge { font-size: .65rem; vertical-align: super; }

/* ===== Page Headers ===== */
.page-header {
  background: linear-gradient(135deg, var(--primary-darker) 0%, var(--primary-dark) 50%, var(--primary) 100%);
  color: #fff;
  padding: 2.5rem 0 2rem;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  padding-left: calc(50vw - 50%);
  padding-right: calc(50vw - 50%);
  margin-top: 0;
}
.page-header h1, .page-header h2 { font-weight: 700; letter-spacing: -0.01em; }
.page-header p { opacity: .85; }
.page-header .breadcrumb { margin-bottom: .5rem; }
.page-header .breadcrumb-item a { color: rgba(255,255,255,.7); text-decoration: none; }
.page-header .breadcrumb-item a:hover { color: #fff; }
.page-header .breadcrumb-item.active { color: rgba(255,255,255,.9); }
.page-header .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.4); }

/* ===== Hero Section ===== */
.hero-section {
  background:
    linear-gradient(135deg, rgba(5,50,30,.93) 0%, rgba(7,102,55,.86) 50%, rgba(10,135,76,.80) 100%),
    url('https://images.unsplash.com/photo-1489493887464-892be6d1daae?w=1600&h=900&fit=crop&q=80') center/cover no-repeat;
  min-height: 440px;
}
.hero-overlay {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 20% 80%, rgba(248,236,57,.18) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(10,135,76,.15) 0%, transparent 50%);
  pointer-events: none;
}
.min-vh-hero { min-height: 380px; }
.hero-title { letter-spacing: -0.02em; line-height: 1.08; }
.text-gradient {
  background: linear-gradient(90deg, var(--accent), var(--accent-dark), #b8a800);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Hero stat cards */
.stat-card {
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: .75rem;
  padding: 1.25rem .75rem;
  text-align: center;
  transition: transform .2s, background .2s;
}
.stat-card:hover { transform: translateY(-2px); background: rgba(255,255,255,.14); }
.stat-icon { font-size: 1.4rem; color: var(--accent); margin-bottom: .25rem; }
.stat-value { font-size: 1.5rem; font-weight: 700; color: #fff; line-height: 1.2; }
.stat-label { font-size: .75rem; color: rgba(255,255,255,.6); text-transform: uppercase; letter-spacing: .04em; }

/* ===== Site Detail Hero ===== */
.site-detail-hero {
  height: 360px;
  background-size: cover;
  background-position: center;
  position: relative;
}
.site-detail-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.75) 0%, rgba(0,0,0,.2) 50%, rgba(0,0,0,.1) 100%);
  display: flex;
  align-items: flex-end;
  padding-bottom: 2rem;
}
.site-detail-hero .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.4); }

/* ===== Site Gallery ===== */
.site-gallery-img {
  background-size: cover;
  background-position: center;
  transition: transform .3s ease;
}
.site-gallery-img:hover { transform: scale(1.02); }
.site-gallery-main { height: 280px; }
.site-gallery-thumb { min-height: 134px; }

/* ===== Modern Cards ===== */
.card {
  border: none; border-radius: .75rem;
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
  transition: transform .2s ease, box-shadow .2s ease;
  background: #fff;
}
.card:hover { box-shadow: 0 4px 14px rgba(0,0,0,.07); }
.card-header {
  background: transparent; border-bottom: 1px solid #e9f5ee;
  font-weight: 600; padding: 1rem 1.25rem;
}

/* ===== Site Cards (Gallery Style) ===== */
.site-card { border: none; overflow: hidden; }
.site-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 28px rgba(0,0,0,.12) !important;
}
.site-card-img {
  height: 200px;
  background-size: cover;
  background-position: center;
  position: relative;
  transition: transform .4s ease;
}
.site-card:hover .site-card-img { transform: scale(1.04); }
.site-card-img-wrap { overflow: hidden; }
.site-card-img::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.45) 0%, transparent 60%);
}
.site-card-img .card-img-overlay {
  position: absolute; bottom: 0; left: 0; right: 0; padding: .75rem 1rem;
  z-index: 1; display: flex; justify-content: space-between; align-items: flex-end;
}

/* Pricing chips */
.pricing-chip {
  padding: .3rem .65rem; border-radius: .5rem; line-height: 1.3;
}
.pricing-local  { background: var(--primary-light); color: var(--primary-dark); }
.pricing-foreign { background: #eff6ff; color: #1e40af; }

/* ===== Modern Forms ===== */
.form-control, .form-select {
  border-radius: .5rem; border: 1.5px solid #d6d3d1;
  padding: .625rem .875rem; transition: border-color .2s, box-shadow .2s;
  font-size: .9rem; background: #fff;
}
.form-control:focus, .form-select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(10,135,76,.12);
}
.form-label {
  font-weight: 600; font-size: .82rem; color: #57534e; margin-bottom: .35rem;
}
.form-text { font-size: .78rem; color: #a8a29e; }
.input-icon-wrap { position: relative; }
.input-icon-wrap .form-control { padding-left: 2.5rem; }
.input-icon-wrap .input-icon {
  position: absolute; left: .875rem; top: 50%; transform: translateY(-50%);
  color: #a8a29e; width: 18px; height: 18px; pointer-events: none;
}

/* ===== Auth Cards ===== */
.auth-card {
  border: none; border-radius: 1rem; overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,.07); background: #fff;
}
.auth-card-accent {
  height: 5px;
  background: linear-gradient(90deg, var(--primary-darker), var(--primary), var(--accent));
}
.auth-card .card-body { padding: 2rem; }
.auth-icon-circle {
  width: 60px; height: 60px; border-radius: 50%;
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
  display: flex; align-items: center; justify-content: center;
  color: #fff; margin: 0 auto 1rem;
}

/* ===== Status Badges ===== */
.status-badge {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .3rem .75rem; border-radius: 2rem;
  font-size: .78rem; font-weight: 600; letter-spacing: .01em;
}
.status-draft       { background: #f5f5f4; color: #57534e; }
.status-pending     { background: #fef3c7; color: #92400e; }
.status-approved    { background: #d1fae5; color: #065f46; }
.status-paid        { background: #ccfbf1; color: #115e59; }
.status-permit_issued { background: #dbeafe; color: #1e40af; }
.status-checked_in  { background: #ede9fe; color: #5b21b6; }
.status-checked_out { background: #d1fae5; color: #064e3b; }
.status-declined    { background: #fee2e2; color: #991b1b; }
.status-cancelled   { background: #fee2e2; color: #991b1b; }
.status-refunded    { background: #ffedd5; color: #9a3412; }
.status-sent        { background: #d1fae5; color: #065f46; }
.status-failed      { background: #fee2e2; color: #991b1b; }
.status-dot {
  width: 8px; height: 8px; border-radius: 50%; display: inline-block;
}
.status-draft .status-dot       { background: #a8a29e; }
.status-pending .status-dot     { background: #d97706; }
.status-approved .status-dot    { background: #059669; }
.status-paid .status-dot        { background: #0d9488; }
.status-permit_issued .status-dot { background: #2563eb; }
.status-checked_in .status-dot  { background: #7c3aed; }
.status-checked_out .status-dot { background: #059669; }
.status-declined .status-dot    { background: #dc2626; }
.status-cancelled .status-dot   { background: #dc2626; }
.status-refunded .status-dot    { background: #ea580c; }

/* ===== Booking Cards ===== */
.booking-card {
  border: none; border-radius: .75rem;
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
  transition: all .2s ease; overflow: hidden;
  border-left: 4px solid transparent;
}
.booking-card:hover { transform: translateY(-2px); box-shadow: 0 4px 14px rgba(0,0,0,.07); }
.booking-card.status-border-draft       { border-left-color: #a8a29e; }
.booking-card.status-border-pending     { border-left-color: #d97706; }
.booking-card.status-border-approved    { border-left-color: #059669; }
.booking-card.status-border-paid        { border-left-color: #0d9488; }
.booking-card.status-border-permit_issued { border-left-color: #2563eb; }
.booking-card.status-border-checked_in  { border-left-color: #7c3aed; }
.booking-card.status-border-checked_out { border-left-color: #059669; }
.booking-card.status-border-declined    { border-left-color: #dc2626; }
.booking-card.status-border-cancelled   { border-left-color: #dc2626; }
.booking-card.status-border-refunded    { border-left-color: #ea580c; }

/* ===== Metric Cards ===== */
.metric-card {
  border: none; border-radius: .75rem; text-align: center;
  padding: 1.25rem 1rem; background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
}
.metric-card .metric-icon {
  width: 44px; height: 44px; border-radius: .625rem;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: .5rem;
}
.metric-card .metric-value { font-size: 1.35rem; font-weight: 700; color: #1c1917; }
.metric-card .metric-label { font-size: .78rem; color: #78716c; text-transform: uppercase; letter-spacing: .03em; }

/* ===== Itinerary Items ===== */
.itinerary-item {
  border: none; border-radius: .625rem; background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.04); transition: box-shadow .2s, transform .15s;
}
.itinerary-item:hover { box-shadow: 0 3px 10px rgba(0,0,0,.07); }
.itinerary-item .item-number {
  width: 32px; height: 32px; border-radius: 50%;
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
  color: #fff; display: inline-flex; align-items: center; justify-content: center;
  font-size: .8rem; font-weight: 700; flex-shrink: 0;
}

/* ===== Notification Items ===== */
.notification-item {
  border: none; border-radius: .625rem; background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.04); transition: all .2s; overflow: hidden;
}
.notification-item:hover { box-shadow: 0 3px 10px rgba(0,0,0,.07); }
.notification-icon {
  width: 42px; height: 42px; border-radius: .625rem;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

/* ===== Pricing Card ===== */
.pricing-card {
  border: none; border-radius: .75rem; overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.06); position: sticky; top: 5rem;
}
.pricing-card-header {
  background: linear-gradient(135deg, var(--primary-darker), var(--primary-dark));
  color: #fff;
  padding: 1rem 1.25rem; font-weight: 600;
}
.pricing-row {
  display: flex; justify-content: space-between;
  padding: .625rem 1.25rem; border-bottom: 1px solid #e9f5ee; font-size: .9rem;
}
.pricing-row:last-child { border-bottom: none; }
.pricing-row.total {
  font-weight: 700; font-size: 1.05rem; background: var(--bg); padding: .875rem 1.25rem;
}

/* ===== Slot Chips ===== */
.slot-chip {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .4rem .8rem; border-radius: .5rem;
  background: var(--primary-light); border: 1px solid rgba(10,135,76,.25);
  font-size: .85rem; color: var(--primary-dark);
}

/* ===== Star Rating ===== */
.star-rating .lucide { vertical-align: baseline; }
.star-selector { display: inline-flex; gap: .15rem; flex-direction: row-reverse; justify-content: flex-end; }
.star-selector label { cursor: pointer; color: #d6d3d1; transition: color .15s; }
.star-selector label .lucide { width: 24px; height: 24px; }
.star-selector input { display: none; }
.star-selector label:hover,
.star-selector label:hover ~ label,
.star-selector input:checked ~ label { color: var(--accent-dark); }
.star-selector input:checked ~ label .lucide,
.star-selector label:hover .lucide,
.star-selector label:hover ~ label .lucide { fill: currentColor; }

/* ===== Modal ===== */
.modal-content { border: none; border-radius: .75rem; overflow: hidden; }
.modal-header { background: var(--bg); border-bottom: 1px solid #e9f5ee; }
.modal-footer { border-top: 1px solid #e9f5ee; background: var(--bg); }

/* ===== Section Label ===== */
.section-label {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: #a8a29e; margin-bottom: .75rem;
}

/* ===== Drag Handle ===== */
.drag-handle { cursor: grab; }
.drag-handle:active { cursor: grabbing; }
.drag-handle:hover { color: var(--primary-dark) !important; }

/* ===== Empty States ===== */
.empty-state { text-align: center; padding: 3rem 1rem; }
.empty-state-icon { color: #d6d3d1; margin-bottom: .75rem; }

/* ===== Info Grid ===== */
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.info-grid-item { padding: .75rem; background: var(--bg); border-radius: .5rem; }
.info-grid-item .info-label {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: #a8a29e; margin-bottom: .15rem;
}
.info-grid-item .info-value { font-size: 1rem; font-weight: 600; color: #1c1917; }

/* ===== Buttons ===== */
.btn { border-radius: .5rem; font-weight: 600; }
.btn-primary { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn-primary:hover, .btn-primary:focus { background: var(--primary-dark); border-color: var(--primary-dark); color: #fff; }
.btn-outline-primary { color: var(--primary); border-color: var(--primary); }
.btn-outline-primary:hover { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn-warning, .btn-accent {
  background: var(--accent); border-color: var(--accent-dark); color: #1c1917;
}
.btn-warning:hover, .btn-warning:focus,
.btn-accent:hover, .btn-accent:focus {
  background: var(--accent-dark); border-color: var(--accent-dark); color: #1c1917;
}

/* ===== Select2 Overrides ===== */
.select2-container--bootstrap-5 .select2-selection {
  border: 1.5px solid #d6d3d1 !important;
  border-radius: .5rem !important;
  padding: .5rem .75rem !important;
  min-height: 42px !important;
  font-size: .9rem !important;
  background: #fff !important;
  transition: border-color .2s, box-shadow .2s;
}
.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(10,135,76,.12) !important;
}
.select2-container--bootstrap-5 .select2-selection__rendered {
  color: #1c1917 !important;
  padding: 0 !important;
  line-height: 1.5 !important;
}
.select2-container--bootstrap-5 .select2-selection__placeholder {
  color: #a8a29e !important;
}
.select2-container--bootstrap-5 .select2-dropdown {
  border: 1.5px solid #d6d3d1;
  border-radius: .5rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.1);
  overflow: hidden;
}
.select2-container--bootstrap-5 .select2-search__field {
  border: 1.5px solid #d6d3d1 !important;
  border-radius: .375rem !important;
  padding: .5rem .75rem !important;
  font-size: .9rem !important;
}
.select2-container--bootstrap-5 .select2-search__field:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 2px rgba(10,135,76,.1) !important;
}
.select2-container--bootstrap-5 .select2-results__option--highlighted[aria-selected] {
  background-color: var(--primary) !important;
}
.select2-container--bootstrap-5 .select2-results__option--selected {
  background-color: var(--primary-light) !important;
  color: var(--primary-dark) !important;
}
.select2-container--bootstrap-5 .select2-results__option {
  padding: .5rem .75rem;
  font-size: .9rem;
}

/* ===== Flatpickr Overrides ===== */
.flatpickr-calendar {
  border-radius: .75rem !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.12) !important;
  border: 1px solid #e9f5ee !important;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif !important;
}
.flatpickr-months .flatpickr-month {
  background: var(--primary) !important;
  color: #fff !important;
  border-radius: .625rem .625rem 0 0;
  height: 40px !important;
}
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
  fill: #fff !important;
  color: #fff !important;
}
.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
  fill: var(--accent) !important;
}
.flatpickr-current-month {
  color: #fff !important;
  font-weight: 600 !important;
  font-size: .95rem !important;
}
.flatpickr-current-month .flatpickr-monthDropdown-months {
  background: transparent !important;
  color: #fff !important;
  font-weight: 600 !important;
}
.flatpickr-current-month input.cur-year {
  color: #fff !important;
  font-weight: 600 !important;
}
span.flatpickr-weekday {
  color: #78716c !important;
  font-weight: 600 !important;
  font-size: .75rem !important;
}
.flatpickr-day {
  border-radius: .375rem !important;
  font-size: .85rem !important;
  color: #1c1917 !important;
}
.flatpickr-day:hover {
  background: var(--primary-light) !important;
  border-color: var(--primary-light) !important;
}
.flatpickr-day.selected,
.flatpickr-day.selected:hover {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: #fff !important;
}
.flatpickr-day.today {
  border-color: var(--accent-dark) !important;
}
.flatpickr-day.today:hover {
  background: var(--accent-light) !important;
  border-color: var(--accent-dark) !important;
}
.flatpickr-time {
  border-top: 1px solid #e9f5ee !important;
}
.flatpickr-time input,
.flatpickr-time .flatpickr-am-pm {
  font-size: .9rem !important;
  font-weight: 600 !important;
  color: #1c1917 !important;
}
.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:focus {
  background: var(--primary-light) !important;
}
/* Flatpickr alt-input styling */
input.flatpickr-input[readonly] {
  background: #fff !important;
  cursor: pointer;
}

/* ===== Guest Table ===== */
#guest-table th {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: #a8a29e; border-bottom: 1px solid #e9f5ee;
  padding: .75rem .5rem;
}
#guest-table td {
  vertical-align: middle; font-size: .9rem; padding: .625rem .5rem;
  border-bottom: 1px solid #e9f5ee;
}
#guest-table tr:last-child td { border-bottom: none; }

/* ===== Toast ===== */
.toast {
  border-radius: .625rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  font-size: .9rem;
  font-weight: 500;
}

/* ===== Footer ===== */
.footer a:hover { color: var(--accent) !important; }
