/* --- Navegació amb submenús --- */
.nav-menu {
  display: flex;
  gap: 1.5rem;
}

.nav-menu .menu-item {
  position: relative;
}

.nav-menu .submenu {
  display: none;
  position: absolute;
  top: 100%;   /* just sota l’enllaç pare */
  left: 0;
  background: var(--bg);
  border: 1px solid var(--border);
  padding: 0.5rem 0;
  min-width: 200px;
  z-index: 1000;
}

.nav-menu .submenu li {
  list-style: none;
}

.nav-menu .submenu li a {
  display: block;
  padding: 0.5rem 1rem;
  color: var(--text);
  text-decoration: none;
}

.nav-menu .submenu li a:hover {
  background: var(--header-bg);
}

.nav-menu .menu-item:hover > .submenu {
  display: block;
}

/* —— Layouts genèrics —— */
.tq-container{ max-width:1100px; margin:0 auto; padding:24px 16px; }
.tq-section-header{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px; }
.tq-chips{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:8px; }

/* —— Grid de targetes —— */
.tq-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(180px, 1fr)); gap:20px; }
.tq-card{ text-decoration:none; color:inherit; }
.tq-thumb{ aspect-ratio:1/1; background: var(--bg); border:1px solid rgba(0,0,0,.06); overflow:hidden; }
.tq-thumb > img{ width:100%; height:100%; object-fit:cover; display:block; }
.tq-title{ font-weight:600; font-size:14px; line-height:1.3; margin-top:8px; }
.tq-muted{ font-size:12px; opacity:.7; }

/* —— Xips —— */
.chip{ padding:6px 10px; border-radius:999px; border: 1px solid var(--border); text-decoration:none; color:var(--text); }
.chip--active{ background:var(--brand); color: var(--on-brand); border-color:var(--brand) !important; }
.chip--filter{ background: var(--footer-bg); }

/* —— Paginació —— */
.tq-pager{ display:flex; justify-content:center; gap:12px; margin-top:20px; }
.tq-pager .pager-btn{ padding:8px 12px; border: 1px solid var(--border); border-radius:8px; text-decoration:none; color:var(--text); }
.tq-pager .pager-info{ align-self:center; opacity:.7; }

/* —— Utilitats de layout —— */
.tq-container{ max-width:1100px; margin:0 auto; padding:24px 16px; }
.tq-container--sm{ max-width:900px; }
.tq-container--md{ max-width:1000px; }
.tq-section-header{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px; }
.tq-flex-row{ display:flex; gap:20px; align-items:flex-start; }
.tq-flex-between{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.tq-flex-chips{ display:flex; gap:8px; flex-wrap:wrap; }

/* —— Tipografia utilitària —— */
.tq-h1{ margin:0; font-size:28px; }
.tq-h2{ margin:0; font-size:22px; }
.tq-title{ font-weight:600; font-size:14px; line-height:1.3; }
.tq-muted{ font-size:12px; opacity:.7; }
.tq-muted-strong{ opacity:.8; }
.tq-link-plain{ text-decoration:none; color:inherit; }

/* —— Targetes i grid —— */
.tq-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(180px, 1fr)); gap:20px; }
.tq-grid-sm{ display:grid; grid-template-columns:repeat(auto-fill, minmax(160px, 1fr)); gap:16px; }
.tq-card{ text-decoration:none; color:inherit; }
.tq-thumb{ aspect-ratio:1/1; background: var(--bg); border:1px solid rgba(0,0,0,.06); overflow:hidden; }
.tq-thumb > img{ width:100%; height:100%; object-fit:cover; display:block; }
.tq-mt-0{ margin-top:0; }
.tq-mt-6{ margin-top:6px; }
.tq-mt-8{ margin-top:8px; }
.tq-mt-12{ margin-top:12px; }
.tq-mt-24{ margin-top:24px; }

/* —— Inputs —— */
.tq-input{ border: 1px solid var(--border); padding:6px 8px; max-width:240px; }

/* —— Xips —— */
.chip{ padding:6px 10px; border-radius:999px; border: 1px solid var(--border); text-decoration:none; color:var(--text); }
.chip--active{ background:var(--brand); color: var(--on-brand); border-color:var(--brand) !important; }
.chip--filter{ background: var(--footer-bg); }

/* —— Paginació —— */
.tq-pager{ display:flex; justify-content:center; gap:12px; margin-top:20px; }
.pager-btn{ padding:8px 12px; border: 1px solid var(--border); border-radius:8px; text-decoration:none; color:var(--text); }
.pager-info{ align-self:center; opacity:.7; }

