/* =============================================================================
   style.css — Thème repris de makerspace-doc (bulma-clean-theme + palette zinc)
   Surcharges appliquées par-dessus Bulma 1.0.2
   ========================================================================== */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&display=swap");

:root {
  /* Design tokens (palette zinc — shadcn/ui) */
  --bg:           #ffffff;
  --bg-subtle:    #f4f4f5;
  --card-bg:      #ffffff;
  --fg:           #09090b;
  --fg-muted:     #71717a;
  --fg-strong:    #27272a;
  --border:       #d4d4d8;
  --border-hover: #a1a1aa;
  --navbar-bg:    #ffffff;
  --primary:      #ef2e31;

  /* Variables Bulma */
  --bulma-family-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --bulma-family-secondary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --bulma-family-code: "JetBrains Mono", "Fira Code", monospace;

  --bulma-primary-h: 359.1deg;
  --bulma-primary-s: 85.8%;
  --bulma-primary-l: 55.9%;
  --bulma-primary-invert-l: 100%;
  --bulma-link-h: 359.1deg;
  --bulma-link-s: 85.8%;
  --bulma-link-l: 55.9%;
  --bulma-link-invert-l: 100%;

  --bulma-radius-small: 4px;
  --bulma-radius: 6px;
  --bulma-radius-large: 8px;

  --bulma-navbar-height: 3.5rem;
}

/* Titres/sous-titres alignés sur makerspace-doc.
   Bulma 1.0.2 définit --bulma-title-weight (extrabold = 800) directement sur
   le sélecteur .title : il faut donc le redéfinir au même niveau, pas sur :root. */
.title,
.subtitle {
  --bulma-title-weight: 600;
  --bulma-title-line-height: 1.125;
  --bulma-subtitle-weight: 400;
  --bulma-subtitle-line-height: 1.25;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Padding pour navbar fixée en haut */
html.has-navbar-fixed-top {
  padding-top: 3.5rem;
}

/* =============================================================================
   Navbar — blanche à la place du rouge plein Bulma is-primary
   ========================================================================== */
.navbar.is-primary {
  background-color: var(--navbar-bg) !important;
  border-bottom: 1px solid var(--border);
  box-shadow: none;
  min-height: 3.5rem;
}

.navbar.is-primary .navbar-brand > .navbar-item,
.navbar.is-primary .navbar-brand > a.navbar-item {
  color: var(--fg) !important;
  font-weight: 600;
}

.navbar.is-primary .navbar-brand > a.navbar-item:hover,
.navbar.is-primary .navbar-brand > a.navbar-item:focus {
  background-color: transparent !important;
  color: var(--fg) !important;
}

.navbar.is-primary .navbar-burger {
  color: var(--fg-muted) !important;
}

.navbar.is-primary .navbar-burger span {
  background-color: var(--fg-muted) !important;
}

.navbar.is-primary .navbar-burger:hover {
  background-color: var(--bg-subtle) !important;
}

.navbar.is-primary .navbar-burger.is-active span {
  background-color: var(--fg) !important;
}

.navbar.is-primary .navbar-start > .navbar-item,
.navbar.is-primary .navbar-end > .navbar-item {
  color: var(--fg-strong) !important;
  font-size: 0.875rem;
  font-weight: 500;
}

.navbar.is-primary .navbar-start > .navbar-item:hover,
.navbar.is-primary .navbar-start > .navbar-item:focus,
.navbar.is-primary .navbar-end > .navbar-item:hover,
.navbar.is-primary .navbar-end > .navbar-item:focus {
  background-color: var(--bg-subtle) !important;
  color: var(--fg) !important;
}

.navbar.is-primary .navbar-start > .navbar-item.is-active,
.navbar.is-primary .navbar-end > .navbar-item.is-active {
  background-color: transparent !important;
  color: var(--primary) !important;
  font-weight: 600;
}

/* Menu mobile */
@media screen and (max-width: 1023px) {
  .navbar.is-primary .navbar-menu {
    background-color: var(--navbar-bg) !important;
    border-top: 1px solid var(--border);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.12);
    padding: 0.5rem;
  }

  .navbar.is-primary .navbar-menu .navbar-item {
    border-radius: var(--bulma-radius);
    background-color: var(--navbar-bg) !important;
    color: var(--fg-strong) !important;
  }

  .navbar.is-primary .navbar-menu .navbar-item.is-active {
    background-color: transparent !important;
    color: var(--primary) !important;
  }
}

/* =============================================================================
   Hero — fond gris clair au lieu du rouge plein
   ========================================================================== */
.hero.is-primary {
  background-color: var(--bg-subtle);
  background-image: none;
  color: var(--fg);
}

/* Supprime le dégradé coloré que Bulma applique via .hero.is-bold
   (sinon il recouvre le fond gris du hero) */
.hero.is-bold:not(.has-bg-image) {
  background-image: none !important;
}

.hero.is-primary .hero-body {
  padding: 4rem 1.5rem;
}

.hero.is-primary .title {
  color: var(--fg);
}

.hero.is-primary .subtitle {
  color: var(--fg-muted);
}

/* =============================================================================
   Contenu (.content) — typographie prose reprise de makerspace-doc
   ========================================================================== */
.content h1, .content h2, .content h3,
.content h4, .content h5, .content h6 {
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.3;
  color: var(--fg);
}

.content h2 {
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.5rem;
}

