/*
Theme Name: MyTheme Warsaw
Theme URI: https://warsaw.com.ua/
Author: Warsaw Concierge
Author URI: https://warsaw.com.ua
Description: Warsaw Urban Revival — forward-looking hotel directory theme inspired by Warsaw's resilient elegance.
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 7.0
Version: 2.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mytheme-warsaw
Tags: one-column, custom-colors, custom-menu, custom-logo, featured-images, translation-ready, accessibility-ready, blog
*/

/* ===== GOOGLE FONTS ===== */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Inter:opsz,wght@14..32,300;14..32,400;14..32,500;14..32,600&family=Lora:ital,wght@0,400;0,500;0,600;1,400;1,500&family=JetBrains+Mono:wght@300;400;500&display=swap');

/* ============================================================
   DESIGN TOKENS — Warsaw Urban Revival
   ============================================================ */
:root {
  /* Foundation Palette */
  --background:#FAFAF8;--background-alt:#F2F0EC;--background-warm:#EBE7E0;
  --foreground:#1A1D23;--foreground-soft:#3D4149;
  /* Terracotta / Brick (Primary) */
  --brick:#B85636;--brick-light:#D47A5E;--brick-dark:#A04A30;
  --brick-muted:rgba(184,86,54,.06);--brick-border:rgba(184,86,54,.12);
  /* Slate Blue (Secondary) */
  --slate:#3A5068;--slate-light:#5B7A98;--slate-dark:#2A3C50;
  --slate-muted:rgba(58,80,104,.05);
  /* Warm Gold (Tertiary — decorative) */
  --gold:#B09060;--gold-light:#CCAB7D;--gold-muted:rgba(176,144,96,.06);
  /* Forest Green (Quaternary — contextual) */
  --green:#4A7A5C;--green-light:#6A9B7C;--green-muted:rgba(74,122,92,.05);
  /* Neutrals */
  --neutral-50:#FAFAF8;--neutral-100:#F2F0EC;--neutral-200:#EBE7E0;
  --neutral-300:#DBD5CB;--neutral-400:#B5AEA2;--neutral-500:#736C62;
  --neutral-600:#5C574F;--neutral-700:#3D4149;--neutral-800:#282C32;--neutral-900:#1A1D23;
  /* Functional */
  --card:#FFFFFF;--card-foreground:#1A1D23;--muted:#F2F0EC;--muted-foreground:#736C62;
  --border:#E3DED6;--border-emphasis:#D5CEC4;--ring:#B85636;--input-border:#958E83;
  /* Overlays */
  --overlay-dark:rgba(26,29,35,.55);--overlay-warm:rgba(26,29,35,.35);
  --overlay-gradient:linear-gradient(180deg,rgba(26,29,35,0) 25%,rgba(26,29,35,.7) 100%);
  --overlay-cinematic:linear-gradient(135deg,rgba(184,86,54,.06) 0%,rgba(58,80,104,.08) 100%);
  /* Dark Sections */
  --dark-bg:#1A1D23;--dark-bg-elevated:#282C32;--dark-bg-card:#2F343B;
  --dark-text:#F2F0EC;--dark-text-muted:#B5AEA2;--dark-border:#3D4149;
  --dark-brick:#D47A5E;--dark-slate:#7DA0BE;--dark-gold:#CCAB7D;
  /* Typography */
  --font-heading:"Outfit","Inter",system-ui,sans-serif;
  --font-body:"Inter",system-ui,sans-serif;
  --font-editorial:"Lora",Georgia,serif;
  --font-mono:"JetBrains Mono",monospace;
  --text-xs:.75rem;--text-sm:1rem;--text-base:1rem;--text-md:1rem;
  --text-lg:1.0625rem;--text-xl:1.1875rem;--text-2xl:1.5rem;--text-3xl:1.875rem;
  --text-4xl:2.25rem;--text-5xl:2.875rem;--text-6xl:3.5rem;--text-7xl:4.25rem;
  /* WP Preset Mappings */
  --wp--preset--font-size--small:.8125rem;--wp--preset--font-size--medium:1rem;
  --wp--preset--font-size--large:1.1875rem;--wp--preset--font-size--x-large:1.5rem;
  --wp--preset--font-size--xx-large:1.875rem;
  --wp--preset--spacing--20:.5rem;--wp--preset--spacing--30:.75rem;--wp--preset--spacing--40:1rem;
  --wp--preset--spacing--50:clamp(1.25rem,4vw,3rem);--wp--preset--spacing--60:clamp(2rem,5vw,4rem);
  --wp--preset--spacing--70:clamp(4rem,8vw,7rem);
  --wp--style--global--wide-size:1180px;--wp--style--global--content-size:720px;
  --wp--preset--color--base:#FAFAF8;--wp--preset--color--base-2:#FFFFFF;
  --wp--preset--color--contrast:#1A1D23;--wp--preset--color--contrast-2:#5C574F;
  --wp--preset--color--contrast-3:#736C62;--wp--preset--color--accent:#B85636;
  --wp--preset--color--accent-2:#A04A30;--wp--preset--color--accent-3:#F2F0EC;
  --wp--preset--color--accent-4:#E3DED6;--wp--preset--color--accent-5:#B85636;
  --wp--preset--font-family--heading:var(--font-heading);
  --wp--preset--font-family--body:var(--font-body);
  --wp--preset--font-family--mono:var(--font-mono);
  /* Shadows */
  --shadow-sm:0 1px 2px rgba(26,29,35,.04),0 1px 3px rgba(26,29,35,.02);
  --shadow-md:0 4px 14px rgba(26,29,35,.06),0 2px 5px rgba(26,29,35,.03);
  --shadow-lg:0 12px 36px rgba(26,29,35,.08),0 4px 10px rgba(26,29,35,.04);
  --shadow-xl:0 20px 50px rgba(26,29,35,.10),0 8px 16px rgba(26,29,35,.05);
  --shadow-brick:0 6px 24px rgba(184,86,54,.14),0 2px 6px rgba(184,86,54,.07);
  --shadow-slate:0 6px 20px rgba(58,80,104,.12),0 2px 6px rgba(58,80,104,.06);
  --shadow-inner:inset 0 1px 3px rgba(26,29,35,.04);
  /* Radii */
  --radius-xs:4px;--radius-sm:6px;--radius-base:8px;--radius-md:12px;
  --radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;
  /* Motion */
  --ease-urban:cubic-bezier(.4,0,.2,1);--ease-out:cubic-bezier(0,0,.2,1);
  --ease-snap:cubic-bezier(.2,0,0,1);
}

/* ============================================================
   GLOBAL RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-size:var(--text-lg);font-weight:400;line-height:1.7;color:var(--foreground-soft);background:var(--background)}
/* Stone grain noise — warm tactile texture */
body::before{content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.02;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
img{max-width:100%;height:auto;display:block}
a{color:var(--brick-dark);text-decoration:none;transition:color 200ms var(--ease-urban)}
a:hover{color:var(--brick)}
button,input,select,textarea{font-family:inherit}

/* ===== ACCESSIBILITY ===== */
.screen-reader-text{clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;word-wrap:normal!important}
*:focus-visible{outline:2px solid var(--brick);outline-offset:3px;border-radius:var(--radius-xs)}

/* ===== HEADINGS ===== */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--foreground);line-height:1.15;letter-spacing:-.02em;margin:0 0 .75rem}
h1{font-size:clamp(var(--text-4xl),5vw,var(--text-5xl));font-weight:700}
h2{font-size:clamp(var(--text-3xl),3.5vw,var(--text-4xl));font-weight:600}
h3{font-size:var(--text-2xl);font-weight:600}
h4{font-size:var(--text-xl);font-weight:600}
h5{font-size:var(--text-md);font-weight:600}
h6{font-size:var(--text-base);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
p{margin:0 0 1rem}

/* ===== UTILITY ===== */
.mb{margin-bottom:1.5rem}
.flex{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}
.flex-center{justify-content:center}
.alignfull{width:100%}

/* ===== WP BLOCKS (inherited) ===== */
.wp-block-group{margin:0 auto}
.wp-block-group.has-global-padding{padding-left:clamp(1rem,4vw,3rem);padding-right:clamp(1rem,4vw,3rem)}
.wp-block-group.is-layout-constrained,.wp-block-group-is-layout-constrained{max-width:var(--wp--style--global--wide-size);margin:0 auto}
.wp-block-buttons{display:flex;flex-wrap:wrap;gap:.75rem}
.wp-block-buttons.is-layout-flex,.wp-block-buttons-is-layout-flex{display:flex;align-items:center;gap:.75rem}
.wp-block-button__link,.wp-element-button{display:inline-block;padding:.75rem 1.75rem;border-radius:var(--radius-base);font-family:var(--font-heading);font-weight:600;font-size:var(--text-base);letter-spacing:.04em;text-transform:uppercase;text-decoration:none;cursor:pointer;transition:all 200ms var(--ease-urban);border:none}
.wp-block-button__link.btn-book,.wp-element-button.btn-book{background:var(--brick);color:#fff;box-shadow:0 2px 6px rgba(184,86,54,.2)}
.wp-block-button__link.btn-book:hover{background:var(--brick-light);box-shadow:var(--shadow-brick);transform:translateY(-1px)}
.wp-block-button.is-style-outline .wp-block-button__link.btn-call{background:transparent;color:var(--slate);border:1.5px solid var(--slate)}
.wp-block-button.is-style-outline .wp-block-button__link.btn-call:hover{background:var(--slate);color:#fff;box-shadow:var(--shadow-slate)}
blockquote{border-left:3px solid var(--brick);padding-left:1.5rem;margin:1.5rem 0;font-family:var(--font-editorial);font-style:italic;font-size:var(--text-xl);line-height:1.5;color:var(--foreground)}
pre,code{font-family:var(--font-mono);font-size:var(--text-sm);background:var(--background-alt);border-radius:var(--radius-sm);padding:.15em .4em}
pre{padding:1.25rem;overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-base)}
hr,.wp-block-separator{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--neutral-300),transparent);margin:2.5rem auto;max-width:180px}
table{width:100%;border-collapse:collapse;margin:1.5rem 0}
th,td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}
th{font-family:var(--font-heading);font-weight:600;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--foreground);background:var(--background-alt)}