/* —— Helpers de scroll horitzontal (per al carrusel) —— */
.tq-scroll-x{ overflow-x:auto; overflow-y:hidden; scrollbar-width:none; -ms-overflow-style:none; }
.tq-track-row{ display:flex; gap:24px; padding:4px 0; scroll-behavior:smooth; }
.tq-item-min{ min-width:200px; max-width:240px; }
.tq-center{ display:flex; align-items:center; justify-content:center; }
.tq-error{ color: var(--danger); }

.tq-site-name{ font-weight:800; font-size:18px; }

/* Utils extra per a detalls */
.tq-mt-4{ margin-top:4px; }
.tq-mb-6{ margin-bottom:6px; }
.tq-pl-20{ padding-left:20px; }

/* —— Utilitats extra (neteja inline styles) —— */
.tq-mb-8{ margin-bottom:8px; }
.tq-mb-16{ margin-bottom:16px; } /* 1rem per defecte */
.tq-mt-0{ margin-top:0; }        /* per coherència, ja usada */
.tq-size-220{ width:220px; height:220px; }
.tq-w-100{ width:100%; }
.tq-opacity-50{ opacity:.5; }
.tq-opacity-60{ opacity:.6; }
.tq-fw-600{ font-weight:600; }
.tq-flex-center-10{ display:flex; align-items:center; gap:10px; }
.tq-fs-18{ font-size:18px; line-height:1; }

/* ——— Header / Footer governats per SiteBranding ——— */
.site-header{
  background: var(--header-bg);
  color: var(--header-text);
  min-height: var(--header-h);
}
.site-header a{ color: var(--header-text); }

.site-footer{
  background: var(--footer-bg);
  color: var(--footer-text);
}
.site-footer a{ color: var(--footer-text); }

/* ===== Layout global (migrat des de base.html) — tot estàtic i centralitzat ===== */

/* Reset bàsic i layout coherent */
html, body { margin:0; padding:0; }
*, *::before, *::after { box-sizing: border-box; }

/* Contenidor */
.container{
  max-width: var(--container-max, 1180px);
  margin: 0 auto;
  padding: 0 16px;
}

/* Header */
header.site-header{
  position: relative;
  width: 100%;
  border-bottom: 1px solid rgba(0,0,0,.08);
}
.site-nav{
  display:flex; align-items:center; justify-content:space-between;
  height: var(--header-h, 96px);
}
.site-logo{
  height: clamp(56px, calc(var(--header-h, 96px) * 0.75), 112px);
  width: auto;
}
.nav-left{ display:flex; align-items:center; gap:16px; }
.nav-right{ display:flex; align-items:center; gap:16px; }
.nav-menu{ display:flex; gap:16px; }
.nav-menu a{ text-decoration:none; font-weight:600; }

/* Lupa + panell de cerca */
.search-toggle{
  background: none; border:0; cursor:pointer; font-size:18px; line-height:1;
}
.search-panel{
  position:absolute; left:0; right:0; top:100%;
  background: var(--header-bg); border-bottom:1px solid rgba(0,0,0,.08);
  display:none;
}
.search-panel.open{ display:block; }
.search-panel .container{ display:flex; gap:8px; padding:12px 16px; }
.search-panel input[type="search"]{
  flex:1; padding:10px 12px; font-size:16px; border: 1px solid var(--border);
}
.search-panel button[type="submit"]{
  padding:10px 16px; font-weight:600; border: 1px solid var(--border);
  background: var(--footer-bg); cursor:pointer;
}

/* Hero */
.hero{
  padding: 48px 0 32px;
  border-bottom: 1px solid rgba(0,0,0,.08);
}
.hero h1{ margin:0 0 8px; font-size: 40px; line-height:1.15; }
.hero p{ margin:0; font-size:18px; opacity:.8; }

/* Seccions tipus “cards” */
.section{ padding: 32px 0; }
.section-header{
  display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:16px;
}
.section-header h2{ margin:0; font-size: 22px; }

/* Grid de targetes senzill (no tq-*, sinó classes genèriques) */
.grid{
  display:grid; gap: var(--gap, 24px);
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
@media (max-width: 1200px){ .grid{ grid-template-columns: repeat(5, 1fr); } }
@media (max-width: 992px){ .grid{ grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 768px){ .grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 540px){ .grid{ grid-template-columns: repeat(2, 1fr); } }

.card{
  display:block; text-decoration:none; color:inherit;
}
.card .thumb{
  aspect-ratio: 1 / 1; width:100%; overflow:hidden; background: var(--bg);
  display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(0,0,0,.06);
}
.card .thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.card .meta{ margin-top:8px; }
.card .title{ font-weight:600; font-size:14px; line-height:1.3; }
.card .muted{ font-size:12px; opacity:.7; }

/* Footer */
footer.site-footer{
  margin-top: 40px;
  padding: 24px 0;
  border-top: 1px solid rgba(0,0,0,.08);
}
