/* ============================================================
   Tour card — modern listing card used on /tours and /tours-search
   (rendered by db-tours/single_view.blade.php). Matches the article /
   single-tour design language (red theme, soft cards, hover lift).
   ============================================================ */
:root {
    --tl-theme: var(--theme-color, #af0000);
    --tl-heading: #1f2530;
    --tl-body: #3a4049;
    --tl-muted: #6c727a;
    --tl-border: #e6e8ee;
    --tl-radius: 16px;
}

.tl-card {
    height: 100%;
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid var(--tl-border);
    border-radius: var(--tl-radius);
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(20, 24, 31, .06);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.tl-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 44px rgba(20, 24, 31, .14);
    border-color: rgba(175, 0, 0, .22);
}

/* Media */
.tl-card__media {
    position: relative;
    display: block;
    aspect-ratio: 16 / 10;
    background: #11151c center/cover no-repeat;
}
.tl-card__media::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,.45) 100%);
}
.tl-card__date {
    position: absolute; top: 14px; left: 14px; z-index: 2;
    background: rgba(255, 255, 255, .96); border-radius: 12px;
    padding: 8px 12px; text-align: center; line-height: 1.05;
    box-shadow: 0 6px 16px rgba(0, 0, 0, .18); min-width: 56px;
}
.tl-card__date span { display: block; font-size: 11px; font-weight: 700; color: var(--tl-muted); text-transform: uppercase; letter-spacing: .04em; }
.tl-card__date strong { display: block; font-size: 22px; font-weight: 800; color: var(--tl-theme); line-height: 1; margin: 2px 0; }
.tl-card__badge {
    position: absolute; top: 14px; right: 14px; z-index: 2;
    padding: 5px 12px; border-radius: 999px; font-size: 11px; font-weight: 700;
    letter-spacing: .03em; color: #fff; text-transform: uppercase;
}
.tl-card__badge--closed { background: #6c727a; }
.tl-card__badge--wait { background: #d98300; }

/* Body */
.tl-card__body { display: flex; flex-direction: column; flex: 1; padding: 20px 22px 22px; }
.tl-card__title { font-size: 18px; font-weight: 800; line-height: 1.34; margin: 0 0 14px; }
.tl-card__title a {
    color: var(--tl-heading); text-decoration: none;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.tl-card__title a:hover { color: var(--tl-theme); }

.tl-card__meta { list-style: none; padding: 0; margin: 0 0 18px; display: grid; gap: 8px; }
.tl-card__meta li { display: flex; align-items: center; gap: 9px; font-size: 13.5px; color: var(--tl-body); }
.tl-card__meta i { color: var(--tl-theme); width: 16px; text-align: center; }

.tl-card__foot {
    margin-top: auto; padding-top: 16px; border-top: 1px solid var(--tl-border);
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.tl-card__price { font-size: 19px; font-weight: 800; color: var(--tl-heading); white-space: nowrap; }
.tl-card__price small { display: block; font-size: 11px; font-weight: 600; color: var(--tl-muted); text-transform: uppercase; letter-spacing: .05em; }
.tl-card__btn {
    display: inline-flex; align-items: center; gap: 7px; flex-shrink: 0;
    background: var(--tl-theme); color: #fff; font-weight: 700; font-size: 13px;
    padding: 10px 16px; border-radius: 999px; text-decoration: none;
    transition: background .2s ease, transform .2s ease;
}
.tl-card__btn:hover { background: #931212; color: #fff; transform: translateX(2px); }

/* ---- Listing filter toolbar (used on /tours) ---- */
.tl-toolbar {
    background: #fff; border: 1px solid var(--tl-border); border-radius: var(--tl-radius);
    box-shadow: 0 8px 24px rgba(20, 24, 31, .05);
    padding: 18px; margin-bottom: 30px;
    display: grid; grid-template-columns: 1.6fr repeat(4, 1fr) auto; gap: 12px; align-items: center;
}
@media (max-width: 1100px) { .tl-toolbar { grid-template-columns: 1fr 1fr 1fr; } }
@media (max-width: 640px)  { .tl-toolbar { grid-template-columns: 1fr 1fr; } }
@media (max-width: 420px)  { .tl-toolbar { grid-template-columns: 1fr; } }

.tl-search { position: relative; }
.tl-search i { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--tl-muted); font-size: 14px; pointer-events: none; }
.tl-field {
    width: 100%; padding: 11px 14px; border: 1.5px solid var(--tl-border);
    border-radius: 10px; background: #fff; font-size: 14px; font-family: inherit; color: var(--tl-heading);
    transition: border-color .2s, box-shadow .2s;
}
.tl-search .tl-field { padding-left: 38px; }
.tl-field:focus { outline: none; border-color: var(--tl-theme); box-shadow: 0 0 0 3px rgba(175,0,0,.08); }

.tl-toggle { display: inline-flex; align-items: center; gap: 8px; font-size: 13.5px; font-weight: 600; color: var(--tl-heading); cursor: pointer; white-space: nowrap; user-select: none; }
.tl-toggle input { width: 16px; height: 16px; accent-color: var(--tl-theme); cursor: pointer; }

.tl-count { margin: 0 0 18px; font-size: 14px; color: var(--tl-muted); font-weight: 600; }
.tl-count strong { color: var(--tl-heading); }

.tl-cell { transition: opacity .2s ease; }

.tl-empty {
    grid-column: 1 / -1; text-align: center; padding: 70px 20px;
    background: #f7f8fb; border: 1px dashed var(--tl-border); border-radius: var(--tl-radius); color: var(--tl-muted);
}
.tl-empty i { color: var(--tl-theme); display: block; margin-bottom: 14px; }
.tl-empty p { margin: 0 0 6px; font-size: 16px; font-weight: 600; color: var(--tl-heading); }
.tl-empty span { font-size: 14px; }
.tl-reset {
    margin-top: 16px; display: inline-flex; align-items: center; gap: 8px;
    background: var(--tl-theme); color: #fff; border: 0; cursor: pointer;
    padding: 10px 20px; border-radius: 999px; font-weight: 700; font-size: 13px;
}
.tl-reset:hover { background: #931212; }