/* ============================================================
   SITE HEADER
   ============================================================ */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(250,250,248,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:box-shadow 300ms var(--ease-urban)}
/* Topbar */
.site-header-topbar{background:var(--dark-bg);font-size:var(--text-xs);border-bottom:1px solid var(--dark-border)}
.site-header-topbar-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:.4rem clamp(1rem,4vw,3rem);display:flex;justify-content:flex-end;align-items:center;gap:1.5rem}
.site-header-topbar a{color:var(--dark-text-muted);display:flex;align-items:center;gap:.3rem;font-weight:500;transition:color 180ms}
.site-header-topbar a:hover{color:#fff}
.site-header-topbar svg{width:14px;height:14px;stroke:currentColor;fill:none}
.site-header-main{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem);position:relative}
.site-header-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:1.5rem}
.site-header-brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.site-header-logo img{height:44px;width:auto;object-fit:contain}
.site-header-title{font-family:var(--font-heading);font-weight:700;font-size:var(--text-xl);color:var(--foreground);letter-spacing:-.01em}
.site-header-title:hover{color:var(--brick)}

/* Nav */
.site-header-nav{display:flex;align-items:center}
.site-header-nav ul,.site-header-nav .header-menu{display:flex;list-style:none;margin:0;padding:0;gap:.25rem}
.site-header-nav ul li a,.site-header-nav .header-menu li a{display:block;padding:.5rem .75rem;font-family:var(--font-heading);font-weight:500;font-size:var(--text-sm);color:var(--foreground);border-radius:var(--radius-sm);position:relative;transition:color 180ms var(--ease-urban);white-space:nowrap}
.site-header-nav ul li a::after,.site-header-nav .header-menu li a::after{content:'';position:absolute;bottom:4px;left:.875rem;right:.875rem;height:2px;background:var(--brick);border-radius:1px;transform:scaleX(0);transform-origin:left;transition:transform 220ms var(--ease-snap)}
.site-header-nav ul li a:hover,.site-header-nav .header-menu li a:hover,
.site-header-nav ul li.current-menu-item a,.site-header-nav .header-menu li.current-menu-item a{color:var(--brick)}
.site-header-nav ul li a:hover::after,.site-header-nav .header-menu li a:hover::after,
.site-header-nav ul li.current-menu-item a::after,.site-header-nav .header-menu li.current-menu-item a::after{transform:scaleX(1)}

/* Actions */
.site-header-actions{display:flex;align-items:center;gap:.75rem;font-size:var(--text-xs);flex-shrink:0}
.site-header-phone,.site-header-email{color:var(--foreground-soft);font-weight:500;display:none;align-items:center;gap:.3rem;white-space:nowrap}
.site-header-phone:hover,.site-header-email:hover{color:var(--brick-dark)}
.site-header-phone svg,.site-header-email svg{width:16px;height:16px;stroke:currentColor;fill:none}

/* Search */
.site-header-search-toggle{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--foreground-soft);border-radius:var(--radius-sm);transition:color 150ms}
.site-header-search-toggle:hover{color:var(--brick)}
.site-header-search-toggle svg{width:20px;height:20px}
.site-header-search-overlay{display:none;position:absolute;top:100%;left:0;right:0;background:var(--card);border-bottom:1px solid var(--border);padding:1rem clamp(1rem,4vw,3rem);box-shadow:var(--shadow-md)}
.site-header-main.search-active .site-header-search-overlay{display:block}
.site-header-search-form{display:flex;align-items:center;max-width:600px;margin:0 auto;gap:.5rem;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:4px 4px 4px 18px;transition:border-color 200ms}
.site-header-search-form:focus-within{border-color:var(--brick);box-shadow:var(--shadow-lg)}
.site-header-search-input{border:none;outline:none;flex:1;font-family:var(--font-body);font-size:var(--text-md);padding:10px 12px;background:transparent;color:var(--foreground)}
.site-header-search-submit{background:var(--brick);color:#fff;border:none;border-radius:var(--radius-base);padding:10px 20px;font-family:var(--font-heading);font-weight:600;font-size:var(--text-base);cursor:pointer;transition:background 200ms var(--ease-urban)}
.site-header-search-submit:hover{background:var(--brick-light)}
.site-header-search-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--neutral-500);padding:.5rem;position:absolute;right:1rem;top:50%;transform:translateY(-50%)}
.site-header-search-close:hover{color:var(--foreground)}

/* Burger */
.site-header-burger{display:none;background:none;border:none;padding:.5rem;cursor:pointer;color:var(--foreground)}
.site-header-burger svg,.site-header-burger span{display:block;width:22px;height:2px;background:currentColor;margin:5px 0;border-radius:1px;transition:transform 200ms}

/* ============================================================
   SITE FOOTER
   ============================================================ */