.content a {
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.content a:hover {
  opacity: 0.8;
}

.content code:not([class]) {
  background-color: var(--bg-subtle);
  color: #be185d;
  border: 1px solid var(--border);
  border-radius: var(--bulma-radius-small);
  padding: 0.125rem 0.375rem;
  font-size: 0.875em;
  font-family: var(--bulma-family-code);
}

/* =============================================================================
   Cards projets
   ========================================================================== */
.project-card[hidden] {
  display: none !important;
}

.project-card .card {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  --bulma-card-radius: var(--bulma-radius-large);
  --bulma-card-shadow: 0 0 0 1px var(--border), 0 2px 6px rgba(0, 0, 0, 0.06);
}

.project-card .card-content {
  flex-grow: 1;
}

/* Fond légèrement gris derrière les vignettes pour faire ressortir les captures à fond blanc */
.project-card .card-image {
  background-color: var(--bg-subtle);
}

/* Recadre les vignettes au lieu de les étirer dans le cadre 16:9
   (sinon les photos non-16:9, ex. robots, apparaissent écrasées) */
.project-card .card-image img {
  object-fit: cover;
}

.project-card .card-footer-item {
  color: var(--fg-strong);
  font-size: 0.875rem;
  font-weight: 500;
}

.project-card .card-footer-item:hover {
  background-color: var(--bg-subtle);
  color: var(--primary);
}

.project-card .tag,
#result-count {
  --bulma-tag-radius: 9999px;
}

/* Capsules année + type regroupées, couleur distincte par tag */
.card-tags {
  gap: 0.4rem;
}

.card-tags .tag {
  font-weight: 600;
  color: #fff;
}

/* Année : une couleur par année (tons foncés, distincts des topics) */
.card-tags .tag-year {
  background-color: var(--fg-strong);
}
.card-tags .tag-year[data-year="2022-23"] { background-color: #be123c; }
.card-tags .tag-year[data-year="2023-24"] { background-color: #c2410c; }
.card-tags .tag-year[data-year="2024-25"] { background-color: #047857; }
.card-tags .tag-year[data-year="2025-26"] { background-color: #1d4ed8; }

/* Type de projet : une couleur par topic */
.card-tags .tag-topic[data-topic="projet-i3"]        { background-color: #8b5cf6; }
.card-tags .tag-topic[data-topic="projet-itec"]       { background-color: #14b8a6; }
.card-tags .tag-topic[data-topic="otto"]              { background-color: #f59e0b; }
.card-tags .tag-topic[data-topic="machine-that-draws"]{ background-color: #3b82f6; }
.card-tags .tag-topic[data-topic="puzzle-bot"]        { background-color: #22c55e; }
.card-tags .tag-topic[data-topic="robotique"]         { background-color: #ec4899; }
.card-tags .tag-topic[data-topic="dessin"]            { background-color: #6366f1; }
.card-tags .tag-topic[data-topic="medieval-challenge"]{ background-color: #92400e; }
.card-tags .tag-topic[data-topic="coupe-de-robotique"]{ background-color: #0891b2; }

/* Couleur de repli pour tout topic non prévu */
.card-tags .tag-topic {
  background-color: var(--fg-muted);
}

/* =============================================================================
   Footer — fond gris clair, liens centrés
   ========================================================================== */
footer.footer {
  background-color: var(--bg-subtle);
  border-top: 1px solid var(--border);
  padding: 2.5rem 1.5rem;
}

footer.footer,
footer.footer p {
  color: var(--fg-muted);
}

footer.footer .link {
  color: var(--fg-strong);
  font-weight: 500;
  text-decoration: none;
}

footer.footer .link:hover {
  color: var(--primary);
}

/* =============================================================================
   Modes d'affichage : grille (défaut) / liste / liste + image
   ========================================================================== */
#card-grid.view-list .project-card,
#card-grid.view-list-image .project-card {
  width: 100%;
}

#card-grid.view-list .card,
#card-grid.view-list-image .card {
  flex-direction: row;
  align-items: stretch;
}

#card-grid.view-list .card-image {
  display: none;
}

#card-grid.view-list-image .card-image {
  width: 140px;
  flex-shrink: 0;
}

#card-grid.view-list-image .card-image .image {
  height: 100%;
}

#card-grid.view-list-image .card-image img {
  position: absolute;
  inset: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
}

#card-grid.view-list .card-content,
#card-grid.view-list-image .card-content {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  padding: 0.75rem 1rem;
}

#card-grid.view-list .card-content .content,
#card-grid.view-list-image .card-content .content {
  display: none;
}

#card-grid.view-list .card-content .title,
#card-grid.view-list-image .card-content .title,
#card-grid.view-list .card-content .subtitle,
#card-grid.view-list-image .card-content .subtitle {
  margin-bottom: 0;
}

#card-grid.view-list .card-footer,
#card-grid.view-list-image .card-footer {
  flex-shrink: 0;
  border-top: none;
  border-left: 1px solid var(--border);
  border-radius: 0;
}

/* =============================================================================
   Bouton « remonter en haut »
   ========================================================================== */
#back-to-top {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 2.75rem;
  height: 2.75rem;
  border: none;
  border-radius: 50%;
  background-color: var(--primary);
  color: #fff;
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 0.20em 0.75em rgba(0, 0, 0, 0.356);
  z-index: 30;
}

#back-to-top:hover {
  background-color: #cc1f22;
}

#back-to-top[hidden] {
  display: none !important;
}
