/* ===== Layout wrapper ===== */
.activities-wrap{
    max-width: 1140px !important;
    margin: 36px auto 0 !important;
    padding: 0 18px !important;
}

/* columns: 3 on desktop, centered */
.activities-grid{
    display: grid !important;
    grid-template-columns: repeat(3, 340px) !important;
    gap: 24px !important;
    justify-content: center !important;
    align-items: start !important;
}

/* Tablet: 2 columns */
@media (max-width: 1120px){
    .activities-grid{ grid-template-columns: repeat(2, 340px) !important; }
}

/* Phones: 1 column (fluid) */
@media (max-width: 720px){
    .activities-grid{ grid-template-columns: 1fr !important; }
}

/* ===== Card ===== */
.activity-card{
    width: 340px !important;
    max-width: 340px !important;
    position: relative;
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid #e6e8ee;
    border-radius: 18px;
    box-shadow: 0 10px 28px rgba(15,23,42,.10);
    overflow: hidden;
    transition: transform .18s ease, box-shadow .18s ease;
    height: -webkit-fill-available;
}
@media (max-width: 720px){
    .activity-card{ width: 100% !important; max-width: none !important; }
}
.activity-card:hover{ transform: translateY(-2px); box-shadow: 0 16px 40px rgba(15,23,42,.14) }