.site-footer{
  background:var(--dark-bg);color:var(--dark-text-muted);
  /* Dual ambient glow */
  background-image:radial-gradient(ellipse at 20% 40%,rgba(184,86,54,.05) 0%,transparent 55%),radial-gradient(ellipse at 80% 60%,rgba(58,80,104,.04) 0%,transparent 50%);
  padding:clamp(3rem,6vw,5rem) 0 0
}
.site-footer-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.site-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:3rem 4rem;margin-bottom:3rem}
.site-footer-brand{display:flex;flex-direction:column;gap:1rem}
.site-footer-logo img{height:90px;width:90px;object-fit:contain}
.site-footer-site-name{font-family:var(--font-heading);font-weight:700;font-size:var(--text-xl);color:var(--dark-text)}
.site-footer-site-name:hover{color:var(--dark-brick)}
.site-footer-description{font-size:var(--text-base);line-height:1.6;color:var(--dark-text-muted);max-width:320px}
.site-footer-column{justify-self:end}
.site-footer-heading{display:block;font-family:var(--font-heading);font-weight:600;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.08em;color:var(--dark-text);margin-bottom:1rem}
.site-footer-column ul,.site-footer-column .footer-menu{list-style:none;padding:0;margin:0}
.site-footer-column ul li,.site-footer-column .footer-menu li{margin-bottom:.5rem}
.site-footer-column ul li a,.site-footer-column .footer-menu li a{color:var(--dark-text-muted);font-size:var(--text-base);transition:color 180ms}
.site-footer-column ul li a:hover,.site-footer-column .footer-menu li a:hover{color:#fff}
.site-footer-contact-item{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.75rem;font-size:var(--text-base);color:var(--dark-text-muted)}
.site-footer-contact-item svg{width:18px;height:18px;flex-shrink:0;margin-top:3px;stroke:var(--dark-brick);fill:none}
.site-footer-contact-item a{color:var(--dark-brick);transition:color 180ms}
.site-footer-contact-item a:hover{color:#fff}
.site-footer-bottom{border-top:1px solid var(--dark-border);padding:1.5rem 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.site-footer-copyright{font-size:var(--text-xs);color:var(--dark-text-muted)}
.site-footer-social{display:flex;gap:.75rem}
.site-footer-social a{color:var(--dark-text-muted);transition:color 180ms,transform 200ms}
.site-footer-social a:hover{color:var(--dark-brick);transform:translateY(-2px)}
.site-footer-social a svg{width:20px;height:20px}

/* ============================================================
   HOMEPAGE
   ============================================================ */
/* --- Hero --- */
.hp-hero{position:relative;min-height:80vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--dark-bg)}
.hp-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hp-hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(26,29,35,0) 20%,rgba(26,29,35,.65) 100%);/* Dual warm glow */background-image:radial-gradient(ellipse at 20% 40%,rgba(184,86,54,.05) 0%,transparent 55%),radial-gradient(ellipse at 80% 60%,rgba(58,80,104,.04) 0%,transparent 50%),linear-gradient(180deg,rgba(26,29,35,0) 20%,rgba(26,29,35,.65) 100%)}
.hp-hero-content{position:relative;z-index:2;max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:6rem clamp(1rem,4vw,3rem) clamp(3rem,6vw,5rem);width:100%}
.hp-hero-eyebrow{font-family:var(--font-heading);font-weight:500;font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--dark-brick);margin-bottom:.75rem}
.hp-hero-title{font-family:var(--font-heading);font-weight:700;font-size:clamp(2.5rem,6.5vw,5.25rem);line-height:1.05;letter-spacing:-.025em;color:#fff;margin-bottom:1rem;max-width:700px}
.hp-hero-subtitle{font-family:var(--font-body);font-size:var(--text-xl);color:rgba(255,255,255,.75);max-width:540px;margin-bottom:2rem;line-height:1.6}
.hp-hero-btn{display:inline-block;padding:14px 32px;background:var(--brick);color:#fff;font-family:var(--font-heading);font-weight:600;font-size:var(--text-base);letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius-base);box-shadow:0 2px 6px rgba(184,86,54,.2);transition:all 200ms var(--ease-urban)}
.hp-hero-btn:hover{background:var(--brick-light);color:#fff;box-shadow:var(--shadow-brick);transform:translateY(-1px)}

/* --- Sections (shared) --- */
.hp-section{padding:clamp(3.5rem,7vw,6rem) 0}
.hp-section-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.hp-section-header{text-align:center;margin-bottom:clamp(2rem,4vw,3rem)}
.hp-section-header::before{content:'';display:block;width:36px;height:3px;background:var(--brick);border-radius:2px;margin:0 auto 1rem}
.hp-section-title{font-family:var(--font-heading);font-weight:600;font-size:clamp(1.75rem,3.5vw,var(--text-4xl));line-height:1.15;letter-spacing:-.02em;color:var(--foreground)}
.hp-section-subtitle{font-size:var(--text-lg);color:var(--muted-foreground);max-width:560px;margin:1rem auto 0}
.hp-section-cta{text-align:center;margin-top:clamp(2rem,4vw,3rem)}

/* --- Popular Hotels --- */
.hp-popular{background:var(--background)}
.hp-hotel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.hp-hotel-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all 280ms var(--ease-urban)}
.hp-hotel-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--border-emphasis)}
.hp-hotel-card-link{text-decoration:none;color:inherit;display:flex;flex-direction:column}
.hp-hotel-card-img{aspect-ratio:16/10;overflow:hidden;position:relative;flex-shrink:0;border-radius:var(--radius-md) var(--radius-md) 0 0}
.hp-hotel-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 500ms var(--ease-urban)}
.hp-hotel-card:hover .hp-hotel-card-img img{transform:scale(1.04)}
.hp-hotel-card-rating{position:absolute;top:12px;right:12px;background:var(--brick);color:#fff;font-family:var(--font-mono);font-weight:500;font-size:var(--text-sm);padding:5px 10px;border-radius:var(--radius-sm);box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:1}
.hp-hotel-card-body{padding:20px}
.hp-hotel-card-title{font-family:var(--font-heading);font-weight:600;font-size:1.125rem;line-height:1.35;color:var(--foreground);margin:0}
.hp-hotel-card-location{font-size:var(--text-sm);color:var(--muted-foreground);margin:0 0 .35rem}
.hp-hotel-card-stars{color:var(--gold);margin-bottom:.25rem}
.hp-hotel-card-desc{font-size:var(--text-sm);color:var(--neutral-600);line-height:1.5;margin:.35rem 0 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Buttons — outline & solid */
.hp-btn-outline{display:inline-flex;align-items:center;gap:6px;padding:12px 26px;background:transparent;color:var(--slate);border:1.5px solid var(--slate);border-radius:var(--radius-base);font-family:var(--font-heading);font-weight:600;font-size:var(--text-base);letter-spacing:.04em;text-transform:uppercase;transition:all 200ms var(--ease-urban)}
.hp-btn-outline:hover{background:var(--slate);color:#fff;box-shadow:var(--shadow-slate)}
.hp-btn-outline::after{content:'→';transition:transform 200ms ease}
.hp-btn-outline:hover::after{transform:translateX(3px)}
.hp-btn-outline--light{color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.hp-btn-outline--light:hover{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.5)}
.hp-btn-solid{display:inline-block;padding:13px 28px;background:var(--brick);color:#fff;font-family:var(--font-heading);font-weight:600;font-size:var(--text-base);letter-spacing:.04em;text-transform:uppercase;border:none;border-radius:var(--radius-base);box-shadow:0 2px 6px rgba(184,86,54,.2);transition:all 200ms var(--ease-urban)}
.hp-btn-solid:hover{background:var(--brick-light);color:#fff;box-shadow:var(--shadow-brick);transform:translateY(-1px)}

/* --- Features (dark section) --- */
.hp-features{background:var(--dark-bg);color:var(--dark-text);padding:clamp(3.5rem,7vw,6rem) 0;background-image:radial-gradient(ellipse at 40% 0%,rgba(184,86,54,.05) 0%,transparent 50%),radial-gradient(ellipse at 70% 100%,rgba(58,80,104,.04) 0%,transparent 45%)}
.hp-features .hp-section-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.hp-features .hp-section-header::before{background:var(--dark-brick)}
.hp-section-title--light{color:var(--dark-text)}
.hp-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem}
.hp-feature{text-align:center;padding:2rem 1.5rem}
.hp-feature-icon{width:56px;height:56px;border-radius:var(--radius-md);background:rgba(212,122,94,.12);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}
.hp-feature-icon svg,.hp-feature-icon img{width:28px;height:28px;color:var(--dark-brick)}
.hp-feature-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-xl);color:var(--dark-text);margin-bottom:.5rem}
.hp-feature-desc{font-size:var(--text-base);color:var(--dark-text-muted);line-height:1.6}

/* --- Blog Cards --- */
.hp-blog{background:var(--background-alt)}
.hp-blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.hp-blog-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all 280ms var(--ease-urban)}
.hp-blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.hp-blog-card-link{text-decoration:none;color:inherit;display:flex;flex-direction:column}
.hp-blog-card-img{aspect-ratio:16/10;overflow:hidden;flex-shrink:0;border-radius:var(--radius-md) var(--radius-md) 0 0}
.hp-blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 500ms var(--ease-urban)}
.hp-blog-card:hover .hp-blog-card-img img{transform:scale(1.04)}
.hp-blog-card-body{padding:20px}
.hp-blog-card-date{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.04em}
.hp-blog-card-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-xl);color:var(--foreground);margin:.5rem 0;line-height:1.35}
.hp-blog-card-excerpt{font-size:var(--text-base);color:var(--foreground-soft);line-height:1.6;margin:0}

/* --- CTA Banner --- */
.hp-cta-banner{
  background:var(--dark-bg);color:var(--dark-text);
  padding:clamp(4rem,8vw,7rem) 0;text-align:center;
  /* Brick hatch + dual glow */
  background-image:
    repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(184,86,54,.02) 20px,rgba(184,86,54,.02) 21px),
    repeating-linear-gradient(-45deg,transparent,transparent 20px,rgba(184,86,54,.02) 20px,rgba(184,86,54,.02) 21px),
    radial-gradient(ellipse at 30% 30%,rgba(184,86,54,.06) 0%,transparent 50%),
    radial-gradient(ellipse at 70% 70%,rgba(58,80,104,.05) 0%,transparent 45%)
}
.hp-cta-banner .hp-section-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.hp-cta-title{font-family:var(--font-heading);font-weight:700;font-size:clamp(var(--text-3xl),4vw,var(--text-5xl));color:#fff;margin-bottom:.75rem}
.hp-cta-subtitle{font-size:var(--text-xl);color:var(--dark-text-muted);max-width:540px;margin:0 auto 2rem;line-height:1.6}
.hp-cta-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}

