/* ================================================================
   VALENTINA POODLES v2 – MAIN STYLESHEET
   ================================================================ */

:root {
  --clr-bg:         #FDFAF6;
  --clr-navy:       #0D1B2A;
  --clr-navy-mid:   #1A2E44;
  --clr-gold:       #B8942B;
  --clr-gold-light: #D4AF5A;
  --clr-gold-pale:  #F2E8CE;
  --clr-cream:      #F7F1E6;
  --clr-text:       #2A2A2A;
  --clr-muted:      #6B6660;
  --clr-white:      #FFFFFF;
  --clr-border:     #E5DDD0;
  --clr-footer-bg:  #f5f5f5;

  --ff-display: 'Cormorant Garamond', serif;
  --ff-body:    'DM Sans', sans-serif;

  --radius:     6px;
  --shadow-sm:  0 2px 12px rgba(13,27,42,.08);
  --shadow-md:  0 8px 32px rgba(13,27,42,.14);
  --shadow-lg:  0 20px 60px rgba(13,27,42,.18);
  --header-h:   90px;
  --topbar-h:   38px;
  --transition: 0.3s cubic-bezier(.4,0,.2,1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--ff-body); color: var(--clr-text); background: var(--clr-bg); line-height: 1.65; -webkit-font-smoothing: antialiased; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
img { max-width: 100%; display: block; height: auto; }

h1,h2,h3,h4,h5,h6 { font-family: var(--ff-display); font-weight: 600; line-height: 1.2; color: var(--clr-navy); }
h1 { font-size: clamp(32px,5vw,56px); }
h2 { font-size: clamp(26px,4vw,42px); }
h3 { font-size: clamp(20px,3vw,28px); }
p  { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }

.container { max-width: 1320px; margin: 0 auto; padding: 0 32px; width: 100%; }

/* ── BUTTONS ──────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:7px; border-radius:var(--radius); font-family:var(--ff-body); font-weight:600; cursor:pointer; transition:all var(--transition); border:none; outline:none; text-decoration:none; letter-spacing:.02em; white-space:nowrap; }
.btn-primary { padding:12px 26px; font-size:14px; background:var(--clr-gold); color:var(--clr-white); box-shadow:0 4px 14px rgba(184,148,43,.35); }
.btn-primary:hover { background:#9E7D22; box-shadow:0 6px 20px rgba(184,148,43,.45); transform:translateY(-1px); color:#fff; }
.btn-secondary { padding:12px 26px; font-size:14px; background:transparent; color:var(--clr-navy); border:1.5px solid var(--clr-border); }
.btn-secondary:hover { border-color:var(--clr-gold); color:var(--clr-gold); background:var(--clr-gold-pale); }
.btn-lg { padding:15px 34px; font-size:15px; }

/* ── TOP BAR ──────────────────────────────────────────────────── */
.site-topbar { background:#662113; height:var(--topbar-h); display:flex; align-items:center; position:relative; z-index:1001; }
.topbar-inner { display:flex; align-items:center; justify-content:space-between; }
.topbar-left { display:flex; align-items:center; gap:18px; }

.topbar-item { display:flex; align-items:center; gap:7px; font-size:12.5px; color:#f5f5f5; font-weight:400; letter-spacing:.02em; transition:color var(--transition); }
.topbar-item svg { opacity:.85; flex-shrink:0; color:#f5f5f5; }
.topbar-item:hover { color:#ffd59e; }
.topbar-item:hover svg { opacity:1; color:#ffd59e; }

.topbar-divider { width:1px; height:14px; background:rgba(255,255,255,.25); }
.topbar-right { display:flex; align-items:center; gap:10px; }
.topbar-social { display:flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:50%; background:rgba(255,255,255,.12); color:#f5f5f5; transition:background var(--transition),color var(--transition); }
.topbar-social:hover { background:rgba(255,255,255,.25); color:#fff; }

/* Professional badge — no dot, clean pill with paw icon */
.topbar-badge {
  display:flex; align-items:center; gap:7px;
  font-size:11px; font-weight:600;
  color:#fff;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.3);
  border-radius:4px;
  padding:4px 12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.topbar-badge-icon { font-size:12px; flex-shrink:0; }
@keyframes vp-pulse { 0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)} }

/* ── MAIN HEADER — not sticky ─────────────────────────────────── */
.site-header { position:relative; z-index:1000; background:var(--clr-white); border-bottom:1px solid var(--clr-border); box-shadow:var(--shadow-sm); }
.header-inner { height:var(--header-h); display:flex; align-items:center; justify-content:space-between; gap:16px; overflow:visible; }

/* Logo */
.site-branding { display:flex; align-items:center; gap:13px; flex-shrink:0; text-decoration:none; min-width:0; }
.custom-logo-link { display:flex; align-items:center; flex-shrink:0; }
.custom-logo-link img { max-height:52px; width:auto; }
.logo-fallback { width:52px; height:52px; border-radius:50%; background:var(--clr-navy); display:flex; align-items:center; justify-content:center; border:2px solid var(--clr-gold); font-family:var(--ff-display); font-size:22px; font-weight:600; color:var(--clr-gold-light); flex-shrink:0; }
.site-title-wrap { line-height:1; min-width:0; }
.site-title { display:block; font-family:var(--ff-display); font-size:21px; font-weight:700; color:var(--clr-navy); line-height:1.1; letter-spacing:.01em; white-space:nowrap; }
.site-title:hover { color:var(--clr-gold); }
.site-tagline { display:block; font-size:10.5px; font-weight:500; color:var(--clr-gold); letter-spacing:.12em; text-transform:uppercase; margin-top:2px; white-space:nowrap; }

/* Desktop Nav */
.main-navigation { flex:1; display:flex; justify-content:center; min-width:0; overflow:visible; }
.nav-menu { display:flex; align-items:center; gap:0; flex-wrap:nowrap; }
.nav-menu > li { position:relative; }
.nav-menu > li > a { display:flex; align-items:center; gap:6px; padding:8px 13px; font-size:13.5px; font-weight:500; color:var(--clr-text); border-radius:var(--radius); transition:color var(--transition),background var(--transition); white-space:nowrap; letter-spacing:.01em; }
/* SVG nav icon — gold color, small, aligned */
.nav-menu > li > a .nav-icon { display:inline-flex; align-items:center; flex-shrink:0; color:var(--clr-gold); opacity:.85; transition:opacity var(--transition),transform var(--transition); }
.nav-menu > li > a:hover .nav-icon,
.nav-menu > li.current-menu-item > a .nav-icon,
.nav-menu > li.current-menu-parent > a .nav-icon { opacity:1; transform:scale(1.1); }
.nav-menu > li > a .caret { transition:transform var(--transition); flex-shrink:0; opacity:.5; }
.nav-menu > li:hover > a .caret { transform:rotate(180deg); }
.nav-menu > li > a:hover, .nav-menu > li.current-menu-item > a, .nav-menu > li.current-menu-parent > a { color:var(--clr-gold); background:var(--clr-gold-pale); }

/* Dropdown */
.nav-menu .sub-menu { position:absolute; top:calc(100% + 8px); left:50%; transform:translateX(-50%) translateY(-8px); background:var(--clr-white); border:1px solid var(--clr-border); border-radius:10px; box-shadow:var(--shadow-lg); min-width:230px; padding:8px; opacity:0; pointer-events:none; transition:opacity var(--transition),transform var(--transition); z-index:200; list-style:none; }
.nav-menu .sub-menu::before { content:''; position:absolute; top:-6px; left:50%; width:12px; height:12px; background:var(--clr-white); border-left:1px solid var(--clr-border); border-top:1px solid var(--clr-border); transform:translateX(-50%) rotate(45deg); }
.nav-menu > li:hover .sub-menu, .nav-menu > li:focus-within .sub-menu { opacity:1; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.nav-menu .sub-menu a { display:flex; align-items:center; gap:10px; padding:10px 14px; font-size:13.5px; color:var(--clr-text); border-radius:6px; transition:background var(--transition),color var(--transition),padding-left var(--transition); }
/* sub-icon: coloured box with SVG inside */
.nav-menu .sub-menu .sub-icon { width:30px; height:30px; border-radius:7px; background:var(--clr-cream); border:1px solid var(--clr-border); display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--clr-gold); transition:background var(--transition),color var(--transition); }
.nav-menu .sub-menu a:hover .sub-icon { background:var(--clr-gold); color:#fff; border-color:var(--clr-gold); }
.nav-menu .sub-menu a:hover { background:var(--clr-cream); color:var(--clr-gold); padding-left:18px; }
.nav-menu .sub-menu .dropdown-divider { height:1px; background:var(--clr-border); margin:6px 8px; }

/* Header Actions */
.header-actions { display:flex; align-items:center; gap:10px; flex-shrink:0; margin-left:auto; }
.btn-header-contact { padding:9px 16px; font-size:13px; background:transparent; color:var(--clr-navy); border:1.5px solid var(--clr-border); border-radius:var(--radius); display:inline-flex; align-items:center; gap:6px; font-weight:500; transition:all var(--transition); white-space:nowrap; flex-shrink:0; }
.btn-header-contact:hover { border-color:var(--clr-gold); color:var(--clr-gold); background:var(--clr-gold-pale); }
.btn-quote { padding:10px 20px; font-size:13.5px; background:var(--clr-gold); color:var(--clr-white); border-radius:var(--radius); display:inline-flex; align-items:center; gap:7px; font-weight:600; box-shadow:0 4px 14px rgba(184,148,43,.35); transition:all var(--transition); white-space:nowrap; flex-shrink:0; text-decoration:none; }
.btn-quote:hover { background:#9E7D22; transform:translateY(-1px); color:#fff; box-shadow:0 6px 20px rgba(184,148,43,.45); }

/* Hamburger */
.hamburger-btn { display:none; flex-direction:column; justify-content:center; align-items:center; width:42px; height:42px; border:1.5px solid var(--clr-border); border-radius:var(--radius); background:transparent; cursor:pointer; gap:5px; padding:0; flex-shrink:0; transition:background var(--transition),border-color var(--transition); }
.hamburger-btn:hover { background:var(--clr-cream); border-color:var(--clr-gold); }
.hamburger-bar { width:20px; height:2px; background:var(--clr-navy); border-radius:2px; transition:all var(--transition); transform-origin:center; }
.hamburger-btn.open .hamburger-bar:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger-btn.open .hamburger-bar:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger-btn.open .hamburger-bar:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ── MOBILE SIDEBAR ───────────────────────────────────────────── */
.sidebar-overlay { position:fixed; inset:0; background:rgba(13,27,42,.55); backdrop-filter:blur(4px); z-index:1999; opacity:0; pointer-events:none; transition:opacity var(--transition); }
.sidebar-overlay.open { opacity:1; pointer-events:auto; }
.mobile-sidebar { position:fixed; top:0; right:0; width:min(340px,88vw); height:100dvh; background:var(--clr-white); z-index:2000; display:flex; flex-direction:column; transform:translateX(100%); transition:transform var(--transition); overflow-y:auto; }
.mobile-sidebar.open { transform:translateX(0); }
.sidebar-header { display:flex; align-items:center; justify-content:space-between; padding:18px 22px; border-bottom:1px solid var(--clr-border); flex-shrink:0; }
.sidebar-close-btn { width:36px; height:36px; border-radius:50%; background:var(--clr-cream); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--clr-navy); font-size:18px; line-height:1; transition:background var(--transition); }
.sidebar-close-btn:hover { background:var(--clr-gold-pale); }

.sidebar-nav ul { list-style:none; }
.sidebar-nav > ul > li { border-bottom:1px solid rgba(229,221,208,.5); }
.sidebar-nav > ul > li > a { display:flex; align-items:center; justify-content:space-between; padding:13px 22px; font-size:15px; font-weight:500; color:var(--clr-text); transition:background var(--transition),color var(--transition); gap:10px; }
/* SVG icon in sidebar — navy, turns gold on hover */
.sidebar-nav > ul > li > a .s-icon { display:inline-flex; align-items:center; color:var(--clr-navy); opacity:.6; flex-shrink:0; transition:color var(--transition),opacity var(--transition); }
.sidebar-nav > ul > li > a:hover .s-icon,
.sidebar-nav > ul > li.current-menu-item > a .s-icon { color:var(--clr-gold); opacity:1; }
.sidebar-nav > ul > li > a .s-label { flex:1; }
.sidebar-nav > ul > li > a:hover, .sidebar-nav > ul > li.current-menu-item > a { color:var(--clr-gold); }
.sidebar-nav > ul > li > a:hover { background:var(--clr-cream); }
.sidebar-arrow { width:22px; height:22px; display:flex; align-items:center; justify-content:center; color:var(--clr-muted); transition:transform var(--transition); flex-shrink:0; font-size:18px; font-weight:300; }
.sidebar-nav > ul > li.expanded > a .sidebar-arrow { transform:rotate(180deg); }

.sidebar-nav .sub-menu { display:none; background:var(--clr-cream); list-style:none; }
.sidebar-nav li.expanded .sub-menu { display:block; }
.sidebar-nav .sub-menu li { border-bottom:none; }
.sidebar-nav .sub-menu a { display:flex; align-items:center; gap:8px; padding:11px 22px 11px 36px; font-size:13.5px; color:var(--clr-muted); transition:color var(--transition); }
.sidebar-nav .sub-menu a::before { content:''; width:5px; height:5px; border-radius:50%; background:var(--clr-gold); flex-shrink:0; }
.sidebar-nav .sub-menu a:hover { color:var(--clr-gold); }

.sidebar-footer { padding:18px 22px; border-top:1px solid var(--clr-border); display:flex; flex-direction:column; gap:10px; flex-shrink:0; }
.sidebar-footer .btn { width:100%; justify-content:center; }
.sidebar-contact-row { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--clr-muted); }
.sidebar-contact-row svg { color:var(--clr-gold); flex-shrink:0; }

/* ── CONTENT ──────────────────────────────────────────────────── */
.site-content { min-height:60vh; }
.page-content, .entry-content { max-width:900px; margin:60px auto; padding:0 32px; }
.entry-content p, .entry-content ul, .entry-content ol { font-size:16px; line-height:1.8; color:var(--clr-text); margin-bottom:1.2em; }
.entry-content h2, .entry-content h3 { margin:1.6em 0 .6em; }
.entry-content ul { padding-left:1.5em; list-style:disc; }
.entry-content ol { padding-left:1.5em; list-style:decimal; }
.entry-content img { border-radius:10px; margin:1.5em 0; }
.entry-content a { color:var(--clr-gold); }
.entry-content a:hover { text-decoration:underline; }

.page-banner { background:linear-gradient(135deg,var(--clr-navy) 0%,var(--clr-navy-mid) 100%); padding:60px 32px; text-align:center; position:relative; overflow:hidden; }
.page-banner::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 30% 50%,rgba(184,148,43,.1) 0%,transparent 60%),radial-gradient(circle at 70% 20%,rgba(184,148,43,.07) 0%,transparent 50%); }
.page-banner-inner { position:relative; z-index:1; }
.page-banner h1 { font-family:var(--ff-display); font-size:clamp(28px,4vw,48px); color:var(--clr-white); margin-bottom:12px; }
.page-banner .breadcrumb { display:flex; align-items:center; justify-content:center; gap:8px; font-size:13px; color:rgba(255,255,255,.5); }
.page-banner .breadcrumb a { color:rgba(255,255,255,.65); }
.page-banner .breadcrumb a:hover { color:var(--clr-gold-light); }

/* ================================================================
   FOOTER — background: #f5f5f5 (light)
   ================================================================ */
.site-footer { background:var(--clr-footer-bg); color:var(--clr-text); position:relative; overflow:hidden; border-top:3px solid transparent; background-clip:padding-box; }
.site-footer::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,transparent,var(--clr-gold),var(--clr-gold-light),var(--clr-gold),transparent); }

.footer-top { padding:64px 0 48px; display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:48px; }

/* Footer Brand */
.footer-brand-logo { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.footer-logo-mark { width:46px; height:46px; border-radius:50%; background:var(--clr-navy); border:1.5px solid var(--clr-gold); display:flex; align-items:center; justify-content:center; font-family:var(--ff-display); font-size:19px; font-weight:600; color:var(--clr-gold-light); flex-shrink:0; overflow:hidden; }
.footer-logo-mark img { width:100%; height:100%; object-fit:cover; }
.footer-brand-name { display:block; font-family:var(--ff-display); font-size:18px; font-weight:700; color:var(--clr-navy); }
.footer-brand-sub { display:block; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--clr-gold); margin-top:1px; }
.footer-desc { font-size:13.5px; line-height:1.75; color:var(--clr-muted); margin-bottom:20px; max-width:300px; }
.footer-social { display:flex; gap:10px; margin-bottom:20px; }
.footer-social-link { width:36px; height:36px; border-radius:8px; background:var(--clr-navy); border:1px solid rgba(13,27,42,.15); display:flex; align-items:center; justify-content:center; color:#fff; transition:all var(--transition); }
.footer-social-link:hover { background:var(--clr-gold); border-color:var(--clr-gold); transform:translateY(-2px); }
.footer-trust { display:flex; gap:8px; flex-wrap:wrap; }
.footer-badge { display:flex; align-items:center; gap:5px; font-size:11.5px; color:var(--clr-muted); background:#fff; border:1px solid var(--clr-border); border-radius:20px; padding:4px 11px; }
.footer-badge svg { color:var(--clr-gold); flex-shrink:0; }

/* Footer Column Titles */
.footer-col-header { display:flex; align-items:center; justify-content:space-between; cursor:default; padding-bottom:12px; margin-bottom:16px; border-bottom:1px solid var(--clr-border); }
.footer-col-title { font-family:var(--ff-display); font-size:16px; font-weight:600; color:var(--clr-navy); letter-spacing:.02em; }
/* + / − toggle — desktop hidden */
.footer-toggle-btn { display:none; width:24px; height:24px; border-radius:50%; background:var(--clr-navy); border:none; cursor:pointer; color:#fff; font-size:16px; line-height:1; align-items:center; justify-content:center; flex-shrink:0; transition:background var(--transition); }
.footer-toggle-btn:hover { background:var(--clr-gold); }

.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-link { display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--clr-muted); transition:color var(--transition), gap var(--transition); }
/* SVG icon in footer links — gold colored, small */
.footer-link-icon { display:inline-flex; align-items:center; flex-shrink:0; color:var(--clr-gold); opacity:.8; transition:opacity var(--transition); }
.footer-link:hover .footer-link-icon { opacity:1; }
/* Remove the old ::before dash when icon is present */
.footer-link:hover { color:var(--clr-gold); gap:11px; }

.footer-contact-item { display:flex; align-items:flex-start; gap:12px; margin-bottom:14px; }
.footer-contact-icon { width:32px; height:32px; border-radius:8px; background:var(--clr-gold-pale); border:1px solid var(--clr-gold); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.footer-contact-icon svg { color:var(--clr-gold); }
.footer-contact-label { font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--clr-muted); margin-bottom:2px; }
.footer-contact-value { font-size:13.5px; color:var(--clr-navy); transition:color var(--transition); }
.footer-contact-value:hover { color:var(--clr-gold); }

.footer-newsletter { margin-top:10px; }
.footer-newsletter-label { font-size:12px; color:var(--clr-muted); margin-bottom:9px; }
.footer-newsletter-form { display:flex; border-radius:7px; overflow:hidden; border:1.5px solid var(--clr-border); }
.footer-newsletter-input { flex:1; background:#fff; border:none; padding:10px 13px; font-family:var(--ff-body); font-size:13px; color:var(--clr-text); outline:none; }
.footer-newsletter-input::placeholder { color:var(--clr-muted); }
.footer-newsletter-btn { padding:10px 15px; background:var(--clr-gold); border:none; color:#fff; font-size:12px; font-weight:600; cursor:pointer; font-family:var(--ff-body); letter-spacing:.04em; text-transform:uppercase; transition:background var(--transition); }
.footer-newsletter-btn:hover { background:#9E7D22; }

/* Footer Bottom */
.footer-bottom { border-top:1px solid var(--clr-border); padding:18px 0; background:var(--clr-footer-bg); }
.footer-bottom-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copyright { font-size:12.5px; color:var(--clr-muted); }
.footer-legal { display:flex; gap:18px; }
.footer-legal a { font-size:12.5px; color:var(--clr-muted); transition:color var(--transition); }
.footer-legal a:hover { color:var(--clr-gold); }

/* ── WIDGETS ──────────────────────────────────────────────────── */
.widget { margin-bottom:40px; }
.widget-title { font-family:var(--ff-display); font-size:17px; font-weight:600; color:var(--clr-navy); margin-bottom:14px; padding-bottom:10px; border-bottom:1px solid var(--clr-border); }

/* ================================================================
   RESPONSIVE
   ================================================================ */
/* At 1280px nav items get smaller to fit */
@media (max-width:1280px) {
  .nav-menu > li > a { padding:7px 9px; font-size:12.5px; }
  .btn-quote { padding:9px 15px; font-size:12.5px; }
}
/* At 1100px hide desktop nav, show hamburger */
@media (max-width:1100px) {
  .main-navigation { display:none; }
  .hamburger-btn { display:flex; }
  .btn-header-contact { display:none; }
  .footer-top { grid-template-columns:1fr 1fr; gap:36px; }
}
@media (max-width:768px) {
  :root { --header-h:70px; --topbar-h:34px; }
  /* topbar VISIBLE on mobile — compact version */
  .site-topbar { height:var(--topbar-h); }
  .topbar-left { gap:10px; }
  .topbar-item { font-size:11px; gap:5px; }
  .topbar-divider { display:none; }
  /* keep email visible on mobile; hide hours for a cleaner top bar */
  .topbar-item.topbar-hours { display:none; }
  .topbar-right { gap:8px; }
  .topbar-badge { font-size:10px; padding:3px 9px; letter-spacing:.05em; }
  .header-inner { padding:0 18px; }
  .site-title { font-size:17px; }
  .site-tagline { display:none; }
  .logo-fallback { width:44px; height:44px; }
  .footer-top { grid-template-columns:1fr; gap:0; padding:40px 0 0; }
  .page-content, .entry-content { padding:0 18px; margin:36px auto; }
  .container { padding:0 18px; }

  /* Mobile footer accordion */
  .footer-col-header { cursor:pointer; padding:18px 0; margin-bottom:0; border-bottom:1px solid var(--clr-border); }
  .footer-col-header:hover .footer-col-title { color:var(--clr-gold); }
  .footer-toggle-btn { display:flex; }
  .footer-col-body { display:none; padding:16px 0 20px; }
  .footer-col-body.open { display:block; }
  .footer-col-brand-body { display:block !important; padding:0 0 28px; }
  .footer-bottom-inner { flex-direction:column; text-align:center; }
  .footer-bottom { padding:16px 0; }
}
@media (max-width:480px) {
  .footer-trust { display:none; }
  .btn-lg { padding:13px 24px; font-size:14px; }
}

/* ================================================================
   HOMEPAGE SECTIONS
   ================================================================ */

/* ── HERO ─────────────────────────────────────────────────────── */
.vp-hero { position:relative; background:linear-gradient(135deg,#0D1B2A 0%,#1A2E44 60%,#0D1B2A 100%); min-height:88vh; display:flex; align-items:center; overflow:hidden; }
.vp-hero__bg-pattern { position:absolute; inset:0; background-image:radial-gradient(circle at 15% 50%,rgba(184,148,43,.12) 0%,transparent 55%),radial-gradient(circle at 85% 20%,rgba(184,148,43,.08) 0%,transparent 45%); pointer-events:none; }
.vp-hero__inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; padding:80px 0; }
.vp-hero__eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:11.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--clr-gold-light); background:rgba(184,148,43,.1); border:1px solid rgba(184,148,43,.25); border-radius:4px; padding:5px 14px; margin-bottom:20px; }
.vp-hero h1 { font-family:var(--ff-display); font-size:clamp(38px,5vw,62px); font-weight:700; color:#fff; line-height:1.1; margin-bottom:22px; letter-spacing:-.01em; }
.vp-hero h1 em { font-style:italic; color:var(--clr-gold-light); }
.vp-hero__desc { font-size:17px; color:rgba(255,255,255,.65); line-height:1.75; margin-bottom:36px; max-width:520px; }
.vp-hero__cta { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:40px; }
.vp-hero__trust { display:flex; gap:20px; flex-wrap:wrap; }
.vp-hero__trust-item { display:flex; align-items:center; gap:7px; font-size:12.5px; color:rgba(255,255,255,.55); }
.vp-hero__trust-item svg { color:var(--clr-gold); flex-shrink:0; }
.vp-hero__img { position:relative; }
.vp-hero__img-wrap { border-radius:20px; overflow:hidden; aspect-ratio:4/3.2; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; }
.vp-hero__img-placeholder { text-align:center; color:rgba(255,255,255,.3); }
.vp-hero__img-placeholder svg { margin:0 auto 12px; color:rgba(255,255,255,.2); }
.vp-hero__img-placeholder p { font-size:13px; letter-spacing:.05em; }
.vp-hero__badge { position:absolute; bottom:-20px; left:-20px; background:#fff; border-radius:14px; padding:16px 20px; box-shadow:0 12px 40px rgba(13,27,42,.2); display:flex; align-items:center; gap:12px; }
.vp-hero__badge-icon { width:44px; height:44px; border-radius:10px; background:var(--clr-gold-pale); display:flex; align-items:center; justify-content:center; color:var(--clr-gold); flex-shrink:0; }
.vp-hero__badge-num { font-family:var(--ff-display); font-size:22px; font-weight:700; color:var(--clr-navy); line-height:1; }
.vp-hero__badge-lbl { font-size:11px; color:var(--clr-muted); text-transform:uppercase; letter-spacing:.06em; }

/* ── STATS BAR ────────────────────────────────────────────────── */
.vp-stats { background:var(--clr-navy); padding:0; }
.vp-stats__inner { display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid rgba(255,255,255,.06); }
.vp-stats__item { padding:28px 24px; text-align:center; border-right:1px solid rgba(255,255,255,.06); }
.vp-stats__item:last-child { border-right:none; }
.vp-stats__num { font-family:var(--ff-display); font-size:38px; font-weight:700; color:var(--clr-gold-light); line-height:1; margin-bottom:6px; }
.vp-stats__lbl { font-size:12.5px; color:rgba(255,255,255,.45); text-transform:uppercase; letter-spacing:.07em; }

/* ── SECTION BASE ─────────────────────────────────────────────── */
.vp-section { padding:88px 0; }
.vp-section--alt { background:var(--clr-cream); }
.vp-section--white { background:#fff; }
.vp-section--light { background:#fafafa; }
.vp-section__head { text-align:center; max-width:640px; margin:0 auto 56px; }
.vp-section__eyebrow { display:inline-block; font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--clr-gold); background:var(--clr-gold-pale); border-radius:4px; padding:4px 14px; margin-bottom:14px; }
.vp-section__title { font-family:var(--ff-display); font-size:clamp(28px,4vw,42px); color:var(--clr-navy); margin-bottom:14px; line-height:1.2; }
.vp-section__sub { font-size:16px; color:var(--clr-muted); line-height:1.7; }

/* ── POODLE TYPE CARDS ────────────────────────────────────────── */
.vp-types__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.vp-type-card { background:#fff; border:1px solid var(--clr-border); border-radius:16px; overflow:hidden; transition:box-shadow var(--transition),transform var(--transition); text-decoration:none; color:inherit; display:block; }
.vp-type-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-6px); }
.vp-type-card__img { aspect-ratio:4/3; background:var(--clr-cream); display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.vp-type-card__img img { width:100%; height:100%; object-fit:cover; }
.vp-type-card__img-ph { text-align:center; color:var(--clr-muted); opacity:.5; }
.vp-type-card__img-ph svg { margin:0 auto 8px; }
.vp-type-card__badge { position:absolute; top:12px; right:12px; background:var(--clr-gold); color:#fff; font-size:10.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; border-radius:4px; padding:4px 10px; }
.vp-type-card__body { padding:20px 22px; }
.vp-type-card__name { font-family:var(--ff-display); font-size:19px; font-weight:600; color:var(--clr-navy); margin-bottom:6px; }
.vp-type-card__desc { font-size:13px; color:var(--clr-muted); line-height:1.6; margin-bottom:14px; }
.vp-type-card__link { display:inline-flex; align-items:center; gap:5px; font-size:13px; font-weight:600; color:var(--clr-gold); }
.vp-type-card__link svg { transition:transform var(--transition); }
.vp-type-card:hover .vp-type-card__link svg { transform:translateX(4px); }

/* ── FEATURES / WHY US ────────────────────────────────────────── */
.vp-features { display:grid; grid-template-columns:repeat(5,1fr); gap:24px; }
.vp-feature { background:#fff; border:1px solid var(--clr-border); border-radius:14px; padding:28px 22px; text-align:center; transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition); }
.vp-feature:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); border-color:var(--clr-gold); }
.vp-feature__icon { width:60px; height:60px; border-radius:50%; background:var(--clr-gold-pale); border:2px solid var(--clr-gold); display:flex; align-items:center; justify-content:center; margin:0 auto 16px; color:var(--clr-gold); transition:background var(--transition); }
.vp-feature:hover .vp-feature__icon { background:var(--clr-gold); color:#fff; }
.vp-feature__title { font-family:var(--ff-display); font-size:16px; font-weight:600; color:var(--clr-navy); margin-bottom:8px; }
.vp-feature__desc { font-size:13px; color:var(--clr-muted); line-height:1.65; }

/* ── ABOUT SECTION ────────────────────────────────────────────── */
.vp-about { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.vp-about__img { border-radius:20px; overflow:hidden; aspect-ratio:1; background:var(--clr-cream); display:flex; align-items:center; justify-content:center; border:1px solid var(--clr-border); position:relative; }
.vp-about__img img { width:100%; height:100%; object-fit:cover; }
.vp-about__img-ph { text-align:center; color:var(--clr-muted); opacity:.4; }
.vp-about__years { position:absolute; bottom:24px; right:24px; background:var(--clr-navy); color:#fff; border-radius:12px; padding:16px 20px; text-align:center; }
.vp-about__years-num { font-family:var(--ff-display); font-size:34px; font-weight:700; color:var(--clr-gold-light); line-height:1; }
.vp-about__years-lbl { font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.55); margin-top:4px; }
.vp-about__list { display:flex; flex-direction:column; gap:14px; margin:24px 0 32px; }
.vp-about__list-item { display:flex; align-items:flex-start; gap:12px; }
.vp-about__list-icon { width:32px; height:32px; border-radius:50%; background:var(--clr-gold-pale); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--clr-gold); margin-top:1px; }
.vp-about__list-text strong { display:block; font-size:14px; font-weight:600; color:var(--clr-navy); margin-bottom:2px; }
.vp-about__list-text span { font-size:13px; color:var(--clr-muted); }

/* ── FEATURED PUPPIES ─────────────────────────────────────────── */
.vp-puppies__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.vp-puppy-card { background:#fff; border:1px solid var(--clr-border); border-radius:16px; overflow:hidden; transition:box-shadow var(--transition),transform var(--transition); }
.vp-puppy-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.vp-puppy-card__img { aspect-ratio:4/3; background:var(--clr-cream); display:flex; align-items:center; justify-content:center; position:relative; }
.vp-puppy-card__img img { width:100%; height:100%; object-fit:cover; }
.vp-puppy-card__img-ph { text-align:center; color:var(--clr-muted); opacity:.4; }
.vp-puppy-card__status { position:absolute; top:14px; left:14px; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; border-radius:5px; padding:4px 12px; }
.vp-puppy-card__status--available { background:var(--clr-gold); color:#fff; }
.vp-puppy-card__status--sold { background:rgba(13,27,42,.7); color:rgba(255,255,255,.7); }
.vp-puppy-card__body { padding:20px 22px; }
.vp-puppy-card__name { font-family:var(--ff-display); font-size:20px; font-weight:600; color:var(--clr-navy); margin-bottom:10px; }
.vp-puppy-card__meta { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px; }
.vp-puppy-card__tag { display:flex; align-items:center; gap:5px; font-size:11.5px; color:var(--clr-muted); background:var(--clr-cream); border-radius:4px; padding:4px 10px; }
.vp-puppy-card__tag svg { color:var(--clr-gold); flex-shrink:0; }
.vp-puppy-card__desc { font-size:13px; color:var(--clr-muted); line-height:1.65; margin-bottom:18px; }
.vp-puppy-card__footer { display:flex; align-items:center; justify-content:space-between; padding-top:14px; border-top:1px solid var(--clr-border); }
.vp-puppy-card__price { font-family:var(--ff-display); font-size:22px; font-weight:700; color:var(--clr-gold); }

/* ── TESTIMONIALS ─────────────────────────────────────────────── */
.vp-testimonials { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.vp-testi-card { background:#fff; border:1px solid var(--clr-border); border-radius:16px; padding:30px 28px; display:flex; flex-direction:column; gap:16px; position:relative; }
.vp-testi-card::before { content:'❝'; position:absolute; top:18px; right:24px; font-family:var(--ff-display); font-size:52px; color:var(--clr-gold-pale); line-height:1; }
.vp-testi__stars { display:flex; gap:3px; color:var(--clr-gold); }
.vp-testi__text { font-size:14.5px; color:var(--clr-text); line-height:1.75; font-style:italic; flex:1; }
.vp-testi__author { display:flex; align-items:center; gap:12px; }
.vp-testi__avatar { width:42px; height:42px; border-radius:50%; background:var(--clr-gold-pale); border:2px solid var(--clr-gold); display:flex; align-items:center; justify-content:center; font-family:var(--ff-display); font-size:18px; font-weight:600; color:var(--clr-gold); flex-shrink:0; }
.vp-testi__name { font-weight:600; font-size:14px; color:var(--clr-navy); }
.vp-testi__loc { font-size:12px; color:var(--clr-muted); }

/* ── FAQ ──────────────────────────────────────────────────────── */
.vp-faq { max-width:780px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.vp-faq__item { background:#fff; border:1px solid var(--clr-border); border-radius:10px; overflow:hidden; transition:border-color var(--transition); }
.vp-faq__item.open { border-color:var(--clr-gold); }
.vp-faq__q { display:flex; align-items:center; justify-content:space-between; padding:20px 24px; cursor:pointer; gap:16px; }
.vp-faq__q-text { font-family:var(--ff-display); font-size:17px; font-weight:600; color:var(--clr-navy); line-height:1.3; }
.vp-faq__item.open .vp-faq__q-text { color:var(--clr-gold); }
.vp-faq__icon { width:28px; height:28px; border-radius:50%; background:var(--clr-cream); border:1px solid var(--clr-border); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--clr-gold); font-size:18px; font-weight:300; transition:background var(--transition),transform var(--transition); }
.vp-faq__item.open .vp-faq__icon { background:var(--clr-gold); color:#fff; transform:rotate(45deg); }
.vp-faq__a { display:none; padding:0 24px 20px; font-size:14.5px; color:var(--clr-muted); line-height:1.75; border-top:1px solid var(--clr-border); padding-top:16px; }
.vp-faq__item.open .vp-faq__a { display:block; }

/* ── CONTACT FORM SECTION ─────────────────────────────────────── */
.vp-contact { display:grid; grid-template-columns:1fr 1.4fr; gap:72px; align-items:start; }
.vp-contact__info-item { display:flex; align-items:flex-start; gap:14px; margin-bottom:22px; }
.vp-contact__info-icon { width:44px; height:44px; border-radius:12px; background:var(--clr-gold-pale); border:1px solid var(--clr-gold); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--clr-gold); }
.vp-contact__info-label { font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--clr-muted); margin-bottom:3px; }
.vp-contact__info-value { font-size:15px; font-weight:500; color:var(--clr-navy); }
.vp-contact__info-value a { color:var(--clr-navy); transition:color var(--transition); }
.vp-contact__info-value a:hover { color:var(--clr-gold); }
.vp-contact__shipping { background:var(--clr-navy); border-radius:14px; padding:22px 24px; margin-top:28px; }
.vp-contact__shipping-title { font-family:var(--ff-display); font-size:16px; color:#fff; margin-bottom:8px; }
.vp-contact__shipping-text { font-size:13px; color:rgba(255,255,255,.55); line-height:1.65; }
.vp-contact__shipping-badge { display:inline-flex; align-items:center; gap:6px; background:var(--clr-gold); color:#fff; border-radius:4px; padding:4px 12px; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; margin-top:12px; }

/* Form styles */
.vp-form { background:#fff; border:1px solid var(--clr-border); border-radius:20px; padding:36px 36px; box-shadow:var(--shadow-sm); }
.vp-form__title { font-family:var(--ff-display); font-size:26px; font-weight:600; color:var(--clr-navy); margin-bottom:6px; }
.vp-form__sub { font-size:14px; color:var(--clr-muted); margin-bottom:28px; }
.vp-form__grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.vp-form__group { display:flex; flex-direction:column; gap:6px; }
.vp-form__group--full { grid-column:1/-1; }
.vp-form__label { font-size:12.5px; font-weight:600; color:var(--clr-navy); letter-spacing:.03em; text-transform:uppercase; }
.vp-form__label span { color:var(--clr-gold); }
.vp-form__input, .vp-form__select, .vp-form__textarea { width:100%; padding:12px 16px; border:1.5px solid var(--clr-border); border-radius:8px; font-family:var(--ff-body); font-size:14px; color:var(--clr-text); background:#fff; outline:none; transition:border-color var(--transition),box-shadow var(--transition); }
.vp-form__input:focus, .vp-form__select:focus, .vp-form__textarea:focus { border-color:var(--clr-gold); box-shadow:0 0 0 3px rgba(184,148,43,.12); }
.vp-form__input::placeholder, .vp-form__textarea::placeholder { color:#aaa; }
.vp-form__textarea { resize:vertical; min-height:110px; }
.vp-form__submit { width:100%; padding:14px 24px; background:var(--clr-gold); color:#fff; border:none; border-radius:8px; font-family:var(--ff-body); font-size:15px; font-weight:700; cursor:pointer; transition:all var(--transition); display:flex; align-items:center; justify-content:center; gap:8px; letter-spacing:.02em; margin-top:8px; }
.vp-form__submit:hover { background:#9E7D22; transform:translateY(-1px); box-shadow:0 6px 20px rgba(184,148,43,.4); }

/* Form alerts */
.vp-alert { padding:14px 20px; border-radius:8px; font-size:14px; font-weight:500; margin-bottom:20px; display:flex; align-items:center; gap:10px; }
.vp-alert--success { background:#f0fdf4; border:1px solid #86efac; color:#166534; }
.vp-alert--error { background:#fef2f2; border:1px solid #fca5a5; color:#991b1b; }

/* ── MARQUEE TRUST BAR ────────────────────────────────────────── */
.vp-marquee { background:var(--clr-gold); padding:14px 0; overflow:hidden; }
.vp-marquee__track { display:flex; gap:48px; animation:vp-marquee 28s linear infinite; white-space:nowrap; }
.vp-marquee__item { display:flex; align-items:center; gap:10px; font-size:13px; font-weight:600; color:#fff; letter-spacing:.04em; text-transform:uppercase; flex-shrink:0; }
.vp-marquee__item svg { flex-shrink:0; opacity:.8; }
@keyframes vp-marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── RESPONSIVE HOMEPAGE ──────────────────────────────────────── */
@media (max-width:1100px) {
  .vp-types__grid { grid-template-columns:repeat(2,1fr); }
  .vp-features { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:900px) {
  .vp-hero__inner { grid-template-columns:1fr; gap:40px; }
  .vp-hero__img { display:none; }
  .vp-hero { min-height:auto; }
  .vp-about { grid-template-columns:1fr; gap:40px; }
  .vp-about__img { aspect-ratio:16/9; }
  .vp-contact { grid-template-columns:1fr; gap:40px; }
  .vp-testimonials { grid-template-columns:1fr 1fr; }
  .vp-stats__inner { grid-template-columns:repeat(2,1fr); }
  .vp-puppies__grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:640px) {
  .vp-section { padding:56px 0; }
  .vp-types__grid { grid-template-columns:1fr 1fr; gap:14px; }
  .vp-features { grid-template-columns:1fr 1fr; }
  .vp-testimonials { grid-template-columns:1fr; }
  .vp-puppies__grid { grid-template-columns:1fr; }
  .vp-form { padding:24px 20px; }
  .vp-form__grid { grid-template-columns:1fr; }
  .vp-stats__inner { grid-template-columns:repeat(2,1fr); }
  .vp-hero h1 { font-size:clamp(30px,7vw,48px); }
}


/* ================================================================
   BLOG INDEX + SINGLE
   ================================================================ */
.blog-index { padding:48px 0 72px; }
.blog-index__intro { max-width:760px; margin:0 auto 40px; text-align:center; }
.blog-index__intro--compact { max-width:680px; }
.blog-index__eyebrow { display:inline-block; margin-bottom:14px; padding-bottom:4px; border-bottom:2px solid var(--clr-gold); color:var(--clr-gold); font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; }
.blog-index__title { font-family:var(--ff-display); font-size:clamp(30px,4vw,50px); line-height:1.12; color:var(--clr-navy); margin:0 0 16px; }
.blog-index__text { font-size:15.5px; line-height:1.8; color:var(--clr-muted); }
.blog-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:26px; }
.blog-card { display:flex; flex-direction:column; min-width:0; background:#fff; border:1px solid var(--clr-border); border-radius:22px; overflow:hidden; box-shadow:0 10px 28px rgba(13,27,42,.04); transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition); }
.blog-card:hover { transform:translateY(-6px); box-shadow:0 18px 48px rgba(13,27,42,.10); border-color:rgba(184,148,43,.35); }
.blog-card__media { display:flex; align-items:center; justify-content:center; aspect-ratio:16/10; background:linear-gradient(135deg,#f8f4ec 0%,#f2ebdf 100%); overflow:hidden; }
.blog-card__media img { width:100%; height:100%; object-fit:cover; display:block; transition:transform var(--transition); }
.blog-card:hover .blog-card__media img { transform:scale(1.03); }
.blog-card__placeholder { font-family:var(--ff-display); font-size:28px; color:rgba(13,27,42,.58); }
.blog-card__body { display:flex; flex:1; flex-direction:column; padding:24px; }
.blog-card__meta { display:flex; flex-wrap:wrap; gap:8px; align-items:center; margin-bottom:12px; font-size:12px; font-weight:600; color:var(--clr-muted); letter-spacing:.04em; text-transform:uppercase; }
.blog-card__title { font-family:var(--ff-display); font-size:28px; line-height:1.2; margin:0 0 14px; }
.blog-card__title a { color:var(--clr-navy); }
.blog-card__title a:hover { color:var(--clr-gold); }
.blog-card__excerpt { color:var(--clr-muted); font-size:14.5px; line-height:1.78; }
.blog-card__excerpt p:last-child { margin-bottom:0; }
.blog-card__cta { display:inline-flex; align-items:center; justify-content:center; align-self:flex-start; margin-top:20px; padding:11px 18px; border-radius:10px; border:1px solid var(--clr-border); color:var(--clr-navy); font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; background:#fff; }
.blog-card__cta:hover { color:#fff; background:var(--clr-gold); border-color:var(--clr-gold); }
.blog-index__empty { background:#fff; border:1px solid var(--clr-border); border-radius:18px; padding:28px; text-align:center; color:var(--clr-muted); }
.blog-pagination { margin-top:34px; }
.blog-pagination .nav-links { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; }
.blog-pagination .page-numbers { min-width:42px; padding:10px 14px; border:1px solid var(--clr-border); border-radius:10px; text-align:center; color:var(--clr-navy); background:#fff; }
.blog-pagination .page-numbers.current,
.blog-pagination .page-numbers:hover { background:var(--clr-gold); color:#fff; border-color:var(--clr-gold); }

.blog-single { padding:48px 0 72px; }
.blog-single__layout { display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:28px; align-items:start; }
.blog-single__article { min-width:0; background:#fff; border:1px solid var(--clr-border); border-radius:24px; overflow:hidden; box-shadow:0 14px 40px rgba(13,27,42,.05); }
.blog-single__featured { background:linear-gradient(135deg,#f8f4ec 0%,#f2ebdf 100%); }
.blog-single__featured img { width:100%; max-height:520px; object-fit:cover; display:block; }
.blog-single__inner { padding:34px; }
.blog-single__meta { display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-bottom:16px; color:var(--clr-muted); font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; }
.blog-single__meta a { color:var(--clr-gold); }
.blog-single__title { margin:0 0 18px; font-family:var(--ff-display); font-size:clamp(34px,5vw,54px); line-height:1.05; color:var(--clr-navy); }
.blog-single__excerpt { margin:0 0 26px; padding:18px 20px; border-left:4px solid var(--clr-gold); border-radius:0 14px 14px 0; background:var(--clr-cream); color:var(--clr-muted); font-size:16px; line-height:1.8; }
.blog-single__content.entry-content { max-width:none; margin:0; padding:0; }
.blog-single__content img { width:100%; height:auto; }
.blog-single__tags { display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-top:28px; padding-top:20px; border-top:1px solid var(--clr-border); color:var(--clr-muted); }
.blog-single__tags a { display:inline-flex; align-items:center; padding:7px 12px; border-radius:999px; background:var(--clr-cream); border:1px solid var(--clr-border); color:var(--clr-navy); font-size:12px; font-weight:600; }
.blog-single__tags a:hover { background:var(--clr-gold); border-color:var(--clr-gold); color:#fff; }
.blog-single__sidebar { min-width:0; }
.blog-sidebar-card,
.blog-single__sidebar .widget { background:#fff; border:1px solid var(--clr-border); border-radius:20px; padding:24px; box-shadow:0 10px 28px rgba(13,27,42,.04); }
.blog-sidebar-card + .blog-sidebar-card,
.blog-single__sidebar .widget + .widget { margin-top:18px; }
.blog-sidebar-card:first-child,
.blog-single__sidebar .widget:first-child { position:sticky; top:28px; }
.blog-sidebar-card__title,
.blog-single__sidebar .widget-title { margin:0 0 16px; font-family:var(--ff-display); font-size:26px; color:var(--clr-navy); }
.blog-sidebar-list,
.blog-single__sidebar ul { list-style:none; margin:0; padding:0; }
.blog-sidebar-list li,
.blog-single__sidebar li { border-top:1px solid rgba(229,221,208,.8); }
.blog-sidebar-list li:first-child,
.blog-single__sidebar li:first-child { border-top:none; }
.blog-sidebar-list a,
.blog-single__sidebar li a { display:flex; flex-direction:column; gap:4px; padding:14px 0; color:var(--clr-navy); }
.blog-sidebar-list a:hover,
.blog-single__sidebar li a:hover { color:var(--clr-gold); }
.blog-sidebar-list a span { color:var(--clr-muted); font-size:12px; text-transform:uppercase; letter-spacing:.05em; }
.blog-sidebar-list--cats li,
.blog-single__sidebar .cat-item { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:14px 0; color:var(--clr-muted); }
.blog-sidebar-list--cats li a,
.blog-single__sidebar .cat-item a { padding:0; flex:1; }
.blog-post-nav { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; margin-top:34px; padding-top:24px; border-top:1px solid var(--clr-border); }
.blog-post-nav__item { min-height:100%; }
.blog-post-nav__item a { display:flex; flex-direction:column; justify-content:center; gap:6px; min-height:100%; padding:18px 20px; border-radius:18px; border:1px solid var(--clr-border); background:#fff; color:var(--clr-navy); }
.blog-post-nav__item a:hover { border-color:var(--clr-gold); background:var(--clr-gold-pale); }
.blog-post-nav__item span { font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--clr-gold); }
.blog-post-nav__item strong { font-size:16px; line-height:1.5; }

@media (max-width:1100px) {
  .blog-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .blog-single__layout { grid-template-columns:1fr; }
  .blog-sidebar-card:first-child,
  .blog-single__sidebar .widget:first-child { position:static; }
}
@media (max-width:767px) {
  .blog-index,
  .blog-single { padding:34px 0 56px; }
  .blog-grid { grid-template-columns:1fr; gap:20px; }
  .blog-card__body { padding:20px; }
  .blog-card__title { font-size:24px; }
  .blog-single__inner { padding:22px 18px; }
  .blog-single__title { font-size:34px; }
  .blog-post-nav { grid-template-columns:1fr; }
}
