/*
 * Custom styles for the SMOL block theme.
 *
 * Complements block styles defined in templates/patterns.
 */

/* =========================================================
   1) Global / Malli.html feel (tausta + fontti)
   ========================================================= */
body{
  background: var(--wp--preset--color--accent);
  font-family: var(--wp--preset--font-family--montserrat), Arial, sans-serif;
}
.wp-site-blocks{
  background: transparent;
}

/* =========================================================
   2) Header / Navbar (sticky + “bootstrap” tiiviys + hamburger)
   ========================================================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 9999;
  overflow-x: clip;

  padding: 10px 0;
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
}

/* Sisäcontainer samaan leveyteen kuin kortit */
.smol-container{
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
}

/* Brand spacing */
.site-header .smol-brand .wp-block-site-logo,
.site-header .wp-block-site-logo{
  margin-right: 12px;
}

/* Desktop nav spacing */
.site-header .wp-block-navigation__container{
  gap: 18px;
}

/* Nav linkit: valkoinen → hover accent */
.site-header .wp-block-navigation a{
  color: #fff;
  text-decoration: none;
  padding: 6px 0;
}
.site-header .wp-block-navigation a:hover{
  color: #111111;
  text-decoration: none;
}

/* Hampurilainen-ikonit valkoiseksi */
.site-header .wp-block-navigation__responsive-container-open svg,
.site-header .wp-block-navigation__responsive-container-close svg{
  fill: #fff;
}

/* Mobiilimenu: tummansininen tausta kuten navbar */
.site-header .wp-block-navigation__responsive-container{
  background: var(--wp--preset--color--primary);
  color: #fff;
}
.site-header .wp-block-navigation__responsive-container .wp-block-navigation__container{
  gap: 12px;
}
.site-header .wp-block-navigation__responsive-container a{
  padding: 10px 0;
}

/* “navbar-expand-lg” breakpoint (<= 992px: hamburger) */
@media (max-width: 992px){
  .site-header .wp-block-navigation__responsive-container-open{ display:block; }
  .site-header .wp-block-navigation__container{ display:none; }
}
@media (min-width: 993px){
  .site-header .wp-block-navigation__responsive-container-open{ display:none; }
  .site-header .wp-block-navigation__container{ display:flex; }
}

/* =========================================================
   3) Home Hero (vain etusivu)
   ========================================================= */

/* Ei rakoa headerin jälkeen: vain home-hero */
.home .wp-site-blocks > header + .wp-block-cover.home-hero{
  margin-top: 0 !important;
}

/* Hero-koko/padding vain etusivulla */
.home .wp-block-cover.home-hero{
  min-height: auto !important;
  padding: 100px 20px !important;
}

/* Hero taustakuva CSS:llä */
.home-hero{
  position: relative;
  background-image: url("../images/herokuva.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* CTA nappi herossa */
.smol-cta .wp-block-button__link{
  border-radius: 999px;
  font-weight: 600;
  padding: 0.75rem 1.5rem;
}

/* =========================================================
   4) Layout / spacing helpers
   ========================================================= */
.wp-block-columns{ align-items: stretch; }

/* Ilmaa heron jälkeen: vain etusivun heron perään */
.home .wp-block-cover.home-hero + .wp-block-group{
  margin-top: clamp(60px, 8vw, 100px);
}

.wp-block-group.alignwide{
  padding-left: var(--wp--preset--spacing--40);
  padding-right: var(--wp--preset--spacing--40);
}

/* =========================================================
   5) Cards grid layout (3 per rivi, ei “veny” 2 kortilla)
   ========================================================= */
.smol-card-columns{
  display: flex;
  flex-wrap: wrap;
  gap: var(--wp--preset--spacing--40);

  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;

  justify-content: flex-start; /* ei center */
}

.smol-card-columns > .wp-block-column{
  flex: 0 0 calc((100% - (2 * var(--wp--preset--spacing--40))) / 3);
  max-width: calc((100% - (2 * var(--wp--preset--spacing--40))) / 3);
  box-sizing: border-box;
}

@media (max-width: 782px){
  .smol-card-columns > .wp-block-column{
    flex: 0 0 100%;
    max-width: 100%;
    margin-left: 0;
    margin-bottom: var(--wp--preset--spacing--40);
  }
}

/* =========================================================
   6) Card component (look + clickable + footer)
   ========================================================= */
.wp-block-group.card{
  background-color: var(--wp--preset--color--white);
  border-radius: 0.5rem;
  padding: var(--wp--preset--spacing--40);
  position: relative;

  display: flex;
  flex-direction: column;
  height: 100%;

  margin-bottom: var(--wp--preset--spacing--40);

  box-shadow: 0 4px 10px rgba(0,0,0,.1);
  transition: transform .3s ease, box-shadow .3s ease;
}

.wp-block-group.card:hover{
  transform: scale(1.05);
  box-shadow: 0 8px 16px rgba(0,0,0,.2);
}

.wp-block-group.card,
.wp-block-group.card h3,
.wp-block-group.card p{
  color: var(--wp--preset--color--foreground);
}

.wp-block-group.card h3 a{
  color: inherit;
  text-decoration: none;
}

/* Whole-card clickable overlay (otsikkolinkin pseudo-elementti) */
.wp-block-group.card h3 a::after{
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
}

/* Linkit kortin sisällä “päällä” overlaysta */
.wp-block-group.card a{
  color: var(--wp--preset--color--primary);
  text-decoration: none;
  font-weight: 600;
  position: relative;
  z-index: 2;
}
.wp-block-group.card a:hover{
  color: var(--wp--preset--color--accent);
  text-decoration: underline;
}

/* ===== Card footer ===== */
.wp-block-group.card .card__sep{
  margin: 14px 0 10px;
  opacity: .25;
}

.wp-block-group.card .card__footer{
  margin-top: auto;
  padding: 12px 14px;
  background: #f3f4f6;
  border-top: 1px solid #e0e0e0;
  border-bottom-left-radius: 0.5rem;
  border-bottom-right-radius: 0.5rem;
  text-align: right;
}

.wp-block-group.card .read-more{
  color: var(--wp--preset--color--primary);
  font-weight: 700;
  text-decoration: none;
}
.wp-block-group.card .read-more:hover{
  text-decoration: underline;
}

/* =========================================================
   7) Footer helper (jos inline-stylet poistettiin)
   ========================================================= */
.site-footer{
  padding-top: var(--wp--preset--spacing--40);
  padding-bottom: var(--wp--preset--spacing--40);
}

/* =========================================================
   ARTICLE HERO — VAIN single.html
   Ei koske front-page heroa
   ========================================================= */

.wp-block-cover.smol-article-hero{
  position: relative;
  min-height: 60vh;
  margin-top: 0 !important; /* ei rakoa headerin alle */

  /* fallback jos featured image puuttuu */
  background-color: var(--wp--preset--color--primary);
}

/* Sisäinen padding otsikolle */
.wp-block-cover.smol-article-hero .wp-block-cover__inner-container{
  padding: clamp(2rem, 6vw, 6rem) 1rem;
}

/* Otsikon leveys & rytmi */
.wp-block-cover.smol-article-hero h1{
  max-width: 22ch;
  margin-inline: auto;
  line-height: 1.1;
}