/* --- Stats Strip --- */
.hp-stats{background:var(--dark-bg-elevated);padding:2rem 0;border-top:1px solid var(--dark-border);border-bottom:1px solid var(--dark-border)}
.hp-stats-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem);display:flex;justify-content:center;gap:clamp(2rem,6vw,5rem)}
.hp-stats-item{text-align:center}
.hp-stats-number{display:block;font-family:var(--font-heading);font-weight:700;font-size:var(--text-2xl);color:#fff}
.hp-stats-label{font-size:var(--text-sm);color:var(--dark-text-muted);text-transform:uppercase;letter-spacing:.06em}

/* ============================================================
   HOTEL LISTING (archive-hotels)
   ============================================================ */
/* --- Hero --- */
.hl-hero{position:relative;background:var(--dark-bg);padding:clamp(4rem,8vw,7rem) 0 clamp(3rem,5vw,4.5rem);text-align:center;overflow:hidden;background-image:radial-gradient(ellipse at 30% 50%,rgba(184,86,54,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 30%,rgba(58,80,104,.05) 0%,transparent 45%)}
.hl-hero-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.hl-hero-label{font-family:var(--font-heading);font-weight:500;font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--dark-brick);margin-bottom:.75rem}
.hl-hero-title{font-family:var(--font-heading);font-weight:700;font-size:clamp(var(--text-4xl),5vw,var(--text-6xl));color:#fff;margin-bottom:1.5rem}
.hl-hero-search{max-width:540px;margin:0 auto}
.hl-hero-search form{display:flex;align-items:center;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);border-radius:var(--radius-md);padding:4px 4px 4px 18px;transition:border-color 200ms,box-shadow 200ms}
.hl-hero-search form:focus-within{border-color:var(--dark-brick);box-shadow:0 0 0 3px rgba(184,86,54,.15)}
.hl-hero-search input{border:none;outline:none;flex:1;font-family:var(--font-body);font-size:var(--text-md);padding:10px 12px;background:transparent;color:#fff}
.hl-hero-search input::placeholder{color:rgba(255,255,255,.45)}
.hl-hero-search button{background:var(--brick);color:#fff;border:none;border-radius:var(--radius-base);padding:10px 20px;font-family:var(--font-heading);font-weight:600;font-size:var(--text-base);cursor:pointer;transition:background 200ms}
.hl-hero-search button:hover{background:var(--brick-light)}

/* --- Filter Bar --- */
.hl-filter-bar{background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:64px;z-index:90;box-shadow:var(--shadow-sm)}
.hl-filter-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:.75rem clamp(1rem,4vw,3rem);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.hl-filter-form{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.hl-filter-field{display:flex;align-items:center;gap:.35rem}
.hl-filter-field label{font-family:var(--font-heading);font-weight:500;font-size:var(--text-sm);color:var(--foreground-soft)}
.hl-filter-field select{padding:.4rem .75rem;border:1.5px solid var(--input-border);border-radius:var(--radius-base);font-family:var(--font-body);font-size:var(--text-sm);color:var(--foreground);background:var(--card);transition:border-color 180ms}
.hl-filter-field select:focus{outline:none;border-color:var(--brick);box-shadow:0 0 0 3px var(--brick-muted)}
.hl-filter-btn{padding:.5rem 1.25rem;background:var(--brick);color:#fff;border:none;border-radius:var(--radius-base);font-family:var(--font-heading);font-weight:600;font-size:var(--text-sm);cursor:pointer;transition:background 200ms}
.hl-filter-btn:hover{background:var(--brick-light)}
.hl-filter-active{font-size:var(--text-sm);color:var(--foreground-soft)}
.hl-filter-clear{color:var(--brick);font-size:var(--text-sm);font-weight:500;margin-left:.5rem}
.hl-filter-clear:hover{color:var(--brick-dark)}

/* --- Map --- */
.hl-map-section{background:var(--background-alt);border-bottom:1px solid var(--border)}
.hl-map-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:1.5rem clamp(1rem,4vw,3rem)}
.hl-map-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}
.hl-map-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-2xl);margin:0}
.hl-map-toggle{padding:.4rem 1rem;border:1.5px solid var(--border-emphasis);border-radius:var(--radius-base);background:var(--card);font-family:var(--font-heading);font-weight:500;font-size:var(--text-sm);cursor:pointer;transition:all 200ms}
.hl-map-toggle:hover{border-color:var(--brick);color:var(--brick)}
.hl-map-count{font-size:var(--text-sm);color:var(--muted-foreground)}
.collapsed{display:none}
#hl-hotels-map{width:100%;height:500px}

/* Map Infowindow */
.hl-infowindow{font-family:var(--font-body);max-width:260px}
.hl-iw-img{width:100%;height:140px;object-fit:cover;border-radius:var(--radius-sm) var(--radius-sm) 0 0}
.hl-iw-title{display:block;font-family:var(--font-heading);font-weight:600;font-size:var(--text-md);margin:.5rem 0 .25rem}
.hl-iw-stars{color:var(--gold);font-size:var(--text-sm)}
.hl-iw-loc{display:block;font-size:var(--text-xs);color:var(--muted-foreground);margin-bottom:.5rem}
.hl-iw-footer{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-top:1px solid var(--border)}
.hl-iw-rating{background:var(--brick);color:#fff;font-family:var(--font-mono);font-size:var(--text-sm);padding:3px 8px;border-radius:var(--radius-xs)}
.hl-iw-link{color:var(--brick);font-weight:600;font-size:var(--text-sm)}
.hl-iw-link:hover{color:var(--brick-dark)}

/* --- Hotel Grid --- */
.hl-listing{padding:clamp(2.5rem,5vw,4rem) 0}
.hl-listing-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.hl-hotels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.hl-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all 280ms var(--ease-urban)}
.hl-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--border-emphasis)}
.hl-card-link{display:flex;flex-direction:column;text-decoration:none;color:inherit}
.hl-card-img{aspect-ratio:16/10;overflow:hidden;position:relative;flex-shrink:0;border-radius:var(--radius-md) var(--radius-md) 0 0}
.hl-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 500ms var(--ease-urban)}
.hl-card:hover .hl-card-img img{transform:scale(1.04)}
.hl-card-rating{position:absolute;top:12px;right:12px;background:var(--brick);color:#fff;font-family:var(--font-mono);font-weight:500;font-size:var(--text-sm);padding:5px 10px;border-radius:var(--radius-sm);box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:1}
.hl-card-body{padding:16px 20px 20px}
.hl-card-stars{color:var(--gold);margin-bottom:.25rem}
.hl-card-title{font-family:var(--font-heading);font-weight:600;font-size:1.125rem;line-height:1.35;color:var(--foreground);margin:0 0 .25rem}
.hl-card-location{font-size:var(--text-sm);color:var(--muted-foreground);margin:0 0 .35rem}
.hl-card-desc{font-size:var(--text-sm);color:var(--neutral-600);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Pagination */
.hl-pagination{margin-top:2.5rem;text-align:center}
.hl-pagination .nav-links,.hl-pagination ul.page-numbers{display:flex;justify-content:center;gap:.35rem;flex-wrap:wrap;list-style:none;padding:0;margin:0}
.hl-pagination li{list-style:none}
.hl-pagination .page-numbers:not(ul){display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 .5rem;border-radius:var(--radius-base);font-family:var(--font-heading);font-weight:500;font-size:var(--text-sm);color:var(--foreground-soft);border:1px solid var(--border);background:var(--card);transition:all 200ms var(--ease-urban)}
.hl-pagination .page-numbers:not(ul):hover{border-color:var(--brick);color:var(--brick);background:var(--brick-muted)}
.hl-pagination .page-numbers.current{background:var(--brick);color:#fff;border-color:var(--brick);font-weight:600}
.hl-pagination .page-numbers.dots{border:none;background:none}
.hl-pagination .page-numbers.prev,.hl-pagination .page-numbers.next{font-weight:600}

/* No results */
.hl-no-results{padding:clamp(3rem,6vw,5rem) 0;text-align:center}
.hl-no-results-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}

/* ============================================================
   SINGLE HOTEL (posts-hotel.php)
   ============================================================ */
.sh-hotel{background:var(--background)}

/* Gallery */
.sh-gallery{position:relative;background:var(--dark-bg);padding:0}
.sh-gallery-grid{display:grid;grid-template-columns:2fr 1fr;gap:4px;max-height:500px;overflow:hidden}
.sh-gallery-main{position:relative;overflow:hidden}
.sh-gallery-main img{width:100%;height:100%;object-fit:cover}
.sh-gallery-side{display:grid;grid-template-rows:1fr 1fr;gap:4px}
.sh-gallery-thumb{overflow:hidden;cursor:pointer;position:relative}
.sh-gallery-thumb img{width:100%;height:100%;object-fit:cover;transition:transform 400ms var(--ease-urban)}
.sh-gallery-thumb:hover img{transform:scale(1.04)}
.sh-gallery-all-btn{position:absolute;bottom:16px;right:16px;padding:8px 18px;background:rgba(26,29,35,.8);color:#fff;font-family:var(--font-heading);font-weight:500;font-size:var(--text-sm);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-base);cursor:pointer;backdrop-filter:blur(8px);z-index:2;transition:all 200ms}
.sh-gallery-all-btn:hover{background:rgba(26,29,35,.95);border-color:rgba(255,255,255,.4)}

/* Quick Info Bar */
.sh-quick-info{background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:64px;z-index:80;box-shadow:var(--shadow-sm)}
.sh-quick-info-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:1rem clamp(1rem,4vw,3rem);display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.sh-quick-info-left{flex:1;min-width:0}
.sh-title{font-family:var(--font-heading);font-weight:700;font-size:clamp(var(--text-2xl),3vw,var(--text-3xl));color:var(--foreground);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sh-title-meta{display:flex;align-items:center;gap:.75rem;margin-top:.25rem;flex-wrap:wrap}
.sh-stars{color:var(--gold);display:inline-flex;gap:1px}
.sh-stars svg{width:16px;height:16px;fill:var(--gold)}
.sh-location{font-size:var(--text-sm);color:var(--muted-foreground)}
.sh-quick-info-right{display:flex;align-items:center;gap:1rem;flex-shrink:0}
.sh-rating-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--brick-muted);border-radius:var(--radius-base)}
.sh-rating-number{font-family:var(--font-mono);font-weight:500;font-size:var(--text-2xl);color:var(--brick);line-height:1}
.sh-rating-label{font-size:var(--text-sm);color:var(--foreground-soft);font-weight:500}
.sh-cta-buttons{display:flex;gap:.5rem}
.sh-btn-book{display:inline-block;padding:10px 22px;background:var(--brick);color:#fff;font-family:var(--font-heading);font-weight:600;font-size:var(--text-sm);letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius-base);transition:all 200ms var(--ease-urban);box-shadow:0 2px 6px rgba(184,86,54,.2)}
.sh-btn-book:hover{background:var(--brick-light);color:#fff;box-shadow:var(--shadow-brick);transform:translateY(-1px)}
.sh-btn-call{display:inline-block;padding:10px 22px;background:transparent;color:var(--slate);border:1.5px solid var(--slate);font-family:var(--font-heading);font-weight:600;font-size:var(--text-sm);letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius-base);transition:all 200ms var(--ease-urban)}
.sh-btn-call:hover{background:var(--slate);color:#fff;box-shadow:var(--shadow-slate)}

/* Sections (shared) */
.sh-section{padding:clamp(2rem,4vw,3rem) 0}
.sh-section-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.sh-section-title{font-family:var(--font-heading);font-weight:600;font-size:clamp(var(--text-2xl),3vw,var(--text-3xl));color:var(--foreground);margin-bottom:1.5rem;position:relative;padding-left:16px}
.sh-section-title::before{content:'';position:absolute;left:0;top:.15em;width:3px;height:1em;border-radius:2px;background:linear-gradient(180deg,var(--brick),var(--slate))}
.sh-subsection-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-xl);color:var(--foreground);margin-bottom:1rem}
.sh-sidebar-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-xl);color:var(--foreground);margin-bottom:1rem}

