/*
Theme Name: Whangamata News
Theme URI: https://whangamata.nz
Author: Whangamata News
Description: Newspaper-style theme for Whangamata modelled on Daily Sabah. Sectioned category blocks, hero+sidebar, most read, 3-column grids.
Version: 2.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: whangamata
*/

/* ── SELF-HOSTED FONTS ── */
@font-face{font-family:'Libre Franklin';font-style:normal;font-weight:400 800;font-display:optional;src:url('/wp-content/themes/whangamata-theme/assets/fonts/libre-franklin-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Libre Franklin';font-style:normal;font-weight:400 800;font-display:optional;src:url('/wp-content/themes/whangamata-theme/assets/fonts/libre-franklin-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700 900;font-display:optional;src:url('/wp-content/themes/whangamata-theme/assets/fonts/playfair-display-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700 900;font-display:optional;src:url('/wp-content/themes/whangamata-theme/assets/fonts/playfair-display-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-rendering:optimizeSpeed}
body{font-family:'Libre Franklin',system-ui,-apple-system,sans-serif;line-height:1.55;color:#222;background:#fff;-webkit-font-smoothing:antialiased;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden}
#main{flex:1}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .15s}
a:hover{color:#b5292a}
ul,ol{list-style:none}

/* ── CONTAINER ── */
.container{max-width:1140px;margin:0 auto;padding:0 20px}

/* ══════════════════════════════════
   TOP BAR
   ══════════════════════════════════ */
.top-bar{background:#f7f7f7;border-bottom:1px solid #e8e8e8;padding:6px 0;font-size:.7rem;color:#888}
.top-bar .container{display:flex;justify-content:space-between;align-items:center}
.top-bar-right,.top-bar-right .top-bar-menu{display:flex;gap:14px;align-items:center}
.top-bar-right a,.top-bar-right .top-bar-menu a{color:#888;font-size:.7rem}
.top-bar-right a:hover,.top-bar-right .top-bar-menu a:hover{color:#222}
.top-bar-right .top-bar-menu li{display:inline}

/* ══════════════════════════════════
   HEADER
   ══════════════════════════════════ */
.site-header{text-align:center;padding:22px 0 0}
.site-logo{font-family:'Playfair Display',Georgia,serif;font-size:2.8rem;font-weight:900;letter-spacing:.02em;color:#1a1a2e;display:inline-block}
.site-logo span{color:#b5292a}
.site-logo-img{display:flex;justify-content:center}
.site-logo-img .custom-logo-link img,.custom-logo-link img{max-height:60px;width:auto}

/* ══════════════════════════════════
   MAIN NAVIGATION
   ══════════════════════════════════ */
.main-nav{border-top:2px solid #1a1a2e;border-bottom:1px solid #ddd;margin-top:14px;position:sticky;top:0;z-index:100;background:#fff;overflow:visible}
.main-nav .container{display:flex;align-items:center;justify-content:space-between;position:relative}
.main-nav ul{display:flex;gap:0;flex-wrap:wrap}
.main-nav li{position:relative}
.main-nav li a{display:block;padding:11px 16px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#333;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;white-space:nowrap}
.main-nav li a:hover,.main-nav .current-menu-item>a,.main-nav .current_page_item>a{color:#b5292a;border-bottom-color:#b5292a}
.nav-right{display:flex;gap:12px;align-items:center}
.nav-search-link{color:#555;display:flex;align-items:center;background:none;border:none;cursor:pointer;padding:0}
.nav-search-link:hover{color:#b5292a}
/* Search overlay */
.nav-search-inline{display:none;align-items:center}
.nav-search-inline.open{display:flex}
.nav-search-inline form{display:flex;align-items:center;gap:4px;border-bottom:2px solid #b5292a;padding-bottom:2px}
.nav-search-inline input[type=search]{border:none;outline:none;background:none;font-size:.78rem;font-family:inherit;color:#1a1a2e;padding:2px 6px;width:200px;caret-color:#b5292a}
.nav-search-inline input[type=search]::placeholder{color:#aaa}
.nav-search-close{background:none;border:none;cursor:pointer;color:#aaa;padding:2px;line-height:0;transition:color .15s}
.nav-search-close:hover{color:#b5292a}

/* Dropdown sub-menus */
.main-nav li>.sub-menu{display:none;position:absolute;top:100%;left:0;background:#fff;border:1px solid #ddd;box-shadow:0 8px 24px rgba(0,0,0,.1);z-index:101;min-width:200px;padding:6px 0;flex-direction:column}
.main-nav li:hover>.sub-menu{display:flex}
.main-nav .sub-menu li{width:100%}
.main-nav .sub-menu li a{padding:8px 18px;font-size:.65rem;border-bottom:none;white-space:nowrap;color:#333}
.main-nav .sub-menu li a:hover{background:#f7f7f7;color:#b5292a}

/* Hamburger */
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:10px}
.menu-toggle span{display:block;width:20px;height:2px;background:#333;margin:4px 0;border-radius:1px;transition:all .3s}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
/* Hide JS-injected accordion arrow on desktop (sub-menus open on hover) */
.sub-menu-toggle{display:none}

/* ══════════════════════════════════
   SECTION LABEL (red bar + uppercase)
   ══════════════════════════════════ */
.section-label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:#1a1a2e;padding:10px 0;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.section-label::before{content:'';width:3px;height:14px;background:#b5292a;display:inline-block;flex-shrink:0}
.section-label a{color:#1a1a2e}
.section-label a:hover{color:#b5292a}

/* ══════════════════════════════════
   CATEGORY TAG
   ══════════════════════════════════ */
.cat-tag{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#b5292a;margin-top:4px;display:inline-block}
.cat-tag:hover{text-decoration:underline}

/* ══════════════════════════════════
   HEADLINE CLASSES
   ══════════════════════════════════ */
.headline-lg{font-family:'Playfair Display',Georgia,serif;font-size:1.45rem;font-weight:700;line-height:1.3;color:#1a1a2e;margin:6px 0 4px}
.headline-md{font-size:.95rem;font-weight:700;line-height:1.35;color:#1a1a2e;margin:4px 0 2px}
.headline-sm{font-size:.85rem;font-weight:700;line-height:1.35;color:#1a1a2e;margin:4px 0 2px}
.headline-xs{font-size:.78rem;font-weight:600;line-height:1.35;color:#1a1a2e;margin:2px 0}
.headline-lg a,.headline-md a,.headline-sm a,.headline-xs a{color:inherit}
.headline-lg a:hover,.headline-md a:hover,.headline-sm a:hover,.headline-xs a:hover{color:#b5292a}

/* ══════════════════════════════════
   HERO SECTION
   ══════════════════════════════════ */
.hero-section{padding:24px 0;border-bottom:1px solid #eee}
.hero-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:22px}
.hero-main .thumb{aspect-ratio:4/3;overflow:hidden;margin-bottom:10px;background:#f0f0f0}
.hero-main .thumb img{width:100%;height:100%;object-fit:cover}
.hero-sidebar{display:flex;flex-direction:column;gap:16px}
.hero-side-item{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-bottom:14px;border-bottom:1px solid #f0f0f0}
.hero-side-item:last-child{border-bottom:none;padding-bottom:0}
.hero-side-item .thumb{aspect-ratio:16/10;overflow:hidden;background:#f0f0f0}
.hero-side-item .thumb img{width:100%;height:100%;object-fit:cover}

/* ══════════════════════════════════
   4-COL CARDS
   ══════════════════════════════════ */
.cards-section{padding:24px 0;border-bottom:1px solid #eee}
.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card-item .thumb{aspect-ratio:16/10;overflow:hidden;margin-bottom:6px;background:#f0f0f0}
.card-item .thumb img{width:100%;height:100%;object-fit:cover}

/* ══════════════════════════════════
   TRIPLE SECTION (2 cat cols + most read)
   ══════════════════════════════════ */
.triple-section{padding:24px 0;border-bottom:1px solid #eee}
.triple-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:28px}
.triple-col .section-label{border-bottom:1px solid #eee;padding-bottom:8px}
.col-main-item{margin-bottom:10px}
.col-main-item .thumb{aspect-ratio:16/10;overflow:hidden;margin-bottom:8px;background:#f0f0f0}
.col-main-item .thumb img{width:100%;height:100%;object-fit:cover}
.col-text-item{padding:8px 0;border-bottom:1px solid #f0f0f0}
.col-text-item:last-child{border-bottom:none}

/* ══════════════════════════════════
   3-COL SECTIONS
   ══════════════════════════════════ */
.three-col-section{padding:24px 0;border-bottom:1px solid #eee}
.three-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.three-item .thumb{aspect-ratio:16/10;overflow:hidden;margin-bottom:8px;background:#f0f0f0}
.three-item .thumb img{width:100%;height:100%;object-fit:cover}
.three-item .section-label{margin-bottom:10px}
.excerpt{font-size:.82rem;color:#555;line-height:1.55;margin-top:4px}
.meta-line{font-size:.68rem;color:#999;margin-top:6px;display:flex;gap:12px}
.meta-date{font-size:.68rem;color:#999}

/* ══════════════════════════════════
   MOST READ
   ══════════════════════════════════ */
.most-read-item{display:flex;gap:10px;align-items:flex-start;padding:8px 0;border-bottom:1px solid #f5f5f5}
.most-read-item:last-child{border-bottom:none}
.mr-num{font-family:'Playfair Display',Georgia,serif;font-size:1.6rem;font-weight:900;color:#ddd;line-height:1;min-width:28px}

/* ══════════════════════════════════
   SIDE STORY (thumb + text)
   ══════════════════════════════════ */
.side-story{display:grid;grid-template-columns:80px 1fr;gap:10px;padding:8px 0;border-bottom:1px solid #f0f0f0;align-items:start}
.side-story:last-child{border-bottom:none}
.side-story .thumb{aspect-ratio:1/1;overflow:hidden;background:#f0f0f0}
.side-story .thumb img{width:100%;height:100%;object-fit:cover}

/* ══════════════════════════════════
   POSTS LIST (fallback / paginated)
   ══════════════════════════════════ */
.posts-list{padding:20px 0}
.list-item{padding:18px 0;border-bottom:1px solid #eee}
.list-item:first-child{padding-top:0}
.list-item .headline-md{margin-bottom:4px}
.list-item .excerpt{margin-bottom:4px}

/* ══════════════════════════════════
   ARCHIVE
   ══════════════════════════════════ */
.archive-header{padding:20px 0 10px}
.archive-title{font-family:'Playfair Display',Georgia,serif;font-size:1.8rem;font-weight:700;color:#1a1a2e}
.archive-desc{font-size:.88rem;color:#666;margin-top:4px}

/* ══════════════════════════════════
   BREADCRUMBS
   ══════════════════════════════════ */
.breadcrumbs{font-size:.72rem;color:#888;padding:12px 0 4px}
.breadcrumbs a{color:#666;font-weight:500}
.breadcrumbs a:hover{color:#b5292a}
.breadcrumbs .sep{margin:0 5px;color:#ccc}

/* ══════════════════════════════════
   ARTICLE (single post)
   ══════════════════════════════════ */
.article-layout{display:grid;grid-template-columns:1fr 320px;gap:36px;padding:20px 0 40px}
.article-layout>.site-main{min-width:0}
.article-title{font-family:'Playfair Display',Georgia,serif;font-size:2.2rem;font-weight:700;line-height:1.25;color:#1a1a2e;margin:6px 0 14px}
.article-meta{display:flex;gap:18px;font-size:.78rem;color:#888;padding-bottom:14px;border-bottom:1px solid #eee;margin-bottom:18px;flex-wrap:wrap}
.article-meta .author{font-weight:700;color:#333}
.article-meta .reading-time{color:#b5292a;font-weight:600}
.article-featured{margin-bottom:22px;overflow:hidden}
.article-featured img{width:100%;aspect-ratio:21/9;object-fit:cover}

/* ── ENTRY CONTENT ── */
.entry-content p{margin-bottom:1.4rem;font-size:1rem;line-height:1.8;color:#333}
.entry-content h2{font-family:'Playfair Display',Georgia,serif;font-size:1.35rem;font-weight:700;margin:2rem 0 .7rem;color:#1a1a2e}
.entry-content h3{font-size:1.1rem;font-weight:700;margin:1.5rem 0 .6rem;color:#1a1a2e}
.entry-content blockquote{border-left:3px solid #b5292a;padding:14px 18px;margin:1.5rem 0;background:#faf5f5;font-style:italic;color:#444;line-height:1.7}
.entry-content ul,.entry-content ol{margin:1rem 0 1.5rem 1.5rem}
.entry-content li{margin-bottom:.4rem;line-height:1.6}
.entry-content ul li{list-style:disc}
.entry-content ol li{list-style:decimal}
.entry-content a{color:#1a6b7a;text-decoration:underline;text-underline-offset:2px}
.entry-content figure{margin:1.5rem 0}
.entry-content figcaption{font-size:.72rem;color:#888;margin-top:.4rem}
.entry-content .table-wrap,.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.5rem 0;max-width:100%;-ms-overflow-style:-ms-autohiding-scrollbar}
.entry-content table{border-collapse:collapse;margin:0}
.table-responsive table{display:table!important;width:auto!important;min-width:480px}
.entry-content th,.entry-content td{border:1px solid #ddd;padding:.6rem .75rem;font-size:.83rem;text-align:left;white-space:nowrap}
.entry-content td:last-child,.entry-content th:last-child{white-space:normal;min-width:140px}
.entry-content tbody th,.entry-content tfoot th{background:#f4f4f4;font-weight:600}
.entry-content thead th{background:transparent;font-weight:700}
.entry-content img{max-width:100%;height:auto}

/* ── TAGS ── */
.post-tags{margin-top:20px;display:flex;gap:6px;flex-wrap:wrap}
.post-tags a{padding:4px 12px;background:#f5f5f5;border:1px solid #eee;font-size:.7rem;font-weight:600;color:#555;transition:all .15s}
.post-tags a:hover{border-color:#b5292a;color:#b5292a}

/* ── POST NAV ── */
.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:40px;padding-top:30px;border-top:1px solid #e0e0e0}
.post-nav a{display:flex;flex-direction:column;padding:16px 20px;border:1px solid #e0e0e0;border-radius:10px;text-decoration:none;transition:all .2s ease}
.post-nav a:hover{border-color:#ccc;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.post-nav .nav-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:#888;margin-bottom:4px}
.post-nav .nav-label::before{content:"\2190 "}
.post-nav .nav-next .nav-label::before{content:""}
.post-nav .nav-next .nav-label::after{content:" \2192"}
.post-nav .nav-title{font-size:.9rem;font-weight:600;color:#1a1a2e;line-height:1.4}
.post-nav .nav-next{text-align:right}

/* ── PAGINATION ── */
.pagination{display:flex;justify-content:center;gap:4px;padding:24px 0}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:#fff;border:1px solid #ddd;font-size:.8rem;font-weight:600;color:#555}
.pagination .page-numbers:hover{border-color:#b5292a;color:#b5292a}
.pagination .page-numbers.current{background:#b5292a;border-color:#b5292a;color:#fff}


/* ── SEARCH FORM ── */
.search-form{display:flex;gap:0}
.search-field{flex:1;padding:8px 12px;border:1px solid #ddd;font-size:.85rem;font-family:inherit}
.search-field:focus{border-color:#b5292a;outline:none}
.search-submit{background:#b5292a;color:#fff;border:none;padding:8px 16px;font-weight:700;font-size:.75rem;cursor:pointer;font-family:inherit}
.search-submit:hover{background:#8a1a1a}

/* ── SIDEBAR / WIDGETS ── */
.sidebar{display:flex;flex-direction:column;gap:20px}
.widget{margin-bottom:0}
.widget-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:#1a1a2e;padding:8px 0;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.widget-title::before{content:'';width:3px;height:14px;background:#b5292a;display:inline-block;flex-shrink:0}
.widget ul li{padding:5px 0;border-bottom:1px solid #f0f0f0;font-size:.82rem}
.widget ul li:last-child{border-bottom:none}
.widget ul li a{color:#333}
.widget ul li a:hover{color:#b5292a}

/* ══════════════════════════════════
   FOOTER
   ══════════════════════════════════ */
.site-footer{background:#1a1a2e;color:#999;margin-top:10px}
.footer-logo{font-family:'Playfair Display',Georgia,serif;font-size:1.8rem;font-weight:900;color:#fff;text-align:center;padding:28px 0 18px;letter-spacing:.02em}
.footer-logo span{color:#b5292a}
.footer-logo .custom-logo-link{display:flex;justify-content:center}
.footer-logo .custom-logo-link img{max-height:50px;filter:brightness(0) invert(1)}
.footer-columns{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;width:100%;padding:0 0 24px;border-bottom:1px solid #2a2a3e}
.footer-col-title,.footer-col .widget-title{font-size:.85rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:8px;padding:0;display:block}
.footer-col .widget-title::before{display:none}
.footer-col ul li{padding:2px 0;border-bottom:none}
.footer-col ul li a{font-size:.9rem;color:#d6dce5;transition:color .15s}
.footer-col ul li a:hover{color:#fff}
.footer-social{text-align:center;padding:16px 0 8px}.footer-social a{display:inline-flex;align-items:center;gap:8px;color:#d6dce5;text-decoration:none;font-size:.95rem;transition:color .2s}.footer-social a:hover{color:#1877f2}.footer-social svg{vertical-align:middle}
.footer-bottom-bar{text-align:center;padding:14px 0 0}
.footer-bottom-bar .footer-nav ul{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.footer-bottom-bar .footer-nav a{font-size:.9rem;color:#d6dce5}
.footer-bottom-bar .footer-nav a:hover{color:#fff}
.footer-bottom{text-align:center;padding:12px 0 20px;font-size:.85rem;color:#999}

/* ── AUTHOR BOX ── */
.author-box{display:flex;gap:18px;align-items:flex-start;padding:24px;margin:30px 0 10px;background:#f8f9fa;border:1px solid #e8e8e8;border-radius:8px}
.author-box-avatar{flex-shrink:0}
.author-box-avatar img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.1)}
.author-box-info{flex:1;min-width:0}
.author-box-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:#999;margin-bottom:2px;font-family:'Libre Franklin',sans-serif}
.author-box-name{margin:0 0 8px;font-size:1.05rem;font-family:'Playfair Display',serif;color:#1a1a2e;font-weight:700}
.author-box-bio{margin:0;font-size:.82rem;line-height:1.6;color:#555;font-family:'Libre Franklin',sans-serif}
@media(max-width:600px){
.author-box{flex-direction:column;align-items:center;text-align:center;padding:20px 16px}
.author-box-avatar img{width:64px;height:64px}
}

/* ── IMAGE CREDITS ── */
.image-credit{font-size:.72rem;color:#888;padding:4px 0 2px;line-height:1.4;font-style:italic}
.article-featured .image-credit{margin-top:6px}
.entry-content figure .image-credit{margin-top:2px}

/* ── ROUTE MAP ── */
[id^="route-map-"]{width:100%;border-radius:8px;margin:20px 0;border:1px solid #ddd}
.wn-map-marker span{display:block;width:14px;height:14px;background:#b5292a;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.leaflet-popup-content strong{color:#1a1a2e}
.map-directions-btns{display:flex;gap:10px;padding:10px 0}
.dir-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:8px;text-decoration:none !important;font-weight:600;font-size:14px;transition:all .2s ease;box-shadow:0 2px 4px rgba(0,0,0,.1)}
.dir-btn i{font-size:18px}
.dir-btn-google{background:#fff;color:#1a73e8 !important;border:2px solid #1a73e8}
.dir-btn-google:hover{background:#1a73e8;color:#fff !important}
.dir-btn-waze{background:#fff;color:#1A6B7A !important;border:2px solid #1A6B7A}
.dir-btn-waze:hover{background:#1A6B7A;color:#fff !important}

/* ── TRAVEL GUIDE ROUTE MAP ── */
.tg-route-map-wrap{margin:20px 0 28px;border-radius:10px;overflow:hidden;border:1px solid #ddd;background:#f8f9fa}
.tg-route-map{width:100%;height:380px}
.tg-route-info{display:flex;gap:20px;padding:10px 16px;background:#f8f9fa;font-family:'Libre Franklin',sans-serif;font-size:.88rem;color:#444;border-top:1px solid #e8e8e8}
.tg-route-info span{display:inline-flex;align-items:center;gap:6px;font-weight:600}
.tg-route-info svg{color:#1a6b7a;flex-shrink:0}
.tg-route-btns{display:flex;gap:10px;padding:12px 16px;background:#f8f9fa;border-top:1px solid #e8e8e8}
.tg-route-btns .dir-btn{flex:1;justify-content:center}
.tg-route-btns .dir-btn svg{flex-shrink:0}
.tg-marker span{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-family:'Libre Franklin',sans-serif;font-weight:700;font-size:13px;color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.3);border:2px solid #fff}
.tg-marker-start span{background:#1a6b7a}
.tg-marker-end span{background:#b5292a}
@media(max-width:600px){
.tg-route-map{height:280px}
.tg-route-btns{flex-direction:column}
.tg-route-info{flex-direction:column;gap:6px}
}

/* ── WIKIMEDIA IMAGE CREDITS ── */
.tg-wm-image{margin:24px 0;border-radius:8px;overflow:hidden}
.tg-wm-image img{width:100%;height:auto;display:block;border-radius:8px 8px 0 0}
.tg-wm-image figcaption{padding:8px 2px 4px}
.wm-license{display:block;font-size:.72rem;color:#aaa;font-family:'Libre Franklin',sans-serif;font-weight:400;line-height:1.3}
.wm-desc{display:block;font-size:1.05rem;color:#444;font-family:'Caveat',cursive;font-weight:600;line-height:1.3;margin-top:2px}

/* ── LOCATION CARDS ── */
.loc-card{margin:20px 0 28px;border-radius:12px;border:1px solid #e0e0e0;overflow:hidden;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.loc-card-header{padding:16px 20px 12px;border-bottom:1px solid #f0f0f0}
.loc-card-header h3{margin:0 0 4px;font-family:'Playfair Display',serif;font-size:1.2rem;color:#1a1a2e}
.loc-card-type{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;text-transform:uppercase;letter-spacing:1px;color:#1a6b7a;font-weight:700;font-family:'Libre Franklin',sans-serif}
.loc-card-type svg{width:14px;height:14px;fill:#1a6b7a}
.loc-card-body{padding:14px 20px}
.loc-card-body p{margin:0 0 10px;font-size:.9rem;line-height:1.65;color:#444}
.loc-card-meta{display:flex;flex-wrap:wrap;gap:10px 18px;padding:0 20px 14px}
.loc-meta-item{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:#555;font-family:'Libre Franklin',sans-serif}
.loc-meta-item svg{width:16px;height:16px;flex-shrink:0;color:#1a6b7a;fill:none;stroke:currentColor;stroke-width:2}
.loc-meta-item strong{color:#1a1a2e;font-weight:600}
.loc-card-map{width:100%;height:260px;border:0;border-top:1px solid #f0f0f0}
.loc-card-footer{display:flex;gap:10px;padding:12px 20px;background:#f8f9fa;border-top:1px solid #f0f0f0}
.loc-card-footer a{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:6px;font-size:.8rem;font-weight:600;text-decoration:none;transition:all .2s;color:#fff}
.loc-card-footer a:visited,.loc-card-footer a:hover{color:#fff}
.loc-btn-dir{background:#1a6b7a;color:#fff}
.loc-btn-dir:hover{background:#145a66;color:#fff}
.loc-btn-sec{background:#1a6b7a;color:#fff;border:1.5px solid #1a6b7a}
.loc-btn-sec:hover{background:#145a66;color:#fff}
.loc-badge-yes{color:#1a6b7a;font-weight:700}
.loc-badge-no{color:#b5292a;font-weight:700}
.loc-badge-cond{color:#c97a1a;font-weight:700}
@media(max-width:600px){
.loc-card-meta{flex-direction:column;gap:8px}
.loc-card-map{height:200px}
.loc-card-footer{flex-direction:column}
}

/* ── PERFORMANCE: content-visibility for below-fold ── */
.sidebar{content-visibility:auto;contain-intrinsic-size:auto 800px}
.post-nav{content-visibility:auto;contain-intrinsic-size:auto 100px}
.loc-card{content-visibility:auto;contain-intrinsic-size:auto 500px}
.author-box{content-visibility:auto;contain-intrinsic-size:auto 120px}
.post-tags{content-visibility:auto;contain-intrinsic-size:auto 40px}

/* ── 404 ── */
.error-404{text-align:center;padding:60px 20px}
.error-404 h1{font-family:'Playfair Display',Georgia,serif;font-size:4rem;font-weight:900;color:#b5292a;margin-bottom:10px}
.error-404 p{font-size:1rem;color:#666;margin-bottom:20px}
.no-results{text-align:center;padding:40px 0}

/* ── ACCESSIBILITY ── */
.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute!important;height:1px;width:1px;overflow:hidden;word-wrap:normal!important}
.screen-reader-text:focus{background:#f1f1f1;box-shadow:0 0 2px 2px rgba(0,0,0,.6);clip:auto!important;display:block;font-size:.875rem;font-weight:700;height:auto;left:5px;padding:15px 23px;top:5px;width:auto;z-index:100000}
:focus-visible{outline:2px solid #b5292a;outline-offset:2px}

/* ══════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════ */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .triple-grid{grid-template-columns:1fr}
  .triple-col{margin-bottom:10px}
  .three-grid{grid-template-columns:repeat(2,1fr)}
  .article-layout{grid-template-columns:1fr}
  .sidebar{display:none}
  .article-featured img{aspect-ratio:16/9}
  .article-title{font-size:1.7rem}
  .footer-columns{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:600px){
  .top-bar{display:none}
  .site-logo{font-size:2rem}
  .main-nav ul{display:none}
  .main-nav.toggled ul{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid #ddd;box-shadow:0 8px 24px rgba(0,0,0,.1);z-index:99;padding:0;max-height:70vh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
  body.menu-open{overflow:hidden;height:100%}
  .main-nav li a{padding:12px 20px;border-bottom:1px solid #f0f0f0;font-size:.78rem}
  .main-nav li>.sub-menu{position:static;box-shadow:none;border:none;min-width:0;display:none;background:#f5f5f5;padding:0;width:100%;flex-direction:column}
  .main-nav li:hover>.sub-menu{display:none}
  .main-nav.toggled li.sub-open>.sub-menu{display:flex;flex-direction:column}
  .main-nav .sub-menu li a{padding:11px 20px 11px 32px;font-size:.75rem;color:#555;border-bottom:1px solid #ebebeb;white-space:normal}
  /* Accordion: parent li flex row so arrow sits beside the link */
  .main-nav.toggled .menu-item-has-children{display:flex;flex-wrap:wrap;align-items:stretch;border-bottom:1px solid #f0f0f0}
  .main-nav.toggled .menu-item-has-children>a{flex:1;border-bottom:none;padding-right:0}
  .sub-menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:0 16px;color:#888;flex-shrink:0;line-height:1;align-items:center;justify-content:center}
  .main-nav.toggled .sub-menu-toggle{display:flex}
  .sub-menu-toggle svg{transition:transform .25s ease}
  .main-nav.toggled .sub-open>.sub-menu-toggle svg{transform:rotate(180deg)}
  .main-nav.toggled .sub-open>.sub-menu-toggle{color:#b5292a}
  .menu-toggle{display:block}
  /* Search en mobile: ocupa todo el ancho del nav */
  .nav-search-inline.open{position:absolute;left:0;right:0;top:0;height:100%;background:#fff;z-index:200;padding:0 16px;box-sizing:border-box}
  .nav-search-inline.open form{width:100%;height:100%;align-items:center}
  .nav-search-inline input[type=search]{width:100%;font-size:.9rem;padding:4px 8px}
  .cards-grid,.three-grid{grid-template-columns:1fr}
  .hero-side-item{grid-template-columns:1fr 1fr}
  .footer-columns{grid-template-columns:repeat(2,1fr)}
  .article-title{font-size:1.5rem}
  .headline-lg{font-size:1.15rem}
  .article-layout{gap:24px}
}

/* ══════════════════════════════════
   BUSINESS DIRECTORY
   ══════════════════════════════════ */

/* ── Sort Bar ── */
.biz-sort-bar{display:flex;align-items:center;gap:6px;padding:16px 0 24px;flex-wrap:wrap;border-bottom:1px solid #f0f0f0;margin-bottom:24px}
.biz-sort-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#aaa;margin-right:6px}
.biz-sort-btn{padding:7px 18px;background:#fff;border:1px solid #e0e0e0;border-radius:2px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#666;cursor:pointer;transition:all .15s;white-space:nowrap}
.biz-sort-btn:hover{border-color:#1a1a2e;color:#1a1a2e}
.biz-sort-btn.active{background:#1a1a2e;border-color:#1a1a2e;color:#fff}

/* ── Card Grid (3 col) ── */
.biz-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.biz-card{background:#fff;border:1px solid #ebebeb;border-radius:4px;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}
.biz-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.1)}
.biz-card-img{aspect-ratio:3/2;overflow:hidden;background:#f4f4f4}
.biz-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.biz-card:hover .biz-card-img img{transform:scale(1.04)}
.biz-card-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f0f0 0%,#e4e4e4 100%)}
.biz-card-placeholder i{font-size:2.8rem;color:#c8c8c8}
.biz-card-body{padding:14px 16px 18px}
.biz-card-body .cat-tag{margin-bottom:6px;font-size:.58rem;letter-spacing:.14em}
.biz-card-body .headline-sm{margin:4px 0 8px;font-size:.9rem;line-height:1.3}
.biz-card-stars{display:flex;align-items:center;gap:5px;font-size:.75rem;color:#f5a623;margin-bottom:8px}
.biz-card-stars span{color:#333;font-weight:700;font-size:.8rem}
.biz-card-stars .biz-review-count{color:#aaa;font-weight:400;font-size:.7rem}
.biz-card-address{font-size:.72rem;color:#999;display:flex;align-items:flex-start;gap:5px;line-height:1.4}
.biz-card-address i{color:#b5292a;font-size:.6rem;margin-top:3px;flex-shrink:0}

/* ── Single Business ── */
.biz-meta-line{display:flex;gap:18px;font-size:.82rem;color:#666;padding:6px 0 14px;flex-wrap:wrap}
.biz-meta-line i{color:#b5292a;margin-right:4px;font-size:.75rem}
.biz-meta-line a{color:#b5292a}

/* ── Map Section ── */
.biz-map-section{margin:20px 0}
#biz-map{height:300px;width:100%;border-radius:8px;border:1px solid #ddd}

/* ── Apple Maps Button ── */
.dir-btn-apple{background:#fff;color:#333;border:2px solid #333}
.dir-btn-apple:hover{background:#333;color:#fff}

/* ── Google Rating Display ── */
.biz-google-rating{display:flex;align-items:center;gap:8px;padding:16px 0 6px;font-size:.9rem}
.biz-stars{color:#f5a623;display:flex;gap:1px;font-size:.9rem}
.biz-rating-num{font-weight:700;color:#333}
.biz-review-count{color:#888;font-size:.82rem}
.biz-stars-sm{font-size:.68rem;color:#f5a623}
.biz-stars-sm .fas,.biz-stars-sm .far,.biz-stars-sm .fa-star-half-alt{font-size:.65rem}

/* ── Google Review Snippets ── */
.biz-reviews{padding:8px 0 16px;border-bottom:1px solid #eee;margin-bottom:16px}
.biz-review-item{padding:10px 0;border-top:1px solid #f0f0f0}
.biz-review-item:first-child{border-top:none}
.biz-review-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.biz-review-header strong{font-size:.82rem;color:#333}
.biz-review-stars{color:#f5a623;font-size:.72rem}
.biz-review-item p{font-size:.82rem;color:#555;line-height:1.5;font-style:italic;margin:0}

/* ── Interactive Star Rating ── */
.biz-user-rating{padding:18px 0;border-bottom:1px solid #eee;margin-bottom:16px}
.biz-user-rating h3{font-size:.9rem;font-weight:700;margin-bottom:8px;color:#1a1a2e}
.biz-stars-interactive{display:flex;gap:4px}
.biz-star-btn{background:none;border:none;cursor:pointer;padding:2px;font-size:1.4rem;color:#ddd;transition:color .1s,transform .1s}
.biz-star-btn:hover{transform:scale(1.15)}
.biz-star-btn .fas{color:#f5a623}
.biz-star-btn .far{color:#ddd}
.biz-star-btn.active .far{color:#f5a623}
.biz-user-avg{margin-top:6px;font-size:.78rem;color:#888}
.biz-user-avg-num{font-weight:700;color:#333}

/* ── Vibe Tags ── */
.biz-vibe-tags{display:flex;gap:8px;flex-wrap:wrap;padding:0 0 18px;border-bottom:1px solid #eee;margin-bottom:16px}
.vibe-tag-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:20px;cursor:pointer;font-size:.78rem;font-weight:600;color:#555;font-family:inherit;transition:all .15s}
.vibe-tag-btn:hover{border-color:#b5292a;color:#b5292a}
.vibe-tag-btn.active{background:#fef2f2;border-color:#b5292a;color:#b5292a}
.vibe-tag-btn i{font-size:.72rem}
.vibe-count{background:#eee;padding:1px 7px;border-radius:10px;font-size:.68rem;font-weight:700;color:#666}
.vibe-tag-btn.active .vibe-count{background:#b5292a;color:#fff}

/* ── Details Card ── */
.biz-details-card{background:#f9f9f9;border:1px solid #eee;border-radius:8px;padding:18px;margin:20px 0}
.biz-details-heading{font-size:1.1rem;font-weight:700;margin:0 0 12px;padding-bottom:10px;border-bottom:2px solid #b5292a}
.biz-detail-row{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid #eee;align-items:flex-start}
.biz-detail-row:last-child{border-bottom:none}
.biz-detail-row>i{color:#b5292a;font-size:.9rem;margin-top:2px;min-width:18px;text-align:center}
.biz-detail-row strong{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#888;margin-bottom:2px}
.biz-detail-row span,.biz-detail-row a{font-size:.85rem;color:#333}
.biz-detail-row a{color:#b5292a}

/* ── Responsive ── */
@media(max-width:900px){
  .biz-grid{grid-template-columns:repeat(2,1fr);gap:16px}
}
@media(max-width:600px){
  .biz-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .biz-card-body{padding:10px 12px 14px}
  .biz-card-body .headline-sm{font-size:.82rem}
  .biz-google-rating{flex-wrap:wrap}
  .biz-meta-line{flex-direction:column;gap:6px}
  .biz-vibe-tags{gap:6px}
  .vibe-tag-btn{padding:6px 10px;font-size:.72rem}
  #biz-map{height:220px}
  .map-directions-btns{flex-wrap:wrap}
  .dir-btn{padding:8px 12px;font-size:.78rem}
}

/* ══════════════════════════════════
   BUSINESS BADGE SYSTEM
   ══════════════════════════════════ */

/* ── Section wrapper ── */
.wn-badge-section{margin:32px 0 24px;padding:28px 32px;background:#fdfaf2;border:1px solid #e8d89a;border-radius:4px}

/* ── Title ── */
.wn-badge-title{font-family:'Playfair Display',Georgia,serif;font-size:1.15rem;font-weight:700;color:#1a1a2e;margin:0 0 6px;display:flex;align-items:center}
.wn-badge-subtitle{font-size:.82rem;color:#999;margin:0 0 20px}

/* ── Tabs ── */
.wn-badge-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid #e8d89a}
.wn-badge-tab{padding:9px 22px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#aaa;cursor:pointer;font-family:inherit;transition:all .15s}
.wn-badge-tab:hover{color:#C9952A}
.wn-badge-tab--active{color:#C9952A;border-bottom-color:#C9952A}

/* ── Preview area ── */
.wn-badge-preview-area{display:flex;justify-content:center;align-items:center;padding:32px 20px;min-height:380px;background:#fff;border:1px solid #f0e8c8;border-radius:4px;margin-bottom:20px}
.wn-badge-preview-inner{display:flex;justify-content:center;align-items:center;width:100%}

/* ── Embed code ── */
.wn-badge-embed{}
.wn-badge-embed-label{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#bbb;margin-bottom:8px}
.wn-badge-embed-row{display:flex;gap:10px;align-items:stretch}
.wn-badge-code{flex:1;font-size:.68rem;font-family:'Courier New',monospace;background:#f8f5eb;border:1px solid #e0d49a;border-radius:4px;padding:10px 12px;resize:none;color:#666;height:80px;line-height:1.6}
.wn-badge-code:focus{outline:none;border-color:#C9952A}
.wn-badge-copy{flex-shrink:0;background:#C9952A;color:#fff;border:none;border-radius:4px;padding:0 20px;font-size:.75rem;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s;display:flex;align-items:center;gap:7px;white-space:nowrap}
.wn-badge-copy:hover{background:#a67d20}
.wn-badge-copy.copied{background:#2a7a3b}

/* ── Responsive ── */
@media(max-width:600px){
  .wn-badge-section{padding:20px 16px}
  .wn-badge-tabs{flex-wrap:wrap}
  .wn-badge-embed-row{flex-direction:column}
  .wn-badge-copy{width:100%;justify-content:center;padding:10px}
}

/* ══════════════════════════════════════════════════
   BUSINESS GUIDE CARDS — hero + card layout for
   posts containing [business_listing] shortcode
   ══════════════════════════════════════════════════ */

/* -- Hero Banner -- */
.guide-hero{position:relative;padding:60px 40px 80px;overflow:hidden;background:linear-gradient(170deg,#0e4a55 0%,#1a6b7a 40%,#2d97ab 100%);color:#fff8f0;text-align:center;margin:-20px -40px 40px}
.guide-hero::before{content:'';position:absolute;bottom:-2px;left:0;right:0;height:60px;background:#fff;clip-path:ellipse(55% 100% at 50% 100%)}
.guide-hero::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 30 Q15 20 30 30 Q45 40 60 30' fill='none' stroke='rgba(255,255,255,0.04)' stroke-width='1.5'/%3E%3C/svg%3E");background-size:60px 60px;animation:guideWave 8s linear infinite}
@keyframes guideWave{0%{background-position:0 0}100%{background-position:60px 0}}
.guide-hero-content{position:relative;z-index:2;max-width:700px;margin:0 auto}
.guide-hero-label{display:inline-block;font-size:11px;letter-spacing:3px;text-transform:uppercase;font-weight:600;color:#f0b89a;margin-bottom:16px}
.guide-hero h1{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;line-height:1.2;margin-bottom:16px}
.guide-hero p{font-size:1rem;font-weight:300;line-height:1.7;color:rgba(255,255,255,0.8);max-width:560px;margin:0 auto}

/* -- Section Headers -- */
.guide-section-header{display:flex;align-items:center;gap:16px;margin:48px 0 32px;padding:0}
.guide-section-icon{width:44px;height:44px;border-radius:50%;background:#1a6b7a;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.guide-section-icon svg{width:20px;height:20px;fill:none;stroke:#fff8f0;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.guide-section-header h2{font-family:'Playfair Display',Georgia,serif;font-size:1.4rem;font-weight:700;color:#0e4a55;margin:0;line-height:1.3}
.guide-section-header p{font-size:0.9rem;color:#4a4a42;font-weight:300;margin-top:2px}
.guide-section-line{flex:1;height:1px;background:#b8a68a;opacity:0.3}

/* -- Business Cards -- */
.guide-card-grid{display:flex;flex-direction:column;gap:28px;margin-bottom:40px}
.guide-card{background:#fff;border-radius:16px;overflow:hidden;display:grid;grid-template-columns:240px 1fr;box-shadow:0 2px 16px rgba(0,0,0,0.04),0 0 0 1px rgba(0,0,0,0.03);transition:transform 0.3s ease,box-shadow 0.3s ease}
.guide-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,0.08)}

/* Card image */
.guide-card-visual{position:relative;background:linear-gradient(135deg,#d4eef2 0%,#e8e0d0 100%);display:flex;align-items:center;justify-content:center;min-height:260px;overflow:hidden}
.guide-card-visual img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.guide-card-visual .placeholder-icon{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.7);display:flex;align-items:center;justify-content:center}
.guide-card-visual .placeholder-icon svg{width:20px;height:20px;stroke:#1a6b7a;fill:none;stroke-width:1.5}

/* Rating badge */
.guide-rating-badge{position:absolute;top:12px;left:12px;background:rgba(255,255,255,0.92);backdrop-filter:blur(8px);padding:5px 10px;border-radius:24px;display:flex;align-items:center;gap:4px;font-size:0.8rem;font-weight:600;color:#0e4a55;z-index:2}
.guide-rating-badge svg{width:13px;height:13px;fill:#e8926a}
.guide-rating-badge .reviews{font-weight:300;color:#4a4a42;font-size:0.75rem}

/* Card content */
.guide-card-body{padding:28px 32px;display:flex;flex-direction:column}
.guide-card-name{font-family:'Playfair Display',Georgia,serif;font-size:1.25rem;font-weight:700;color:#222;margin-bottom:4px;line-height:1.3}
.guide-card-name a{color:inherit;text-decoration:none}
.guide-card-name a:hover{color:#1a6b7a}
.guide-card-address{font-size:0.82rem;color:#8b7355;display:flex;align-items:center;gap:4px;margin-bottom:14px}
.guide-card-address svg{width:13px;height:13px;stroke:#b8a68a;fill:none;stroke-width:2;flex-shrink:0}
.guide-card-desc{font-size:0.9rem;line-height:1.7;color:#4a4a42;font-weight:300;margin-bottom:16px}
.guide-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.guide-card-tag{font-size:0.72rem;font-weight:500;letter-spacing:0.5px;text-transform:uppercase;padding:4px 12px;border-radius:24px;background:#d4eef2;color:#0e4a55}

/* Verdict */
.guide-card-verdict{margin-top:auto;padding-top:14px;border-top:1px solid #e8e0d0;display:flex;gap:10px;align-items:flex-start}
.guide-verdict-icon{width:26px;height:26px;border-radius:50%;background:#e8926a;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.guide-verdict-icon svg{width:13px;height:13px;fill:none;stroke:#fff;stroke-width:2.5;stroke-linecap:round}
.guide-verdict-text{font-size:0.85rem;line-height:1.6;color:#4a4a42;font-weight:300;font-style:italic}

/* -- Tips & FAQ sections -- */
.guide-tips{background:#fff;border-radius:16px;padding:32px;margin:40px 0;box-shadow:0 2px 16px rgba(0,0,0,0.04)}
.guide-tips h2{font-family:'Playfair Display',Georgia,serif;font-size:1.3rem;font-weight:700;color:#0e4a55;margin-bottom:20px}
.guide-tips ul{list-style:none;padding:0}
.guide-tips li{padding:10px 0;border-bottom:1px solid #f0ebe3;font-size:0.9rem;color:#4a4a42;line-height:1.6}
.guide-tips li:last-child{border-bottom:none}
.guide-tips li strong{color:#222}

.guide-faq{margin:40px 0}
.guide-faq h2{font-family:'Playfair Display',Georgia,serif;font-size:1.3rem;font-weight:700;color:#0e4a55;margin-bottom:24px}
.guide-faq-item{background:#fff;border-radius:12px;padding:24px;margin-bottom:12px;box-shadow:0 1px 8px rgba(0,0,0,0.03)}
.guide-faq-item h3{font-size:1rem;font-weight:600;color:#222;margin-bottom:8px}
.guide-faq-item p{font-size:0.9rem;color:#4a4a42;line-height:1.7;font-weight:300}

/* -- Responsive -- */
@media(max-width:980px){
  .guide-hero{padding:40px 20px 60px;margin:-20px -20px 30px}
}
@media(max-width:800px){
  .guide-card{grid-template-columns:1fr}
  .guide-card-visual{min-height:180px}
  .guide-card-body{padding:20px}
  .guide-section-header{flex-wrap:wrap}
  .guide-section-line{display:none}
}

/* -- Guide page: full-width layout (no sidebar) -- */
.guide-page .article-layout{display:block}
.guide-page .sidebar{display:none}
.guide-page .site-main{max-width:900px;margin:0 auto}

/* ── PRINT ── */
@media print{
  .top-bar,.site-header,.main-nav,.site-footer,.sidebar,.post-nav,.pagination,.ad-bar,.biz-stars-interactive,.biz-vibe-tags,.map-directions-btns{display:none}
  body{color:#000;background:#fff}
  .article-layout{grid-template-columns:1fr}
}

/* ── DESTINATION INTRO (homepage) ── */
.destination-intro{padding:28px 0 24px;border-bottom:2px solid #eee;margin-bottom:0}
.destination-title{font-family:'Playfair Display',Georgia,serif;font-size:2.4rem;font-weight:700;color:#0e4a55;margin:0 0 10px}
.destination-desc{font-size:0.97rem;color:#444;line-height:1.75;max-width:820px;margin:0 0 18px}
.destination-nav{display:flex;flex-wrap:wrap;gap:8px}
.destination-nav a{display:inline-block;background:#f0f7f8;border:1px solid #cde3e8;color:#0e4a55;font-size:0.82rem;font-weight:600;padding:7px 14px;border-radius:20px;text-decoration:none;transition:background .15s,color .15s}
.destination-nav a:hover{background:#0e4a55;color:#fff}
@media(max-width:600px){
  .destination-title{font-size:1.8rem}
  .destination-desc{font-size:0.9rem}
}

/* ── UTILITY BOX (tides, weather, surf pages) ── */
.utility-box{background:#f0f7f8;border-left:4px solid #0e4a55;padding:20px 22px;margin-bottom:28px;border-radius:6px}
.utility-box h3{font-size:1.05rem;font-weight:700;color:#0e4a55;margin:0 0 8px}
.utility-box p{font-size:0.9rem;color:#444;margin:0 0 14px}
.utility-box-btns{display:flex;flex-wrap:wrap;gap:8px}
.utility-btn{display:inline-block;background:#0e4a55;color:#fff!important;font-size:0.85rem;font-weight:600;padding:9px 18px;border-radius:5px;text-decoration:none!important;transition:background .15s}
.utility-btn:hover{background:#0a3540}
.utility-btn.secondary{background:#fff;color:#0e4a55!important;border:1.5px solid #0e4a55}
.utility-btn.secondary:hover{background:#0e4a55;color:#fff!important}

/* ── RELATED GUIDES (black links) ── */
.entry-content h2+ul a,.entry-content .related-guides a{color:#222!important}
.entry-content h2+ul a:hover,.entry-content .related-guides a:hover{color:#0e4a55!important;text-decoration:underline}
