/* =====================================================================
   Our Dartmoor — front-end styles (self-contained; safe inside YOOtheme)
   Tweak the palette below to taste.
   ===================================================================== */
:root {
    --od-green:    #798d53;
    --od-green-d:  #62733f;
    --od-green-l:  #eef1e6;
    --od-ink:      #24271f;
    --od-granite:  #5b5e60;
    --od-stone:    #f5f4ef;
    --od-line:     #dcd8cf;
    --od-muted:    #71746d;
}

.od-listing { color: var(--od-ink); }
.od-listing a:not(.od-btn) { color: var(--od-green-d); }
.od-listing h1, .od-listing h2, .od-listing h3 { color: var(--od-ink); }

.od-back { font-size: .9rem; margin-bottom: 1rem; }
.od-back a { color: var(--od-granite); text-decoration: none; }
.od-back a:hover { color: var(--od-green-d); }
.od-back .sep { color: var(--od-line); margin: 0 .5rem; }

/* Header */
.od-head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; flex-wrap: wrap; }
.od-head-logo { width: 84px; height: 84px; object-fit: contain; border-radius: .5rem; border: 1px solid var(--od-line); background: #fff; flex: 0 0 auto; }
.od-head h1 { margin: .1rem 0; font-size: 2.2rem; line-height: 1.15; }
.od-head-place { color: var(--od-muted); margin: 0; }
.od-badges { display: flex; gap: .4rem; flex-wrap: wrap; margin-bottom: .25rem; }
.od-badge { font-size: .72rem; font-weight: 600; letter-spacing: .02em; text-transform: uppercase; padding: .18rem .55rem; border-radius: 1rem; background: var(--od-green-l); color: var(--od-green-d); }
.od-badge.is-featured { background: #f3e6c4; color: #8a6d18; }

/* Hero (image-led) */
.od-hero { width: 100%; max-height: 360px; object-fit: cover; border-radius: .6rem; margin-bottom: 1.2rem; }

/* Action row */
.od-actions { display: flex; flex-wrap: wrap; gap: .5rem; margin: 0 0 1.4rem; }
.od-btn { display: inline-flex; align-items: center; gap: .45rem; padding: .55rem .95rem; border-radius: .45rem; font-weight: 600; font-size: .92rem; text-decoration: none; border: 1px solid var(--od-green); background: var(--od-green); color: #fff; cursor: pointer; transition: background .15s; }
.od-btn:hover { background: var(--od-green-d); border-color: var(--od-green-d); color: #fff; }
.od-btn.is-ghost { background: #fff; color: var(--od-green-d); }
.od-btn.is-ghost:hover { background: var(--od-green-l); }

/* Layout */
.od-layout { display: grid; grid-template-columns: 1fr 340px; gap: 1.8rem; align-items: start; }
@media (max-width: 820px) { .od-layout { grid-template-columns: 1fr; } }
.od-body { font-size: 1.05rem; }
.od-body :is(p, ul, ol) { line-height: 1.65; }

/* Cards / sidebar */
.od-card { background: #fff; border: 1px solid var(--od-line); border-radius: .6rem; padding: 1rem 1.1rem; margin-bottom: 1.1rem; }
.od-card h2 { font-size: 1.2rem; text-transform: uppercase; letter-spacing: .03em; color: var(--od-granite); margin: 0 0 .7rem; }
.od-contact { list-style: none; margin: 0; padding: 0; font-size: 1.05rem; }
.od-contact li { margin-bottom: .5rem; }
.od-contact a { word-break: break-word; }

/* Chips (categories / tags) */
.od-chips { display: flex; flex-wrap: wrap; gap: .4rem; }
.od-chip { font-size: .95rem; text-decoration: none; padding: .3rem .7rem; border-radius: 1rem; border: 1px solid var(--od-line); color: var(--od-granite); background: var(--od-stone); }
.od-chip:hover { border-color: var(--od-green); color: var(--od-green-d); }
.od-chip.is-tag { background: var(--od-green-l); border-color: transparent; color: var(--od-green-d); }

/* Social icons */
.od-social { display: flex; flex-wrap: wrap; gap: .5rem; }
.od-social a { width: 46px; height: 46px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; background: var(--od-stone); border: 1px solid var(--od-line); color: var(--od-granite); font-size: 1.25rem; text-decoration: none; transition: all .15s; }
.od-social a:hover { background: var(--od-green); border-color: var(--od-green); color: #fff; transform: translateY(-2px); }

/* Tabs */
.od-tabs { margin-top: 1.4rem; }
.od-tabbar { display: flex; gap: .25rem; border-bottom: 2px solid var(--od-line); margin-bottom: 1rem; flex-wrap: wrap; }
.od-tabbtn { appearance: none; border: 0; background: none; padding: .6rem 1rem; font-weight: 600; color: var(--od-muted); cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -2px; }
.od-tabbtn.is-active { color: var(--od-green-d); border-bottom-color: var(--od-green); }
.od-panel { display: none; }
.od-panel.is-active { display: block; }

/* Gallery - grid */
.od-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: .6rem; }
.od-grid a { display: block; }
.od-grid img { width: 100%; height: 130px; object-fit: cover; border-radius: .45rem; }
.od-grid figcaption { font-size: .78rem; color: var(--od-muted); margin-top: .2rem; }

/* Gallery - carousel */
.od-carousel { display: flex; gap: .6rem; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: .5rem; }
.od-carousel a { flex: 0 0 auto; scroll-snap-align: start; }
.od-carousel img { height: 220px; width: auto; border-radius: .45rem; }

/* Gallery - slideshow */
.od-slideshow { }
.od-slide-stage { position: relative; background: var(--od-stone); border-radius: .5rem; overflow: hidden; }
.od-slide-stage img { display: block; width: 100%; max-height: 460px; object-fit: contain; }
.od-slide-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 42px; height: 42px; border-radius: 50%; border: 0; background: rgba(0,0,0,.45); color: #fff; font-size: 1.2rem; cursor: pointer; }
.od-slide-nav.prev { left: .6rem; } .od-slide-nav.next { right: .6rem; }
.od-slide-thumbs { display: flex; gap: .4rem; margin-top: .5rem; overflow-x: auto; }
.od-slide-thumbs img { height: 56px; width: 76px; object-fit: cover; border-radius: .3rem; cursor: pointer; opacity: .55; border: 2px solid transparent; }
.od-slide-thumbs img.is-active { opacity: 1; border-color: var(--od-green); }

/* Video */
.od-videos .ratio { position: relative; width: 100%; padding-top: 56.25%; margin-bottom: 1rem; }
.od-videos .ratio iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; border-radius: .5rem; }

/* Map */
.od-map { height: 340px; border-radius: .5rem; }

/* =====================================================================
   Stage 2 - directory / category listing pages + map page chrome
   ===================================================================== */
.od-directory h1, .od-categories h1, .od-category h1, .od-map-page h1 {
    font-size: 2rem; color: var(--od-ink); margin: 0 0 1.1rem;
}
.od-category .od-crumb { font-size: .95rem; margin-bottom: .6rem; }
.od-category .od-crumb a { color: var(--od-granite); text-decoration: none; }
.od-category .od-crumb a:hover { color: var(--od-green-d); }
.od-lead { color: var(--od-muted); font-size: 1.05rem; max-width: 60ch; margin: 0 0 1.4rem; }
.od-empty { color: var(--od-muted); font-size: 1.05rem; }

/* Filter bar */
.od-filters { display: flex; gap: .6rem; flex-wrap: wrap; margin-bottom: 1.6rem; }
.od-filters .od-field { flex: 1 1 240px; }
.od-filters .od-field-submit { flex: 0 0 auto; }
.od-input, .od-select { width: 100%; padding: .62rem .8rem; border: 1px solid var(--od-line); border-radius: .45rem; font-size: 1rem; background: #fff; color: var(--od-ink); }
.od-input:focus, .od-select:focus { outline: none; border-color: var(--od-green); box-shadow: 0 0 0 3px var(--od-green-l); }
.od-filters .od-btn { height: 100%; }

/* Listing tiles (directory + category views) - column count set inline via --od-cols */
.od-tiles { display: grid; grid-template-columns: repeat(var(--od-cols, 3), 1fr); gap: 1.3rem; }
@media (max-width: 900px) { .od-tiles { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .od-tiles { grid-template-columns: 1fr; } }
.od-tile { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--od-line); border-radius: .6rem; overflow: hidden; transition: box-shadow .15s, transform .15s; }
.od-tile:hover { box-shadow: 0 7px 20px rgba(0, 0, 0, .1); transform: translateY(-3px); }
.od-tile-img { display: block; aspect-ratio: 3 / 2; background: var(--od-green-l); }
.od-tile-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* Logos (no cover photo): contain + centre on a neutral panel instead of cropping */
.od-tile-img.is-logo { background: #fff; }
.od-tile-img.is-logo img { object-fit: contain; padding: 14px; }
.od-tile-body { padding: .85rem 1rem 1.1rem; display: flex; flex-direction: column; gap: .35rem; flex: 1; }
.od-tile-badges { display: flex; gap: .4rem; flex-wrap: wrap; }
.od-tile h2 { font-size: 1.35rem; margin: .1rem 0 0; line-height: 1.2; }
.od-tile h2 a { color: var(--od-ink); text-decoration: none; }
.od-tile h2 a:hover { color: var(--od-green-d); }
.od-tile-town { color: var(--od-muted); font-size: .95rem; margin: 0; }
.od-tile-text { font-size: .95rem; line-height: 1.5; margin: .15rem 0 0; }

/* Category cards */
.od-cat-group { margin-bottom: 2.6rem; }
.od-cat-group-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; }
.od-cat-group-head h2 { font-size: 1.5rem; color: var(--od-ink); margin: 0 0 .2rem; }
.od-catcards { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1.1rem; margin-top: .7rem; }
.od-catcard { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--od-line); border-radius: .6rem; overflow: hidden; text-decoration: none; transition: box-shadow .15s, transform .15s; }
.od-catcard:hover { box-shadow: 0 7px 20px rgba(0, 0, 0, .1); transform: translateY(-3px); }
.od-catcard-img { aspect-ratio: 3 / 2; background: var(--od-green-l); }
.od-catcard-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.od-catcard-body { padding: .8rem 1rem; }
.od-catcard-title { display: flex; justify-content: space-between; align-items: flex-start; gap: .5rem; font-size: 1.35rem; color: var(--od-ink); margin: 0; }
.od-count { background: var(--od-green-l); color: var(--od-green-d); border-radius: 1rem; padding: .12rem .6rem; font-size: .9rem; font-weight: 600; white-space: nowrap; }
.od-catcard-text { font-size: 1rem; color: var(--od-muted); margin: .4rem 0 0; }

/* Pagination - centred numbers in equal boxes (neutralises Bootstrap page-link) */
.od-pagination { margin-top: 2rem; }
.od-pagination ul, .od-pagination .pagination { display: flex; flex-wrap: wrap; gap: .35rem; list-style: none; padding: 0; margin: 0; justify-content: center; }
.od-pagination li { margin: 0; }
.od-pagination a, .od-pagination span, .od-pagination .page-link {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 2.5em; height: 2.5em; padding: 0 .6rem; margin: 0;
    border: 1px solid var(--od-line); border-radius: .4rem; box-sizing: border-box;
    text-decoration: none; color: var(--od-green-d); background: #fff; font-size: 1rem;
}
.od-pagination a:hover, .od-pagination .page-link:hover { border-color: var(--od-green); background: var(--od-green-l); }
.od-pagination .active span, .od-pagination .active a, .od-pagination .active .page-link { background: var(--od-green); color: #fff; border-color: var(--od-green); }
.od-pagination .disabled span, .od-pagination .disabled .page-link { color: #bbb; }
.od-pagination .counter { margin-top: .7rem; text-align: center; color: var(--od-muted); font-size: .9rem; }

/* Map page chrome */
.od-map-controls { background: #fff; border: 1px solid var(--od-line); border-radius: .6rem; padding: 1rem; margin-bottom: 1rem; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1rem; align-items: start; }
@media (max-width: 820px) { .od-map-controls { grid-template-columns: 1fr; } }
.od-label { font-size: .9rem; color: var(--od-granite); font-weight: 600; display: block; margin-bottom: .3rem; }
.od-input-group { display: flex; }
.od-input-group .od-input { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.od-input-group .od-btn { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.od-place-status { font-size: .9rem; color: #b3261e; margin-top: .3rem; min-height: 1.1em; }
.od-fullmap { height: 72vh; min-height: 440px; border-radius: .6rem; }
.od-pin span { display: block; width: 14px; height: 14px; border-radius: 50%; border: 2px solid #fff; box-shadow: 0 0 2px rgba(0, 0, 0, .5); }
.od-type-filters { display: flex; flex-wrap: wrap; gap: .5rem .9rem; }
.od-type-filter { display: inline-flex; align-items: center; gap: .35rem; cursor: pointer; font-size: .95rem; }
.od-type-filter .swatch { display: inline-block; width: 13px; height: 13px; border-radius: 50%; border: 1px solid #fff; box-shadow: 0 0 1px rgba(0, 0, 0, .4); }
.leaflet-popup-content .od-view-listing { display: inline-block; margin-top: .4rem; color: var(--od-green-d); font-weight: 600; }
.marker-cluster-small, .marker-cluster-medium, .marker-cluster-large { background: rgba(121, 141, 83, .35); }
.marker-cluster-small div, .marker-cluster-medium div, .marker-cluster-large div { background: var(--od-green); color: #fff; font-weight: 600; }

/* =====================================================================
   Events
   ===================================================================== */
.od-events-page h1 { font-size: 2rem; color: var(--od-ink); margin: 0 0 .4rem; }
.od-events-toggle { margin: 0 0 1.5rem; }
.od-events-toggle a { color: var(--od-green-d); text-decoration: none; font-weight: 600; }
.od-events-toggle a:hover { text-decoration: underline; }

.od-events { display: flex; flex-direction: column; gap: 1rem; }
.od-event { display: flex; gap: 1rem; background: #fff; border: 1px solid var(--od-line); border-radius: .6rem; overflow: hidden; transition: box-shadow .15s; }
.od-event:hover { box-shadow: 0 6px 18px rgba(0, 0, 0, .09); }
.od-event-date { flex: 0 0 88px; background: var(--od-green); color: #fff; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: .6rem .3rem; }
.od-event-date .day { font-size: 1.8rem; font-weight: 700; line-height: 1; }
.od-event-date .mon { font-size: .85rem; text-transform: uppercase; letter-spacing: .05em; margin-top: .15rem; }
.od-event-date .yr { font-size: .75rem; opacity: .85; }
.od-event-body { padding: .85rem 1.1rem; flex: 1; min-width: 0; }
.od-event-body h2 { font-size: 1.35rem; margin: 0 0 .25rem; line-height: 1.2; }
.od-event-body h2 a { color: var(--od-ink); text-decoration: none; }
.od-event-body h2 a:hover { color: var(--od-green-d); }
.od-event-when { color: var(--od-muted); font-size: .95rem; margin: 0 0 .3rem; }
.od-event-venue { font-size: .95rem; margin: 0 0 .4rem; }
.od-event-venue a { color: var(--od-green-d); }
.od-event-snippet { font-size: .95rem; line-height: 1.5; margin: 0; }
.od-event-thumb { flex: 0 0 150px; }
.od-event-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 620px) { .od-event-thumb { display: none; } }

/* Single event */
.od-event-single .od-back { margin-bottom: 1rem; }
.od-event-single h1 { font-size: 2.2rem; color: var(--od-ink); margin: 0 0 .5rem; }
.od-event-hero { width: 100%; max-height: 360px; object-fit: cover; border-radius: .6rem; margin: 0 0 1.3rem; }
.od-event-meta { display: flex; flex-direction: column; gap: .5rem; background: var(--od-stone); border: 1px solid var(--od-line); border-radius: .6rem; padding: 1rem 1.1rem; margin-bottom: 1.3rem; font-size: 1.05rem; }
.od-event-meta .row-i { display: flex; gap: .6rem; align-items: flex-start; }
.od-event-meta .row-i i { color: var(--od-green-d); width: 1.2em; text-align: center; margin-top: .2rem; }
.od-event-actions { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1.3rem 0; }

/* Upcoming events block on a listing page */
.od-listing-events { margin-top: 1.6rem; }
.od-listing-events h2 { font-size: 1.3rem; color: var(--od-ink); margin: 0 0 .7rem; }
.od-mini-events { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; }
.od-mini-events li { display: flex; gap: .8rem; align-items: baseline; flex-wrap: wrap; padding: .55rem .8rem; background: var(--od-stone); border: 1px solid var(--od-line); border-radius: .45rem; }
.od-mini-events .od-mini-date { color: var(--od-green-d); font-weight: 600; font-size: .9rem; min-width: 9em; }
.od-mini-events a { color: var(--od-ink); text-decoration: none; font-size: 1.05rem; }
.od-mini-events a:hover { color: var(--od-green-d); }