/* Address Bar */
.sh-address-bar{background:var(--background-alt);border-bottom:1px solid var(--border);padding:.75rem 0}
.sh-address{font-style:normal;font-size:var(--text-sm);color:var(--muted-foreground)}

/* Overview */
.sh-overview{display:block}
.sh-overview--with-sidebar{display:grid;grid-template-columns:1fr 340px;gap:3rem;align-items:start}
.sh-overview-content{line-height:1.7;color:var(--foreground-soft)}
.sh-overview-content p{margin-bottom:1rem}
.sh-overview-sidebar{background:var(--background-alt);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem}
.sh-rule-group{border:1px solid var(--border);border-radius:var(--radius-base);margin-bottom:.75rem}
.sh-rule-group summary{padding:.75rem 1rem;font-family:var(--font-heading);font-weight:500;cursor:pointer;color:var(--foreground);transition:color 150ms}
.sh-rule-group summary:hover{color:var(--brick)}
.sh-rule-group[open] summary{border-bottom:1px solid var(--border)}
.sh-rule-group ul,.sh-rule-group ol{margin:.5rem 0;padding-left:1.25rem}
.sh-rule-group li{margin-bottom:.25rem;font-size:var(--text-base);color:var(--foreground-soft)}

/* Rooms */
.sh-rooms{background:var(--background-alt)}
.sh-rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}
.sh-room-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem;transition:all 200ms var(--ease-urban)}
.sh-room-card:hover{border-color:var(--border-emphasis);box-shadow:var(--shadow-md)}
.sh-room-name{font-family:var(--font-heading);font-weight:600;font-size:var(--text-xl);color:var(--foreground);margin:0 0 .75rem}
.sh-room-beds,.sh-room-guests{font-size:var(--text-base);color:var(--foreground-soft);margin:0 0 .35rem;display:flex;align-items:center;gap:.35rem}
.sh-room-price{font-family:var(--font-mono);font-weight:500;font-size:var(--text-md);color:var(--brick);margin:.75rem 0 0}

/* Amenities */
.sh-amenities{}
.sh-amenity-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.sh-amenity-chip{display:inline-flex;align-items:center;padding:6px 14px;font-size:var(--text-sm);font-family:var(--font-body);border-radius:var(--radius-sm);background:var(--brick-muted);color:var(--brick-dark);border:1px solid var(--brick-border);transition:all 150ms}
.sh-amenity-chip:hover{background:rgba(184,86,54,.12)}
.sh-amenity-groups{}
.sh-amenity-group{border:1px solid var(--border);border-radius:var(--radius-base);margin-bottom:.5rem}
.sh-amenity-group summary{padding:.75rem 1rem;font-family:var(--font-heading);font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:color 150ms}
.sh-amenity-group summary:hover{color:var(--brick)}
.sh-amenity-count{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--muted-foreground);background:var(--muted);padding:2px 8px;border-radius:var(--radius-full)}
.sh-amenity-group[open] summary{border-bottom:1px solid var(--border)}
.sh-amenity-group ul{list-style:none;padding:.75rem 1rem;margin:0;columns:2;column-gap:2rem}
.sh-amenity-group ul li{margin-bottom:.35rem;font-size:var(--text-base);color:var(--foreground-soft);break-inside:avoid}

/* Reviews */
.sh-reviews{}
.sh-reviews-header{display:flex;align-items:flex-start;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}
.sh-reviews-score-card{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--brick-muted);border-radius:var(--radius-md);border:1px solid var(--brick-border)}
.sh-reviews-score-number{font-family:var(--font-mono);font-weight:500;font-size:var(--text-4xl);line-height:1;color:var(--brick)}
.sh-reviews-score-label{font-family:var(--font-heading);font-weight:600;font-size:var(--text-md);color:var(--foreground)}
.sh-reviews-score-count{font-size:var(--text-sm);color:var(--muted-foreground)}
.sh-review-bars{flex:1;min-width:280px}
.sh-review-bar-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}
.sh-review-bar-label{font-size:var(--text-sm);color:var(--foreground-soft);min-width:100px}
.sh-review-bar-track{flex:1;height:6px;background:var(--neutral-200);border-radius:3px;overflow:hidden}
.sh-review-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--brick),var(--brick-light));transition:width 600ms var(--ease-out)}
.sh-review-bar-value{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--foreground);min-width:28px;text-align:right}
.sh-reviews-list{margin-top:2rem}
.sh-review-item{border-bottom:1px solid var(--border);padding:1.5rem 0}
.sh-review-item.hidden{display:none}
.sh-review-item:last-child{border-bottom:none}
.sh-review-item-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.sh-review-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--slate-muted);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:600;color:var(--slate);font-size:var(--text-md);flex-shrink:0}
.sh-review-meta{flex:1}
.sh-review-name{font-family:var(--font-heading);font-weight:600;font-size:var(--text-md);color:var(--foreground);display:block}
.sh-review-from{font-size:var(--text-xs);color:var(--muted-foreground)}
.sh-review-date{font-size:var(--text-xs);color:var(--muted-foreground)}
.sh-review-score{font-family:var(--font-mono);font-weight:500;font-size:var(--text-sm);color:#fff;background:var(--brick);padding:3px 8px;border-radius:var(--radius-xs);flex-shrink:0}
.sh-review-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-md);color:var(--foreground);margin:0 0 .35rem}
.sh-review-text{font-size:var(--text-base);color:var(--foreground-soft);line-height:1.6;margin:0}
.sh-reviews-toggle{margin-top:1.5rem}

/* Location */
.sh-location-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.sh-map{width:100%;height:500px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border)}
#sh-hotel-map{width:100%;height:100%}
.sh-surroundings{}

/* CTA Section */
.sh-cta-section{background:var(--background-alt);text-align:center}
.sh-cta-section .sh-section-title::before{display:none}
.sh-cta-section .sh-section-title{padding-left:0}

/* Contact */
.sh-contact{}

/* Related Hotels */
.sh-related{background:var(--background-alt);color:var(--foreground)}
.sh-related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}
.sh-tags{margin-top:1rem;display:flex;flex-wrap:wrap;gap:.5rem}
.sh-tags a{display:inline-block;padding:4px 12px;font-family:var(--font-heading);font-size:var(--text-xs);font-weight:500;letter-spacing:.03em;border-radius:var(--radius-sm);background:var(--slate-muted);color:var(--slate);border:1px solid transparent;transition:all 150ms}
.sh-tags a:hover{border-color:var(--slate);background:rgba(58,80,104,.1)}

/* Lightbox */
.sh-lightbox{position:fixed;inset:0;z-index:99999;background:rgba(26,29,35,.92);display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);opacity:0;transition:opacity 300ms var(--ease-urban)}
.sh-lightbox.active{display:flex;opacity:1}
.sh-lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius-base)}
.sh-lightbox-close,.sh-lightbox-prev,.sh-lightbox-next{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;font-size:1.5rem;cursor:pointer;border-radius:var(--radius-base);padding:.5rem .75rem;transition:all 200ms;backdrop-filter:blur(8px)}
.sh-lightbox-close{top:1rem;right:1rem;font-size:1.75rem}
.sh-lightbox-prev{left:1rem;top:50%;transform:translateY(-50%)}
.sh-lightbox-next{right:1rem;top:50%;transform:translateY(-50%)}
.sh-lightbox-close:hover,.sh-lightbox-prev:hover,.sh-lightbox-next:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3)}
.sh-lightbox-counter{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:var(--text-sm);color:rgba(255,255,255,.7)}

