/*
Theme Name: Shov Music (shovmusic)
Theme URI: https://example.com/shovmusic
Author: Kwame Anane
Description: Minimal music streaming theme with persistent floating player, AJAX navigation, responsive featured image and polished UI.
Version: 5.0
License: GNU General Public License v2 or later
Text Domain: shovmusic
*/
:root{
  --shov-accent: #C6005D;
  --shov-bg: #ffffff;
  --shov-text: #000000;
  --shov-header-height: 72px;
  --shov-radius: 15px;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,sans-serif;background:var(--shov-bg);color:var(--shov-text);line-height:1.45}
a{color:var(--shov-accent);text-decoration:none}
a:hover{text-decoration:underline}

/* Header */
header.site-header{padding:12px 18px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;background:var(--shov-bg);position:relative}
.menu-toggle{display:none;background:none;border:0;font-size:22px;cursor:pointer;color:var(--shov-accent)}
.site-branding .site-title{font-weight:700;margin:0;font-size:1.2rem;text-align:center}

/* Main layout */
.main-wrap{max-width:1100px;margin:0 auto;padding:18px}
.post-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.post-card{display:flex;gap:12px;align-items:flex-start;background:#fff;padding:10px;border-radius:10px}
.post-card img{width:96px;height:96px;object-fit:cover;border-radius:10px}
.post-card h3{margin:0;font-size:1rem}
.post-card .excerpt{color:#666;font-size:0.95rem;margin-top:6px}

/* Featured image boxed 4:2 ratio */
.single-featured .featured-wrap{max-width:900px;margin:0 auto 18px;overflow:hidden;border-radius:var(--shov-radius);box-shadow:0 8px 24px rgba(0,0,0,0.08);position:relative}
.single-featured .featured-wrap .featured-image{
  width:100%;
  aspect-ratio: 4 / 2;
  overflow:hidden;
  display:block;
}
.single-featured .featured-wrap .featured-image img{
  width:100%;height:100%;object-fit:cover;display:block;border-radius:var(--shov-radius);
}
/* Title overlay */
.featured-title-overlay{
  position:absolute;left:0;right:0;bottom:12px;padding:12px 16px;
  background: rgba(198,0,93,0.85);
  color:#fff;font-weight:700;border-radius:10px;margin:12px;
  max-width:calc(100% - 24px);
  transform: translateY(10px);
  opacity:0;
  transition: transform 380ms ease, opacity 380ms ease;
}
.featured-wrap.show-overlay .featured-title-overlay{ transform: translateY(0); opacity:1; }

.single-featured .post-content{max-width:900px;margin:18px auto;padding:0 12px}

/* More songs section */
.more-songs{max-width:900px;margin:30px auto;padding:0 12px}
.more-songs h3{margin-bottom:12px;display:flex;align-items:center;gap:12px}
.more-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.more-card{display:flex;gap:10px;align-items:center;background:#fff;padding:8px;border-radius:10px;transition:transform 260ms ease,opacity 260ms ease;opacity:0;transform:translateY(8px)}
.more-card.show{opacity:1;transform:translateY(0)}
.more-card img{width:100px;height:100px;object-fit:cover;border-radius:10px}

/* Floating player */
#shov-floating-player{
  position:fixed;left:50%;transform:translateX(-50%);bottom:18px;max-width:600px;width:calc(100% - 32px);z-index:99999;border-radius:12px;overflow:hidden;display:none;box-shadow:0 12px 40px rgba(0,0,0,0.12);background:#fff;transition:transform 0.28s ease, opacity 0.28s ease;opacity:0;
}
#shov-floating-player.active{display:block;opacity:1;transform:translateX(-50%) translateY(0)}
#shov-floating-player.minimized{opacity:0;transform:translateX(-50%) translateY(60px);display:none}
#shov-floating-player .player-head{display:flex;justify-content:flex-end;padding:6px 8px;background:transparent}
#shov-floating-player .player-head button{border:0;background:transparent;padding:6px;cursor:pointer;font-weight:700;color:var(--shov-accent);font-size:18px}
#shov-floating-player .player-body iframe{width:100%;height:clamp(140px,38vw,180px);border:0;display:block;border-radius:0 0 12px 12px}
#shov-player-mini{position:fixed;right:18px;bottom:18px;width:56px;height:56px;border-radius:28px;display:none;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(0,0,0,0.15);background:var(--shov-accent);color:#fff;z-index:99999;cursor:pointer}

/* Responsive */
@media(max-width:768px){
  .menu-toggle{display:block;position:absolute;left:12px;top:12px}
  .site-branding .site-title{text-align:center;width:100%}
  .site-nav{display:none;flex-direction:column;gap:12px;background:#fff;position:absolute;top:var(--shov-header-height);left:0;right:0;padding:12px;border-top:1px solid #eee;box-shadow:0 8px 20px rgba(0,0,0,0.08)}
  header.site-header.open .site-nav{display:flex}
  .post-grid{grid-template-columns:repeat(1,1fr)}
  .more-grid{grid-template-columns:repeat(1,1fr)}
  .more-card img{width:100%;height:auto}
  .featured-wrap{margin:0 auto 14px}
  .featured-title-overlay{font-size:1rem;padding:10px}
}

@media(min-width:769px){
  .more-grid{grid-template-columns:repeat(2,1fr)}
}

/* small polish */
.post-card a img{border-radius:8px}


/* Appended listing/grid styles from updated package */
:root{
  --shov-accent: #C6005D;
  --shov-bg: #f6f6f7;
  --shov-text: #111;
  --shov-radius: 14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;background:var(--shov-bg);color:var(--shov-text)}
a{color:var(--shov-accent);text-decoration:none}
a:hover{text-decoration:underline}

/* Boxed content wrapper */
.site-inner{max-width:1200px;margin:24px auto;padding:18px;background:#fff;border-radius:16px;box-shadow:0 8px 30px rgba(0,0,0,0.04)}

/* Header */
header.site-header{padding:12px 18px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;background:transparent;position:relative}
.menu-toggle{display:none;background:none;border:0;font-size:22px;cursor:pointer;color:var(--shov-accent)}

/* Page heading */
.page-heading{display:flex;align-items:center;justify-content:center;flex-direction:column;padding:18px 0}
.page-heading h1{margin:0;font-size:1.6rem;font-weight:800}
.page-heading .underline{height:4px;width:80px;background:var(--shov-accent);border-radius:4px;margin-top:10px}

/* Grid */
.grid-wrap{padding:6px 12px 30px}
.grid{display:grid;gap:18px;grid-template-columns:repeat(4,1fr)}

/* Card: square tile with title overlay */
.card{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;background:#eee;display:block;text-decoration:none;color:inherit;box-shadow:0 6px 18px rgba(0,0,0,0.04);transition:transform .28s ease,box-shadow .28s ease}
.card img{width:100%;height:100%;object-fit:cover;display:block}

/* Maintain 1:1 ratio */
.card .ratio{width:100%;padding-top:100%;position:relative;overflow:hidden}
.card .ratio img{position:absolute;top:0;left:0;width:100%;height:100%;}

/* Title overlay centered bottom */
.card .title-overlay{position:absolute;left:8px;right:8px;bottom:8px;padding:8px 10px;background:rgba(198,0,93,0.85);color:#fff;font-weight:700;border-radius:8px;text-align:center;backdrop-filter: blur(2px);}

/* Hover */
.card:hover{transform:translateY(-6px);box-shadow:0 12px 30px rgba(0,0,0,0.08)}

/* Responsive columns */
@media (max-width:1100px){ .grid{grid-template-columns:repeat(3,1fr)} }
@media (max-width:800px){ .grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:480px){ .grid{grid-template-columns:repeat(1,1fr)} .site-inner{margin:12px;padding:12px} .page-heading h1{font-size:1.4rem} }

/* Load more */
.load-more-wrap{text-align:center;padding:20px}
.load-more {background:var(--shov-accent);color:#fff;border:0;padding:10px 18px;border-radius:999px;cursor:pointer;font-weight:700}

/* Floating player kept as before */
#shov-floating-player{position:fixed;left:50%;transform:translateX(-50%);bottom:18px;max-width:600px;width:calc(100% - 32px);z-index:99999;border-radius:12px;overflow:hidden;display:none;background:#fff;box-shadow:0 12px 40px rgba(0,0,0,0.12)}
#shov-floating-player.active{display:block}


/* Added horizontal menu styles */

/* Menu: horizontal desktop, centered */
.site-nav .menu { display:flex; gap:18px; justify-content:center; align-items:center; padding:0; margin:0; list-style:none; }
.site-nav .menu li { display:inline-block; }
.footer-menu { display:flex; gap:14px; justify-content:center; align-items:center; padding:0; margin:0; list-style:none; }
/* Mobile: hamburger toggles .open on header to show nav vertically */
@media (max-width: 768px) {
  .site-nav { display:none; position:absolute; top:72px; left:0; right:0; background:#fff; padding:12px; box-shadow:0 8px 20px rgba(0,0,0,0.08); z-index:9999; }
  header.site-header.open .site-nav { display:block; }
  .site-nav .menu { flex-direction:column; gap:12px; }
  .footer-menu { flex-wrap:nowrap; overflow-x:auto; padding:6px 12px; }
}


/* === Mobile Hamburger Menu === */
.hamburger-menu {
  display: none;
  cursor: pointer;
  flex-direction: column;
  justify-content: space-between;
  width: 26px;
  height: 20px;
  z-index: 1001;
}
.hamburger-menu span {
  display: block;
  height: 3px;
  background: #C6005D;
  border-radius: 2px;
  transition: 0.3s;
}
.hamburger-menu.active span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}
.hamburger-menu.active span:nth-child(2) {
  opacity: 0;
}
.hamburger-menu.active span:nth-child(3) {
  transform: rotate(-45deg) translate(5px, -5px);
}
.mobile-menu {
  display: none;
  position: absolute;
  top: 60px;
  left: 0;
  width: 100%;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  padding: 15px 0;
  transition: all 0.3s ease;
  text-align: center;
}
.mobile-menu.open {
  display: block;
  animation: slideDown 0.3s ease forwards;
}
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 768px) {
  .hamburger-menu { display: flex; }
  .main-navigation { display: none; }
}
.mobile-menu a {
  display: block;
  padding: 10px;
  color: #333;
  text-decoration: none;
  transition: background 0.3s;
}
.mobile-menu a:hover {
  background: #C6005D;
  color: #fff;
}


/* ===== shovmusic5: Mobile left hamburger & slide-down dropdown ===== */
/* header layout */
.site-header{display:flex;align-items:center;justify-content:space-between;position:relative;padding:12px 18px;background:#fff;z-index:9999}
.hamburger-left{flex:0 0 auto;display:none}
#hamburger-icon{background:transparent;border:0;padding:8px;display:inline-flex;flex-direction:column;gap:4px;cursor:pointer}
#hamburger-icon .hb-line{width:22px;height:3px;background:var(--shov-accent);display:block;border-radius:2px;transition:all .28s ease}
#hamburger-icon.open .hb-line-1{transform:rotate(45deg) translate(4px,4px)}
#hamburger-icon.open .hb-line-2{opacity:0;transform:translateX(-10px)}
#hamburger-icon.open .hb-line-3{transform:rotate(-45deg) translate(4px,-4px)}

/* primary nav desktop */
.site-nav{flex:0 0 100%;display:flex;justify-content:center}
.site-nav .menu{display:flex;gap:18px;align-items:center;list-style:none;padding:0;margin:0}

/* mobile dropdown */
.mobile-dropdown{display:none;position:relative;width:100%;background:#fff;box-shadow:0 8px 24px rgba(0,0,0,0.08);overflow:hidden;transition:all .32s ease;padding:0}
.mobile-dropdown.open{display:block;animation:shov_slide_down .32s ease both}
@keyframes shov_slide_down{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.mobile-dropdown .mobile-menu{display:flex;flex-direction:column;padding:12px 6px}
.mobile-dropdown .mobile-menu li{margin:6px 0;padding:6px 12px;border-radius:8px}
.mobile-dropdown .mobile-menu li a{display:block;color:#111;text-decoration:none;padding:8px 6px;border-radius:6px}
.mobile-dropdown .mobile-menu li a:hover{background:rgba(198,0,93,0.85);color:#fff}

/* responsive behavior */
@media(max-width:768px){
  .hamburger-left{display:block}
  .site-nav{display:none}
  .site-header{justify-content:center}
  .site-branding{order:2}
  .hamburger-left{order:1;position:absolute;left:12px;top:12px}
}

/* ensure desktop shows nav */
@media(min-width:769px){
  #mobile-dropdown{display:none!important}
  #hamburger-icon{display:none!important}
}



/* === shovmusic7: mobile hamburger & slide-down partial overlay (darker) === */
.shov-hamburger-btn{background:transparent;border:0;padding:8px;display:inline-flex;flex-direction:column;gap:4px;cursor:pointer}
.shov-hamburger-btn .hb-line{width:22px;height:3px;background:var(--shov-accent);border-radius:2px;display:block;transition:all .28s ease}
.shov-hamburger-btn.open .hb-1{transform:rotate(45deg) translate(4px,4px)}
.shov-hamburger-btn.open .hb-2{opacity:0;transform:translateX(-10px)}
.shov-hamburger-btn.open .hb-3{transform:rotate(-45deg) translate(4px,-4px)}

/* mobile dropdown area */
.shov-mobile-dropdown{display:none;position:relative;width:100%;top:0;left:0;z-index:9998}
.shov-mobile-dropdown.open{display:block}
.shov-mobile-dropdown-inner{background:#fff;box-shadow:0 12px 30px rgba(0,0,0,0.08);padding:12px;border-radius:10px;margin:8px 12px;position:relative;z-index:1001;}

/* partial overlay behind dropdown */
.shov-mobile-overlay{position:absolute;left:0;right:0;top:0;bottom:0;background:rgba(0,0,0,0.5);opacity:0;pointer-events:none;transition:opacity .08s linear;z-index:1000}
.shov-mobile-dropdown.open .shov-mobile-overlay{opacity:1;pointer-events:auto}

/* mobile menu items */
.mobile-menu{display:flex;flex-direction:column;gap:6px;padding:6px}
.mobile-menu li{list-style:none;margin:0;padding:0;border-radius:8px}
.mobile-menu li a{display:block;padding:10px 12px;color:#111;text-decoration:none;border-radius:6px}
.mobile-menu li a:hover{background:rgba(198,0,93,0.85);color:#fff}

/* responsive visibility */
@media (max-width:768px){
  #shov-desktop-nav{display:none}
  .hamburger-left{display:block}
  .site-branding{order:2}
  .hamburger-left{order:1}
}

/* ensure desktop shows nav */
@media (min-width:769px){
  .shov-mobile-dropdown{display:none !important}
  .shov-hamburger-btn{display:none !important}
}


/* ==== Appended SHOV header/menu fixes ==== */


/* ==== SHOV FIX: Header + Menu layout strong patch ==== */
/* Make header constrained and avoid horizontal overflow */
.site-header, header.site-header, .header-inner {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: visible !important;
  padding-left: 12px !important;
  padding-right: 12px !important;
}

/* Ensure boxed content centers and doesn't affect header width */
.site-inner, .container, .wrap, .content-area {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 18px !important;
  padding-right: 18px !important;
  box-sizing: border-box !important;
}

/* Prevent body-level horizontal scroll */
html, body { overflow-x: hidden !important; }

/* Desktop nav should be flex and wrap if too many items */
.site-nav, #shov-desktop-nav, .site-nav .menu {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 12px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Ensure logo doesn't push nav off-screen */
.site-branding, .custom-logo-link, .site-title { max-width: 60% !important; text-align: center; overflow: hidden; }

/* Make nav items shrink if necessary */
.site-nav .menu li, .site-nav li { flex: 0 1 auto !important; white-space: nowrap; }

/* Mobile specific adjustments */
@media (max-width: 768px){
  .site-header { padding-left: 8px !important; padding-right: 8px !important; }
  .site-branding { max-width: 70% !important; }
  .hamburger-left, .shov-hamburger-btn, #shov-hamburger { display: block !important; }
  #shov-desktop-nav, .site-nav { display: none !important; }
  .shov-mobile-dropdown-inner { margin: 6px !important; border-radius: 8px !important; }
  .shov-mobile-dropdown-inner .mobile-menu li a { padding: 12px 10px !important; font-size: 16px !important; }
}

/* Fix potential large margins */
header.site-header, .site-header { margin: 0 auto !important; left: 0; right: 0; }


/* Added: Next Page button styling */
.next-page-btn {
    display: inline-block;
    padding: 10px 20px;
    background: #111;
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
    transition: background 0.3s ease;
}
.next-page-btn:hover { background: #333; }
.pagination-wrap { text-align:center; margin:30px 0; }

/* --- Pagination Buttons (Styled for Shov Theme) --- */
.pagination-wrap {
  text-align: center;
  margin: 40px 0;
}

.pagination-nav a {
  display: inline-block;
  background: var(--shov-accent, #C6005D);
  color: #ffffff;
  padding: 12px 28px;
  border-radius: 6px;
  text-decoration: none;
  margin: 0 6px;
  font-weight: 500;
  transition: all 0.3s ease;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
}

.pagination-nav a:hover {
  background: #000000;
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
}

.pagination-nav .prev-page a::before {
  content: "← ";
}

.pagination-nav .next-page a::after {
  content: " →";
}

/* Footer container */
.site-footer {
  background: #f9f9f9;
  text-align: center;
  padding: 24px 16px;
  border-top: 1px solid #eee;
  color: #555;
}

/* Footer navigation menu */
.footer-menu {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  list-style: none;
  margin: 0 0 10px 0;
  padding: 0;
  flex-wrap: wrap;
}

.footer-menu li a {
  display: inline-block;
  padding: 8px 16px;
  background: var(--shov-accent, #C6005D);
  color: #fff;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 500;
  transition: all 0.3s ease;
}

.footer-menu li a:hover {
  background: #000;
  color: #fff;
  transform: translateY(-2px);
}

/* Responsive adjustments */
@media (max-width: 600px) {
  .footer-menu {
    gap: 10px;
    flex-wrap: wrap;
  }
  .footer-menu li a {
    padding: 8px 14px;
    font-size: 15px;
  }
}

/* Footer copyright */
.site-footer div {
  font-size: 14px;
  color: #777;
}

/* Pagination Buttons */
.pagination-wrap {
  text-align: center;
  margin: 40px 0;
}

.pagination-nav a {
  display: inline-block;
  background: var(--shov-accent, #C6005D);
  color: #ffffff;
  padding: 12px 28px;
  border-radius: 6px;
  text-decoration: none;
  margin: 0 6px;
  font-weight: 500;
  transition: all 0.3s ease;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
}

.pagination-nav a:hover {
  background: #000000;
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
}

.pagination-nav .prev-page a::before {
  content: "← ";
}

.pagination-nav .next-page a::after {
  content: " →";
}




/* === ShovMusic: Footer (Horizontal Menu) + Pagination === */

.site-footer {
  background: #f9f9f9;
  text-align: center;
  padding: 24px 16px;
  border-top: 1px solid #eee;
  color: #555;
}

/* Force footer menu horizontal layout */
.footer-menu,
.footer-nav ul {
  display: flex !important;
  justify-content: center;
  align-items: center;
  gap: 18px;
  list-style: none !important;
  margin: 0 0 10px 0;
  padding: 0;
  flex-wrap: wrap;
}

.footer-menu li,
.footer-nav ul li {
  display: inline-flex !important;
}

.footer-menu li a,
.footer-nav ul li a {
  display: inline-block;
  padding: 8px 16px;
  background: var(--shov-accent, #C6005D);
  color: #fff;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 500;
  transition: all 0.3s ease;
}

.footer-menu li a:hover,
.footer-nav ul li a:hover {
  background: #000;
  color: #fff;
  transform: translateY(-2px);
}

.site-footer div {
  font-size: 14px;
  color: #777;
}

/* Pagination Buttons */
.pagination-wrap {
  text-align: center;
  margin: 40px 0;
}

.pagination-nav a {
  display: inline-block;
  background: var(--shov-accent, #C6005D);
  color: #ffffff;
  padding: 12px 28px;
  border-radius: 6px;
  text-decoration: none;
  margin: 0 6px;
  font-weight: 500;
  transition: all 0.3s ease;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
}

.pagination-nav a:hover {
  background: #000000;
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
}

.pagination-nav .prev-page a::before {
  content: "← ";
}

.pagination-nav .next-page a::after {
  content: " →";
}


/* === Unified Main + Footer Menu Styling (Final Plain Version) === */
.site-nav .menu, .footer-menu {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.site-nav .menu li, .footer-menu li {
  display: inline-block;
}

.site-nav .menu a, .footer-menu a {
  display: inline-block;
  padding: 10px 16px;
  color: #000;
  text-decoration: none;
  border-radius: 6px;
  transition: all 0.25s ease;
  font-weight: 500;
}

.site-nav .menu a:hover, .footer-menu a:hover {
  background: var(--shov-accent);
  color: #fff;
}

/* Footer background tint */
.site-footer {
  background: #f9f9f9;
  text-align: center;
  padding: 24px 0;
  color: #666;
  border-top: 1px solid #eee;
}

/* Mobile stacking */
@media (max-width: 768px) {
  .site-nav .menu, .footer-menu {
    flex-direction: column;
    gap: 10px;
  }
}


.page-heading {
  text-align: center;
  margin-top: 20px;
}

.page-content {
  font-size: 16px;
  line-height: 1.7;
  color: var(--shov-text);
}

.page-content a {
  color: var(--shov-accent);
  text-decoration: underline;
}

.page-content a:hover {
  color: #000;
}

/* Tag buttons under single posts */
.tag-buttons {
  margin: 10px 0 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.tag-btn {
  background-color: var(--shov-accent);
  color: #fff;
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 14px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.tag-btn:hover {
  background-color: #000;
  color: #fff;
}

/* --- More Songs From section --- */
.more-songs {
  margin-top: 40px;
}

.more-songs-header {
  text-align: center !important;
  margin-bottom: 20px;
}

.more-songs-header h3 {
  font-size: 20px;
  margin-bottom: 10px;
  color: var(--shov-text);
  font-weight: 600;
  text-align: center !important;
}

.tag-buttons {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.tag-btn {
  background-color: var(--shov-accent);
  color: #fff;
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 14px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.tag-btn:hover {
  background-color: #000;
  color: #fff;
}

/* ---- Search bar styling (SHOV custom) ---- */
:root {
  --accent-color: #C6005D;
}

.shov-search-box {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px 0;
}

.search-form {
  display: flex;
  align-items: center;
  border: 1px solid #ddd;
  border-radius: 30px;
  overflow: hidden;
  background: #fff;
  max-width: 400px;
  width: 100%;
  box-shadow: 0 1px 4px rgba(0,0,0,0.08);
}

.search-field {
  flex: 1;
  border: none;
  padding: 10px 15px;
  font-size: 15px;
  outline: none;
  background: transparent;
  color: #333;
}

.search-field::placeholder {
  color: #888;
}

.search-submit {
  background: var(--accent-color);
  color: #fff;
  border: none;
  padding: 10px 20px;
  font-size: 15px;
  cursor: pointer;
  border-radius: 0 30px 30px 0;
  transition: background 0.3s ease, transform 0.1s ease;
}

.search-submit:hover {
  background: #a0004a; /* darker shade for hover */
  transform: scale(1.05);
}
