/*
 Theme tokens and boxed layout for Experience-Gifts.co.uk
 - Uses Bootstrap 5 as base (already included)
 - Keep overrides minimal and layered after site.css
*/

:root {
  --eg-primary: #0a6cff;
  --eg-primary-600: #0859d1;
  --eg-accent: #ffb703;
  --eg-bg: #f5f7fb;
  --eg-surface: #ffffff;
  --eg-text: #1f2a37;
  --eg-muted: #6b7280;
  --eg-radius: 14px;
  --eg-shadow: 0 8px 24px rgba(16, 24, 40, 0.08);
}

/* Base */
html, body { color: var(--eg-text); background: var(--eg-bg); }
body { 
  -webkit-font-smoothing: antialiased; 
  -moz-osx-font-smoothing: grayscale;
  background-image: radial-gradient(1200px 600px at 50% -200px, rgba(10,108,255,0.07), rgba(255,255,255,0));
}

/* Boxed shell */
.page-bg { padding-top: 88px; /* account for fixed header */ }
@media (max-width: 767.98px) { .page-bg { padding-top: 72px; } }

.page-shell { 
  background: var(--eg-surface);
  border-radius: var(--eg-radius);
  box-shadow: var(--eg-shadow);
  padding: 24px;
  margin-bottom: 24px;
}
@media (min-width: 992px) { .page-shell { padding: 28px; margin-top: 8px; } }
@media (max-width: 575.98px) { .page-shell { padding: 12px; margin: 0; overflow-x: hidden; } }

/* Tame Bootstrap gutters inside boxed layout on small screens */
@media (max-width: 575.98px) {
  .page-shell { padding-left: 12px; padding-right: 12px; }
  .page-shell .container-fluid { padding-left: 0; padding-right: 0; }
  .page-shell .row { margin-left: 0; margin-right: 0; }
}

/* Header adjustments */
header.fixed-top { box-shadow: 0 2px 12px rgba(0,0,0,0.06); }