/* ============================================================
   SINGLE ATTRACTION (posts-attraction.php)
   ============================================================ */
.attraction{background:var(--background)}

/* ── Hero header ── */
.attraction .post-header{
  background:var(--dark-bg);
  padding:clamp(2.5rem,6vw,4.5rem) clamp(1rem,4vw,3rem) clamp(2rem,5vw,3.5rem);
  margin-bottom:0;
  text-align:center;
  position:relative;
  border-bottom:4px solid var(--brick)
}
.attraction .post-header::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 80%,rgba(184,86,54,.12),transparent 60%),
             radial-gradient(ellipse at 70% 20%,rgba(58,80,104,.10),transparent 55%);
  pointer-events:none
}
.attraction .post-title{
  font-family:var(--font-heading);font-weight:700;
  font-size:clamp(var(--text-3xl),5vw,var(--text-5xl));
  color:#fff;margin:0;line-height:1.2;position:relative;z-index:1
}

/* ── Content area ── */
.attraction .post-content{line-height:1.7;color:var(--foreground-soft);padding-top:2rem}

/* Section headings — brick accent bar */
.attraction .post-content h2{
  margin-top:2.5rem;margin-bottom:1rem;
  padding-left:1rem;
  border-left:4px solid var(--brick);
  font-family:var(--font-heading);font-weight:700;
  font-size:var(--text-2xl);color:var(--foreground)
}
.attraction .post-content h3{margin-top:2rem;font-family:var(--font-heading);font-weight:600;color:var(--foreground)}

/* ── Free cancellation chip ── */
.attraction .free-cancel{
  display:inline-block;
  font-style:italic;color:var(--green);
  background:rgba(34,139,34,.08);
  padding:.4rem 1rem;border-radius:var(--radius-base);
  border:1px solid rgba(34,139,34,.2)
}

/* ── Image gallery (display_two_images → .flex > div > img) ── */
.attraction .post-content > .flex{gap:1rem}
.attraction .post-content > .flex > div{
  flex:1 1 45%;overflow:hidden;border-radius:var(--radius-md);
  border:1px solid var(--border)
}
.attraction .post-content > .flex > div img{
  width:100%;height:100%;max-height:420px;
  object-fit:cover;display:block;
  transition:transform 500ms var(--ease-urban)
}
.attraction .post-content > .flex > div:hover img{transform:scale(1.05)}

/* ── Reviews list ── */
.attraction .post-content > .wp-block-group > .flex > div:first-child ul{list-style:none;padding:0;margin:0}
.attraction .post-content > .wp-block-group > .flex > div:first-child li{
  padding:1rem 1.25rem;margin-bottom:1rem;
  background:var(--card);border-left:3px solid var(--brick);
  border-radius:0 var(--radius-base) var(--radius-base) 0;
  box-shadow:var(--shadow-sm)
}
.attraction .post-content > .wp-block-group > .flex > div:first-child li p:first-child{
  font-weight:600;font-size:var(--text-sm);color:var(--foreground);margin-bottom:.35rem
}
.attraction .post-content > .wp-block-group > .flex > div:first-child li p:last-child{
  font-size:var(--text-base);color:var(--foreground-soft);margin:0
}

/* ── Facilities / ratings ── */
.attraction .facilities.reviews{
  background:var(--card);border-radius:var(--radius-md);
  padding:1.75rem;border:1px solid var(--border);
  box-shadow:var(--shadow-sm)
}
.attraction .facilities.reviews .title{
  font-family:var(--font-heading);font-weight:700;
  font-size:var(--text-xl);margin-bottom:1.25rem;
  color:var(--foreground);
  padding-bottom:.75rem;border-bottom:1px solid var(--border)
}
.attraction .facilities.reviews p{font-size:var(--text-sm);font-weight:500;color:var(--foreground);margin-bottom:.25rem}
.attraction .facilities.reviews .wrap{
  background:var(--neutral-200);border-radius:4px;
  height:10px;overflow:hidden;margin-bottom:1rem;
  position:relative
}
.attraction .facilities.reviews .val{
  height:100%;border-radius:4px;
  background:linear-gradient(90deg,var(--brick),var(--brick-light));
  font-size:0;color:transparent
}
.attraction .post-content > .wp-block-group > .flex{gap:2.5rem}
.attraction .facilities.reviews:only-child{max-width:100%;width:100%}

/* ── Address card ── */
.attraction address.post-title{
  font-style:normal;font-size:var(--text-base);font-weight:500;
  display:inline-flex;align-items:center;gap:.5rem;
  padding:1rem 1.5rem;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-base);
  color:var(--foreground);
  box-shadow:var(--shadow-sm)
}
.attraction address.post-title::before{
  content:"📍";font-size:1.2em
}

/* ── Duration chip ── */
.attraction .duration{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.6rem 1.25rem;
  background:var(--background-alt);border:1px solid var(--border);
  border-radius:var(--radius-base);
  font-size:var(--text-base);font-weight:500;color:var(--foreground)
}

/* ── Departure / End points ── */
.attraction .dep-end-points{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-md);padding:1.5rem 2rem;
  margin-top:1.5rem;box-shadow:var(--shadow-sm)
}
.attraction .dep-end-points h2{
  font-size:var(--text-lg);font-weight:600;
  display:flex;align-items:center;gap:.5rem;
  border-left:none;padding-left:0;margin-top:0
}
.attraction .departure-points,.attraction .end-points{margin-bottom:1rem}
.attraction .departure-points p,.attraction .end-points p{
  padding:.4rem 0;border-bottom:1px solid var(--border);
  font-size:var(--text-base);color:var(--foreground-soft)
}
.attraction .departure-points p:last-child,.attraction .end-points p:last-child{border-bottom:none}

/* ── Large text / form heading ── */
.attraction .is-large-text{font-size:var(--text-xl);font-weight:600;font-family:var(--font-heading)}

/* ── Contact form ── */
.attraction .cf7b{
  margin-top:2rem;padding:2rem;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-md);
  border-top:4px solid var(--brick);
  box-shadow:var(--shadow-sm)
}
.attraction .cf7b .post-title{margin-bottom:.5rem}
.attraction .cf7b p{color:var(--foreground-soft)}

/* ── Footer / tags ── */
.attraction .post-footer{
  border-top:2px solid var(--border);
  padding-top:2rem;margin-top:3rem
}
.attraction .post-tags a{
  display:inline-block;padding:5px 14px;
  font-size:var(--text-xs);font-weight:500;
  border-radius:var(--radius-sm);
  background:var(--slate-muted);color:var(--slate);
  margin-right:.35rem;margin-bottom:.5rem;
  transition:all 200ms var(--ease-urban)
}
.attraction .post-tags a:hover{
  background:var(--brick-muted);color:var(--brick-dark)
}

/* ── Related attractions ── */
.attraction .related{
  margin-top:2.5rem;padding-top:2rem;
  border-top:1px solid var(--border)
}
.attraction .related-posts .post-title{
  font-size:var(--text-2xl);font-family:var(--font-heading);
  font-weight:700;text-align:center;margin-bottom:1rem;
  color:var(--foreground)
}
.attraction .related-posts .flex p{margin:0}
.attraction .related-posts .flex a{
  display:inline-block;
  padding:.6rem 1.25rem;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-base);
  font-weight:500;font-size:var(--text-base);
  color:var(--foreground);
  transition:all 200ms var(--ease-urban);
  box-shadow:var(--shadow-sm)
}
.attraction .related-posts .flex a:hover{
  border-color:var(--brick);color:var(--brick);
  box-shadow:var(--shadow-md);transform:translateY(-2px)
}

/* news aside */
.news{background:var(--background-alt);border-radius:var(--radius-md);padding:2rem;margin:2rem 0;border:1px solid var(--border)}
.news .post-title{font-family:var(--font-heading);font-weight:600}

/* ============================================================
   PAGES (generic, about-us, contact-us, privacy)
   ============================================================ */