/* Optional colour frames (outer shell) */
.activity-card.svc-corporate{ background:#c9b791 }
.activity-card.svc-event{     background:#e7e7ea }
.activity-card.svc-school{    background:#c06a61 }
.activity-card.svc-corporate .activity-body,
.activity-card.svc-event .activity-body,
.activity-card.svc-school .activity-body{
    background:#fff; border-top-left-radius:14px; border-top-right-radius:14px;
}

/* ===== Media ===== */
.activity-media{
    position: relative;
    aspect-ratio: 3 / 4;
    max-height: 30vh;
}
.activity-media img{ width: 100%; height: 100%; object-fit: cover; display:block }

.activity-media::after{
    content: attr(data-label);; position:absolute; z-index:2;
    width:auto; height:auto; border-radius:999px; background:#fff; box-shadow:0 1px 0 rgba(0,0,0,.10);font-size: 12px; padding:4px 10px; font-weight:700; color:#111827;
}
.activity-media::after { right:10px; bottom:10px }

/* ===== Body ===== */
.activity-body{
    padding:12px;
    display:flex;
    flex-direction:column;
    gap:10px;
    font-family:"Poppins", sans-serif;
    height: inherit;
}

.ticket-head{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:10px }
.ticket-head .tl{ font-weight:700; font-size:.9rem; color:#111827; font-family:"Figtree", sans-serif; }
.ticket-head .tr{ font-weight:800; font-size:.94rem; color:#111827; font-family:"Figtree", sans-serif; }
.ticket-head .rule{ height:1px; background:#1f2937; opacity:.8 }

/* Title */
.t-title{
    margin:0;
    font-family:"Figtree", sans-serif;
    text-transform:uppercase;
    font-weight:900;
    font-size:20px;
    color:#111827;
}

/* Availability */
.avail-row{ display:flex; gap:8px; flex-wrap:wrap; margin-top:2px }
.pill{ border-radius:999px; padding:6px 10px; font-weight:800; font-size:.78rem; font-family:"Poppins", sans-serif; }
.pill-ok{ background:#ecfdf5; border:1px solid #bbf7d0; color:#065f46 }
.pill-sold{ background:#fef2f2; border:1px solid #fecaca; color:#991b1b }
.avail-next{ color:#6b7280; font-size:.86rem; font-family:"Poppins", sans-serif; }

/* Description */
.activity-body p.muted{
    margin:0;
    color:#667085;
    font-size:.92rem;
    height: -webkit-fill-available;
    font-family:"Poppins", sans-serif;
}

.meta {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px 16px;
    align-items: start;
    margin-top: auto;
}

.meta > .loc,
.meta > .dur {
    display: grid;
    gap: 2px;
    position: relative;
    padding-left: 22px;
    font-size: .9rem;
    line-height: 1.25;
    color: #374151;
    min-width: 0;
    font-family:"Poppins", sans-serif;
}

/* Labels */
.meta > .loc::before,
.meta > .dur::before {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #9aa1ae;
    line-height: 1;
    position: relative;
    left: -22px;
    font-family:"Urbanist", sans-serif;
}
.meta > .loc::before { content: "Location"; }
.meta > .dur::before { content: "Duration"; }

/* Icons */
.meta .loc::after,
.meta .dur::after {
    position: absolute;
    left: 0;
    top: calc(0.72rem + 4px);
    font-size: .95rem;
    opacity: .9;
}

/* Mobile: stack vertically */
@media (max-width: 480px) {
    .meta { grid-template-columns: 1fr; row-gap: 10px; }
}

/* ===== Badges ===== */
.badges{ display:flex; gap:6px; flex-wrap:wrap }
.badge{
    background:#f8fafc;
    border:1px solid #eef2f7;
    font-size:.72rem;
    padding:4px 8px;
    border-radius:999px;
    font-weight:800;
    font-family:"Poppins", sans-serif;
}

.opt-details{ margin-top:4px }
.options-toggle{ display:flex; align-items:center; gap:8px; cursor:pointer; user-select:none; font-family:"Urbanist", sans-serif; }
.options-toggle .caret{ opacity:.7 }

.options-row{
    display:flex;
    gap:10px;
    padding:8px 0;
    overflow-x:auto;
    overflow-y:hidden;
    flex-wrap:nowrap;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type:x proximity;
}
.opt-card{
    flex:0 0 160px;
    border:1px solid #e6e8f2;
    border-radius:12px;
    background:#fff;
    cursor:pointer;
    scroll-snap-align:start;
}
.opt-card.selected{ outline:2px solid #2563eb; outline-offset:2px }

.opt-thumb{ aspect-ratio: 16/10; overflow:hidden; border-top-left-radius:12px; border-top-right-radius:12px; background:#f8fafc; display:grid; place-items:center }
.opt-thumb img{ width:100%; height:100%; object-fit:cover; display:block }
.no-thumb{ color:#94a3b8; font-size:.85rem; font-family:"Poppins", sans-serif; }
.opt-cap{ padding:8px }
.opt-title{ font-weight:700; font-size:.9rem; color:#111827; font-family:"Figtree", sans-serif; }
.opt-desc{ font-size:.85rem; color:#6b7280; font-family:"Poppins", sans-serif; }

.view-all-btn{
    flex:0 0 auto;
    white-space: nowrap;
    min-width: 150px;
    height: 42px;
    padding: 0 18px;
    font-weight: 700;
    font-size: 15px;
    border-radius: 999px;
    border: 1.5px solid #ccd1d7;
    background: #fff;
    color: #0b0c0d;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all .2s ease;
    margin-left: 2px;
    font-family:"Urbanist", sans-serif;
}
.view-all-btn:hover{ background:#f7f8f9; border-color:#b6bcc3 }

/* ===== CTA ===== */
.actions{ display:flex; gap:8px; margin-top:4px; align-items:center; flex-wrap:wrap }
.btn{
    padding:0 12px;
    border-radius:10px;
    font-weight:850;
    font-size:.9rem;
    height:38px;
    display:inline-grid;
    place-items:center;
    border:0;
    cursor:pointer;
    font-family:"Urbanist", sans-serif;
}
.btn.small{ height:34px; font-size:.88rem }
.btn.green{ background:linear-gradient(90deg,#0ea5e9,#2563eb); color:#fff }
.btn.outline{ background:#fff; color:#1f2937; border:1px solid #d1d5db }
.btn[disabled]{ opacity:.6; cursor:not-allowed }

.hint{ font-size:.85rem; color:#6b7280; font-family:"Poppins", sans-serif; }

/* ===== Gallery Modal ===== */
.gallery-modal { position: fixed; inset: 0; z-index: 2000; display: none; align-items: center; justify-content: center; }
.gallery-modal.show { display: flex; }
.gallery-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.6); }
.gallery-content {
    position: relative; background: #fff; border-radius: 12px; box-shadow: 0 10px 40px rgba(0,0,0,.3);
    width: min(1000px, 92vw); max-height: 90vh; overflow: hidden; z-index: 1; display:grid; grid-template-rows:auto 1fr;
}
.gallery-header{ display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid #eee }
.gallery-title{ font-weight:600; font-family:"Figtree", sans-serif; }
.close-btn{ background:transparent; border:0; font-size:24px; line-height:1; cursor:pointer; padding:6px 8px }

.gallery-scroll{ overflow:auto; padding:12px }
.gallery-stack{ display:grid; gap:12px }

/* big uniform images */
.gallery-image{
    width: 100%;
    height: 520px;
    object-fit: cover;
    border-radius: 8px;
    background: #f2f2f2;
}
@media (max-width: 600px){
    .gallery-image{ height: 320px; }
}