/* Buttons & links */
.btn-primary { background-color: var(--eg-primary); border-color: var(--eg-primary); }
.btn-primary:hover { background-color: var(--eg-primary-600); border-color: var(--eg-primary-600); }
.btn-warning { color: #111827; }
a { color: var(--eg-primary); }
a:hover { color: var(--eg-primary-600); }

/* Cards polish */
.card { border: 1px solid #eef2f7; border-radius: 12px; }
.card-img-top { object-fit: cover; }
.card-title { line-height: 1.25; }
.card .price { font-weight: 700; color: #065f46; }
.badge-sale { background: #10b981; }
.badge-new { background: #6366f1; }

/* Experience listing cards */
.eg-experience { position: relative; display: flex; flex-direction: column; height: 100%; }
.eg-experience .eg-thumb { width: 100%; border-bottom: 1px solid #eef2f7; overflow: hidden; border-radius: 12px 12px 0 0; }
.eg-experience .eg-thumb img { width: 100%; height: 100%; object-fit: cover; }
.eg-experience .card-body { padding: 1.25rem; display: flex; flex-direction: column; gap: 0.5rem; }
.eg-experience .card-body .card-title { font-size: 1.05rem; font-weight: 600; margin-bottom: 0; }
.eg-experience .card-body .card-text { color: var(--eg-muted); font-size: 0.925rem; margin-bottom: 0; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.eg-experience .card-footer { padding: 0 1.25rem 1.25rem; margin-top: auto; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.eg-experience .card-footer .expprice { float: none; background: none; border: 0; padding: 0; margin: 0; font-weight: 700; color: #065f46; }
.eg-experience .card-footer .btn { white-space: nowrap; }

/* View toolbar */
.eg-toolbar { 
  display: flex; gap: 12px; align-items: center; 
  justify-content: space-between; flex-wrap: wrap; margin-bottom: 16px;
}
.eg-toolbar .segmented { border: 1px solid #e5e7eb; border-radius: 10px; overflow: hidden; }
.eg-toolbar .segmented .btn { border: 0; }
.eg-toolbar .count { color: var(--eg-muted); font-size: .95rem; }
.eg-toolbar .form-select { min-width: 160px; }
@media (max-width: 575.98px) {
  .eg-toolbar { flex-direction: column; align-items: stretch; }
  .eg-toolbar .d-flex.gap-2 { width: 100%; justify-content: space-between; }
  .eg-toolbar .form-select { width: 100%; }
}

/* Results views */
.eg-results { display: block; margin: 0; padding: 0; }
.eg-results > * { display: block; width: 100%; padding: 0 !important; margin: 0; }

.eg-results.view-grid { column-count: 1; column-gap: 24px; }
@media (min-width: 576px) { .eg-results.view-grid { column-count: 2; } }
@media (min-width: 992px) { .eg-results.view-grid { column-count: 3; } }
@media (min-width: 1400px) { .eg-results.view-grid { column-count: 4; } }
.eg-results.view-grid > * { break-inside: avoid; margin-bottom: 24px; }
.eg-results.view-grid .eg-experience { height: 100%; }

.eg-results.view-list > * { margin-bottom: 12px; }
.eg-results.view-list .eg-experience { flex-direction: row; align-items: center; gap: 24px; padding: 16px 24px; box-shadow: none; }
.eg-results.view-list .eg-thumb { display: none; }
.eg-results.view-list .eg-experience .card-body { flex: 1; padding: 0; gap: 0.35rem; }
.eg-results.view-list .eg-experience .card-body .card-text { -webkit-line-clamp: 2; }
.eg-results.view-list .eg-experience .card-footer { padding: 0; margin: 0; border: 0; gap: 16px; justify-content: flex-end; }
.eg-results.view-list .eg-experience .card-footer .expprice { font-size: 1.05rem; }
.eg-results.view-list .eg-experience .card-footer .btn { padding-inline: 1rem; }

/* Search dropdown in modal */
.eg-search { position: relative; }
.eg-suggestions { position: absolute; top: 100%; left: 0; right: 0; z-index: 1056; background: #fff; border: 1px solid #e5e7eb; border-radius: 10px; box-shadow: var(--eg-shadow); max-height: 60vh; overflow: auto; }
.eg-suggestion { padding: 10px 12px; cursor: pointer; display: flex; gap: 10px; align-items: center; }
.eg-suggestion:hover, .eg-suggestion.active { background: #f3f4f6; }
.eg-suggestion .title { font-weight: 600; }
.eg-suggestion .meta { color: var(--eg-muted); font-size: .875rem; }

/* Filters */
.eg-filter-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px; background: #eef2f7; border-radius: 999px; font-size: .875rem; }
.eg-sticky-sidebar { position: sticky; top: 98px; }

/* Disclosure */
.affiliate-disclosure { color: var(--eg-muted); font-size: .85rem; margin-top: 8px; }

/* Focus rings */
:focus-visible { outline: 3px solid rgba(10,108,255,.35); outline-offset: 2px; border-radius: 6px; }

/* Experience detail: widen price/CTA row on desktop */
@media (min-width: 992px) {
  .exp-detail-side .col-lg-4 { flex: 0 0 100% !important; max-width: 100% !important; }
}

/* Tabs: keep labels on one line on desktop, allow horizontal scroll */
@media (min-width: 992px) {
  .tabs { flex-wrap: nowrap; overflow-x: auto; }
  .tabs label { white-space: nowrap; }
}

/* Bootstrap tabs: prevent wrapping and allow horizontal scroll */
.nav-tabs { flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden; }
.nav-tabs .nav-link { white-space: nowrap; }

/* Experience detail: stack summary and CTA on desktop to give CTA full width */
@media (min-width: 992px) {
  .exp-detail-side .row { display: grid; grid-template-columns: 1fr; gap: 8px; }
  .exp-detail-side .col-lg-8,
  .exp-detail-side .col-lg-4 { flex: 0 0 100% !important; max-width: 100% !important; }
}