/* --- Hero --- */
.pg-hero{background:var(--dark-bg);padding:clamp(3.5rem,7vw,6rem) 0;text-align:center;background-image:radial-gradient(ellipse at 30% 50%,rgba(184,86,54,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 30%,rgba(58,80,104,.05) 0%,transparent 45%)}
.pg-hero-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.pg-hero-title{font-family:var(--font-heading);font-weight:700;font-size:clamp(var(--text-4xl),5vw,var(--text-5xl));color:#fff;margin-bottom:.75rem}
.pg-hero-subtitle{font-size:var(--text-lg);color:var(--dark-text-muted);max-width:600px;margin:0 auto}
.pg-label{display:inline-block;font-family:var(--font-heading);font-weight:500;font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--brick);margin-bottom:.5rem}
.pg-label--light{color:var(--dark-brick)}

/* --- Sections --- */
.pg-section{padding:clamp(3rem,6vw,5rem) 0}
.pg-section--dark{background:var(--dark-bg);color:var(--dark-text);background-image:radial-gradient(ellipse at 40% 0%,rgba(184,86,54,.05) 0%,transparent 50%),radial-gradient(ellipse at 70% 100%,rgba(58,80,104,.04) 0%,transparent 45%)}
.pg-section-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.pg-section-header{text-align:center;margin-bottom:clamp(2rem,4vw,3rem)}
.pg-section-header::before{content:'';display:block;width:36px;height:3px;background:var(--brick);border-radius:2px;margin:0 auto 1rem}
.pg-section--dark .pg-section-header::before{background:var(--dark-brick)}
.pg-section-title{font-family:var(--font-heading);font-weight:600;font-size:clamp(var(--text-3xl),3.5vw,var(--text-4xl));color:var(--foreground)}
.pg-section-title--left{text-align:left}
.pg-section-title--light{color:var(--dark-text)}
.pg-section-subtitle{font-size:var(--text-lg);color:var(--muted-foreground);max-width:560px;margin:.75rem auto 0}
.pg-content{line-height:1.7;color:var(--foreground-soft)}
.pg-content h2,.pg-content h3{margin-top:2rem}
.pg-content a{color:var(--brick);font-weight:500}
.pg-content a:hover{color:var(--brick-dark)}
.pg-content img{border-radius:var(--radius-md);margin:1.5rem 0}

/* --- About Us --- */
.au-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.au-story-text{}
.au-prose{line-height:1.7;color:var(--foreground-soft)}
.au-prose p{margin-bottom:1rem}
.au-story-visual{position:relative}
.au-stats-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-md);display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.au-stat{text-align:center;padding:1rem .5rem}
.au-stat-number{display:block;font-family:var(--font-heading);font-weight:700;font-size:var(--text-4xl);letter-spacing:-.02em;color:var(--brick);line-height:1}
.au-stat-label{font-size:var(--text-sm);color:var(--muted-foreground);margin-top:.35rem;text-transform:uppercase;letter-spacing:.06em}
.au-values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.au-value-card{background:var(--dark-bg-card);border:1px solid var(--dark-border);border-radius:var(--radius-md);padding:2rem;text-align:center;transition:all 250ms var(--ease-urban)}
.au-value-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.au-value-icon{width:56px;height:56px;border-radius:var(--radius-md);background:rgba(212,122,94,.12);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}
.au-value-icon svg,.au-value-icon img{width:28px;height:28px;color:var(--dark-brick)}
.au-value-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-xl);color:var(--dark-text);margin-bottom:.5rem}
.au-value-desc{font-size:var(--text-base);color:var(--dark-text-muted);line-height:1.6}
.au-steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem;counter-reset:step}
.au-step{text-align:center;position:relative}
.au-step-num{width:52px;height:52px;border-radius:var(--radius-full);background:var(--brick-muted);border:2px solid var(--brick-border);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;font-family:var(--font-heading);font-weight:700;font-size:var(--text-xl);color:var(--brick)}
.au-step-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-xl);color:var(--foreground);margin-bottom:.5rem}
.au-step-text{font-size:var(--text-base);color:var(--foreground-soft);line-height:1.6}

/* --- Contact Us --- */
.cu-section{}
.cu-layout{display:grid;grid-template-columns:340px 1fr;gap:3rem;align-items:start}
.cu-sidebar{}
.cu-cards{display:flex;flex-direction:column;gap:1rem}
.cu-card{background:var(--background-alt);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem;display:flex;align-items:flex-start;gap:.75rem;transition:all 200ms var(--ease-urban);overflow-wrap:break-word;min-width:320px}
.cu-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-emphasis)}
.cu-card-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--brick-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cu-card-icon svg,.cu-card-icon img{width:22px;height:22px;color:var(--brick)}
.cu-card h3{font-family:var(--font-heading);font-weight:600;font-size:var(--text-base);margin:0 0 .15rem;color:var(--foreground)}
.cu-card p{margin:0;font-size:var(--text-sm);color:var(--foreground-soft);overflow-wrap:anywhere}
.cu-card a{color:var(--brick-dark);transition:color 180ms var(--ease-urban)}
.cu-card a:hover{color:var(--brick)}
.cu-form-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm)}
.cu-form-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-2xl);color:var(--foreground);margin-bottom:1.5rem}
.cu-form{display:flex;flex-direction:column;gap:1rem}
.cu-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cu-form-group{display:flex;flex-direction:column;gap:.35rem}
.cu-form-label{font-family:var(--font-heading);font-weight:500;font-size:var(--text-sm);color:var(--foreground)}
.cu-form-input{background:var(--card);border:1.5px solid var(--input-border);border-radius:var(--radius-base);padding:13px 16px;font-family:var(--font-body);font-size:var(--text-base);color:var(--foreground);transition:border-color 180ms,box-shadow 180ms}
.cu-form-input::placeholder{color:var(--neutral-400);font-weight:300}
.cu-form-input:focus{outline:none;border-color:var(--brick);box-shadow:0 0 0 3px var(--brick-muted)}
.cu-form-textarea{background:var(--card);border:1.5px solid var(--input-border);border-radius:var(--radius-base);padding:13px 16px;font-family:var(--font-body);font-size:var(--text-base);color:var(--foreground);min-height:120px;resize:vertical;transition:border-color 180ms,box-shadow 180ms}
.cu-form-textarea:focus{outline:none;border-color:var(--brick);box-shadow:0 0 0 3px var(--brick-muted)}
.cu-form-submit{padding:13px 28px;background:var(--brick);color:#fff;border:none;border-radius:var(--radius-base);font-family:var(--font-heading);font-weight:600;font-size:var(--text-base);letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:all 200ms var(--ease-urban);box-shadow:0 2px 6px rgba(184,86,54,.2);align-self:flex-start}
.cu-form-submit:hover{background:var(--brick-light);box-shadow:var(--shadow-brick);transform:translateY(-1px)}

/* ============================================================
   BLOG / CATEGORY / ARCHIVE (ar- & bl- classes)
   ============================================================ */
/* --- Blog Hero --- */
.bl-hero{background:var(--dark-bg);padding:clamp(3.5rem,7vw,6rem) 0;text-align:center;background-image:radial-gradient(ellipse at 25% 45%,rgba(184,86,54,.06) 0%,transparent 50%),radial-gradient(ellipse at 75% 30%,rgba(58,80,104,.05) 0%,transparent 45%)}
.bl-hero-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.bl-hero-label{font-family:var(--font-heading);font-weight:500;font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--dark-brick);margin-bottom:.75rem}
.bl-hero-title{font-family:var(--font-heading);font-weight:700;font-size:clamp(var(--text-4xl),5vw,var(--text-5xl));color:#fff;margin-bottom:.75rem}
.bl-hero-subtitle{font-size:var(--text-lg);color:var(--dark-text-muted);max-width:560px;margin:0 auto 1.5rem}
.bl-hero-search{max-width:540px;margin:0 auto}
.bl-hero-search form{display:flex;align-items:center;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);border-radius:var(--radius-md);padding:4px 4px 4px 18px;transition:border-color 200ms,box-shadow 200ms}
.bl-hero-search form:focus-within{border-color:var(--dark-brick);box-shadow:0 0 0 3px rgba(184,86,54,.15)}
.bl-hero-search input{border:none;outline:none;flex:1;font-family:var(--font-body);font-size:var(--text-md);padding:10px 12px;background:transparent;color:#fff}
.bl-hero-search input::placeholder{color:rgba(255,255,255,.45)}
.bl-hero-search button{background:var(--brick);color:#fff;border:none;border-radius:var(--radius-base);padding:10px 20px;font-family:var(--font-heading);font-weight:600;font-size:var(--text-base);cursor:pointer}

/* --- Featured Post --- */
.bl-featured{padding:clamp(2.5rem,5vw,4rem) 0;background:var(--background)}
.bl-featured-inner{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.bl-featured-grid{display:grid;grid-template-columns:1.2fr 1fr;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all 300ms var(--ease-urban)}
.bl-featured-grid:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.bl-featured-img{display:block;overflow:hidden}
.bl-featured-thumb{width:100%;height:100%;object-fit:cover;transition:transform 500ms var(--ease-urban)}
.bl-featured-grid:hover .bl-featured-thumb{transform:scale(1.04)}
.bl-featured-body{padding:clamp(1.5rem,3vw,2.5rem);display:flex;flex-direction:column;justify-content:center}
.bl-featured-title{font-family:var(--font-heading);font-weight:600;font-size:clamp(var(--text-2xl),3vw,var(--text-3xl));color:var(--foreground);margin:.5rem 0;line-height:1.25}
.bl-featured-excerpt{font-size:var(--text-base);color:var(--foreground-soft);line-height:1.6;margin-bottom:1rem}
.bl-featured-meta{font-size:var(--text-sm);color:var(--muted-foreground);margin-bottom:1rem}
.bl-featured-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-heading);font-weight:500;font-size:var(--text-base);color:var(--brick)}
.bl-featured-link::after{content:'→';transition:transform 200ms ease}
.bl-featured-link:hover{color:var(--brick-dark)}
.bl-featured-link:hover::after{transform:translateX(3px)}

/* --- Archive Grid (shared) --- */
.ar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.ar-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all 280ms var(--ease-urban)}
.ar-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--border-emphasis)}
.ar-card-thumb{display:block;overflow:hidden;aspect-ratio:16/10;flex-shrink:0;border-radius:var(--radius-md) var(--radius-md) 0 0}
.ar-card-img{width:100%;height:100%;object-fit:cover;transition:transform 500ms var(--ease-urban)}
.ar-card:hover .ar-card-img{transform:scale(1.04)}
.ar-card-body{padding:20px}
.ar-card-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-xl);color:var(--foreground);margin:.35rem 0;line-height:1.35}
.ar-card-title a{color:inherit}
.ar-card-title a:hover{color:var(--brick)}
.ar-card-excerpt{font-size:var(--text-base);color:var(--foreground-soft);line-height:1.6;margin:.5rem 0 0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.ar-card-meta{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--muted-foreground);margin-top:.75rem;text-transform:uppercase;letter-spacing:.04em}
.ar-pagination{margin-top:2.5rem}
.ar-pagination .nav-links{display:flex;justify-content:center;gap:.35rem;flex-wrap:wrap}
.ar-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 .5rem;border-radius:var(--radius-base);font-family:var(--font-heading);font-weight:500;font-size:var(--text-sm);color:var(--foreground-soft);border:1px solid var(--border);background:var(--card);transition:all 200ms var(--ease-urban)}
.ar-pagination .page-numbers:hover{border-color:var(--brick);color:var(--brick)}
.ar-pagination .page-numbers.current{background:var(--brick);color:#fff;border-color:var(--brick)}
.ar-empty{text-align:center;padding:3rem 0;font-size:var(--text-lg);color:var(--muted-foreground)}

/* ============================================================
   SINGLE POST (single.php)
   ============================================================ */
.sp-article{background:var(--background)}
.sp-featured{max-width:var(--wp--style--global--wide-size);margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.sp-featured-img{width:100%;border-radius:var(--radius-lg);margin-top:2rem;box-shadow:var(--shadow-md)}
.sp-body{max-width:var(--wp--style--global--content-size);margin:0 auto;padding:clamp(2rem,4vw,3rem) clamp(1rem,4vw,2rem)}
.sp-header{margin-bottom:2rem}
.sp-title{font-family:var(--font-heading);font-weight:700;font-size:clamp(var(--text-3xl),4vw,var(--text-4xl));color:var(--foreground);margin-bottom:.75rem}
.sp-meta{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:.5rem}
.sp-meta-sep{color:var(--neutral-300)}
.sp-content{line-height:1.7;color:var(--foreground-soft)}
.sp-content h2,.sp-content h3{margin-top:2rem}
.sp-content a{color:var(--brick);font-weight:500}
.sp-content a:hover{color:var(--brick-dark)}
.sp-content img{border-radius:var(--radius-md);margin:1.5rem 0}
.sp-content blockquote{font-family:var(--font-editorial);font-style:italic}
.sp-tags{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.5rem}
.sp-tag{display:inline-block;padding:4px 12px;font-family:var(--font-heading);font-size:var(--text-xs);font-weight:500;letter-spacing:.03em;border-radius:var(--radius-sm);background:var(--brick-muted);color:var(--brick);transition:all 150ms}
.sp-tag:hover{background:rgba(184,86,54,.12)}
.sp-nav{border-top:1px solid var(--border);margin-top:3rem;padding-top:2rem}
.sp-nav-inner{display:flex;justify-content:space-between;gap:2rem}
.sp-nav-link{display:flex;flex-direction:column;gap:.25rem;padding:1rem;border:1px solid var(--border);border-radius:var(--radius-base);flex:1;transition:all 200ms var(--ease-urban)}
.sp-nav-link:hover{border-color:var(--brick);box-shadow:var(--shadow-sm)}
.sp-nav-prev{align-items:flex-start}
.sp-nav-next{align-items:flex-end;text-align:right}
.sp-nav-link span:first-child{font-size:var(--text-xs);color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.08em}
.sp-nav-title{font-family:var(--font-heading);font-weight:600;font-size:var(--text-md);color:var(--foreground);line-height:1.35}

/* ============================================================
   SEARCH
   ============================================================ */
.sr-form{display:flex;align-items:center;max-width:600px;margin:0 auto 2rem;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:4px 4px 4px 18px;box-shadow:var(--shadow-md);transition:border-color 200ms,box-shadow 200ms}
.sr-form:focus-within{border-color:var(--brick);box-shadow:var(--shadow-lg)}
.sr-input{border:none;outline:none;flex:1;padding:10px 12px;font-family:var(--font-body);font-size:var(--text-md);background:transparent;color:var(--foreground)}

/* ============================================================
   404
   ============================================================ */
.nf-code{display:block;font-family:var(--font-heading);font-weight:800;font-size:clamp(5rem,15vw,10rem);line-height:1;color:var(--dark-brick);opacity:.4;margin-bottom:.5rem}
.nf-actions{text-align:center}
.nf-home-btn{margin-top:1.5rem}

/* ============================================================
   RESPONSIVE — 782px
   ============================================================ */
@media(max-width:782px){
  /* Header */
  .site-header-topbar{display:none}
  .site-header-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--card);border-bottom:1px solid var(--border);box-shadow:var(--shadow-lg);padding:1rem;flex-direction:column}
  .site-header-main.nav-open .site-header-nav{display:flex}
  .site-header-nav ul,.site-header-nav .header-menu{flex-direction:column;gap:0}
  .site-header-nav ul li a,.site-header-nav .header-menu li a{padding:.75rem 1rem;border-radius:var(--radius-base)}
  .site-header-nav ul li a::after,.site-header-nav .header-menu li a::after{display:none}
  .site-header-burger{display:flex;flex-direction:column;gap:4px}
  .site-header-actions{flex-direction:column;align-items:stretch;padding:0;border-top:none;margin-top:0;width:100%;gap:0;font-size:var(--text-sm)}
  .site-header-actions .site-header-phone,
  .site-header-actions .site-header-email{display:flex;padding:.75rem 1rem;border-radius:var(--radius-base);font-family:var(--font-heading);font-weight:500;color:var(--foreground);transition:color 180ms var(--ease-urban)}
  .site-header-actions .site-header-phone:hover,
  .site-header-actions .site-header-email:hover{color:var(--brick)}
  .site-header-actions .site-header-search-toggle{display:none}
  /* Footer */
  .site-footer-grid{grid-template-columns:1fr;gap:2rem}
  /* Homepage */
  .hp-hero{min-height:70vh}
  .hp-hotel-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
  .hp-features-grid{grid-template-columns:1fr}
  /* Hotel listing */
  .hl-hero-search form{flex-direction:column;padding:12px;gap:8px}
  .hl-hero-search input{width:100%;padding:12px}
  .hl-hero-search button{width:100%;padding:12px;text-align:center}
  .hl-filter-inner{flex-direction:column;align-items:flex-start}
  .hl-hotels-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
  /* Hotel single */
  .sh-gallery-grid{grid-template-columns:1fr;max-height:300px}
  .sh-gallery-side{display:none}
  .sh-quick-info-inner{flex-direction:column;align-items:flex-start}
  .sh-overview--with-sidebar{grid-template-columns:1fr}
  .sh-location-grid{grid-template-columns:1fr}
  .sh-rooms-grid{grid-template-columns:1fr}
  .sh-amenity-group ul{columns:1}
  /* About */
  .au-story-grid{grid-template-columns:1fr}
  .au-stats-card{grid-template-columns:1fr 1fr}
  /* Contact */
  .cu-layout{grid-template-columns:1fr}
  .cu-form-row{grid-template-columns:1fr}
  /* Blog featured */
  .bl-hero-search form{flex-direction:column;padding:12px;gap:8px}
  .bl-hero-search input{width:100%;padding:12px}
  .bl-hero-search button{width:100%;padding:12px;text-align:center}
  .bl-featured-grid{grid-template-columns:1fr}
  /* Archive */
  .ar-grid{grid-template-columns:1fr}
  /* Single post nav */
  .sp-nav-inner{flex-direction:column}
}

/* ============================================================
   RESPONSIVE — 480px
   ============================================================ */
@media(max-width:480px){
  .hp-hero{min-height:60vh}
  .hp-cta-buttons{flex-direction:column;align-items:center}
  .sh-cta-buttons{flex-direction:column;width:100%}
  .sh-btn-book,.sh-btn-call{text-align:center;width:100%}
  .sh-reviews-header{flex-direction:column}
  .au-stats-card{grid-template-columns:1fr}
  .hl-hotels-grid{grid-template-columns:1fr}
}
