
body {
  background: #f5f7fb;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}
.navbar-brand { letter-spacing: .5px; }
.card-img-top { object-fit: cover; height: 200px; }
.ad-slot .ad-placeholder {
  width: 100%; min-height: 120px;
  display:flex; align-items:center; justify-content:center;
  background: repeating-linear-gradient(45deg, #f0f0f0, #f0f0f0 10px, #e4e4e4 10px, #e4e4e4 20px);
  color: #666; border: 1px dashed #bbb; border-radius: .5rem;
}
.badge-osasto { text-transform: uppercase; font-weight: 600; }
.article-hero { max-height: 420px; object-fit: cover; }
.article-content p { line-height: 1.62; font-size: 1.03rem; }
.read-end-sentinel { height: 1px; }

.section-theme-elokuva {
  --section-bg: #FFE5D9;
  --section-bg-soft: #fff4ef;
  --section-accent: #d96f45;
  --section-text: #5b2412;
}
.section-theme-suoratoisto {
  --section-bg: #DCEBFF;
  --section-bg-soft: #f1f7ff;
  --section-accent: #3d73c4;
  --section-text: #173762;
}
.section-theme-dvd {
  --section-bg: #F5E6C8;
  --section-bg-soft: #fff8ea;
  --section-accent: #9c7432;
  --section-text: #4d3611;
}
.section-theme-tv {
  --section-bg: #E8E0FF;
  --section-bg-soft: #f6f2ff;
  --section-accent: #7256c9;
  --section-text: #2f2463;
}
.section-theme-uutuudet {
  --section-bg: #DFF7EA;
  --section-bg-soft: #f1fff7;
  --section-accent: #3d9662;
  --section-text: #173f29;
}
.section-theme-default {
  --section-bg: #eef2f7;
  --section-bg-soft: #ffffff;
  --section-accent: #64748b;
  --section-text: #111827;
}
.section-badge {
  background: var(--section-bg, #eef2f7) !important;
  color: var(--section-text, #111827) !important;
  border: 1px solid color-mix(in srgb, var(--section-accent, #64748b) 36%, transparent);
}
.nav-chip.section-theme-elokuva,
.nav-chip.section-theme-suoratoisto,
.nav-chip.section-theme-dvd,
.nav-chip.section-theme-tv,
.nav-chip.section-theme-uutuudet,
.nav-chip.section-theme-default {
  --chip-bg: var(--section-bg);
  --chip-bg-hover: color-mix(in srgb, var(--section-bg) 78%, var(--section-accent));
  --chip-fg: var(--section-text);
  --chip-border: color-mix(in srgb, var(--section-accent) 42%, transparent);
}
.nav-chip.section-theme-elokuva.active,
.nav-chip.section-theme-suoratoisto.active,
.nav-chip.section-theme-dvd.active,
.nav-chip.section-theme-tv.active,
.nav-chip.section-theme-uutuudet.active,
.nav-chip.section-theme-default.active {
  background: var(--section-accent);
  border-color: var(--section-accent);
  color: #fff;
}
.nav-chip .bi {
  margin-right: .35rem;
  font-size: .95em;
  vertical-align: -0.08em;
}
.heading-icon {
  color: var(--section-accent, #64748b);
  margin-right: .35rem;
  vertical-align: -0.08em;
}

/* --- Sivurakenne: footer näkyvän alueen alareunaan --- */
html {
  height: 100%;
}
main.container {
  flex: 1 1 auto;
  width: 100%;
}

/* --- Lehtimäinen paperi / osasto --- */
.page-paper {
  background: linear-gradient(180deg, var(--section-bg-soft, #fffdf8) 0%, #fff 34%, var(--section-bg, #fafafa) 100%);
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 0.35rem;
  padding: 1.25rem 1.25rem 1.5rem;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.75) inset, 0 12px 40px rgba(15, 23, 42, 0.06);
}
.page-paper .section-head h1 {
  color: var(--section-text, #0f172a);
}
.section-card.card,
.article-card .card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.84)),
    var(--section-bg-soft, #fff);
  border: 1px solid color-mix(in srgb, var(--section-accent, #64748b) 22%, #ffffff) !important;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.07);
  transform: translateY(0);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  will-change: transform;
}
.section-card.card::before,
.article-card .card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: var(--section-accent, #64748b);
  opacity: 0.72;
  z-index: 3;
  pointer-events: none;
}
.section-card .card-body,
.article-card .card-body {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.64)),
    var(--section-bg-soft, #fff);
}
.section-card.card:hover,
.article-card .card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--section-accent, #64748b) 46%, #ffffff) !important;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.12);
}
.section-card.card:active,
.article-card .card:active {
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.10);
}
.section-card.card:hover .section-card__title,
.article-card .card:hover h2 a {
  color: var(--section-text, #111827);
  text-decoration-color: var(--section-accent, #64748b);
}
.article-card .card:hover img {
  transform: scale(1.025);
}
.article-card img {
  transition: transform .35s ease;
}
@media (prefers-reduced-motion: reduce) {
  .section-card.card,
  .article-card .card,
  .section-card__img,
  .article-card img {
    transition: none;
  }
  .section-card.card:hover,
  .article-card .card:hover,
  .section-card.card:active,
  .article-card .card:active {
    transform: none;
  }
}
.section-card__date,
.article-card .text-muted.small {
  color: color-mix(in srgb, var(--section-text, #111827) 70%, #64748b) !important;
}
.section-head h1 {
  letter-spacing: -0.02em;
}
.section-head .display-6 {
  font-size: clamp(1.65rem, 1.1rem + 1.2vw, 2.15rem);
}
.article-card h2 {
  font-size: clamp(1.12rem, .96rem + .35vw, 1.35rem);
  line-height: 1.18;
}
.section-card__media {
  background: #e5e7eb;
}
.section-card__img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transform: scale(1.001);
  transition: transform 0.35s ease;
}
.section-card:hover .section-card__img {
  transform: scale(1.04);
}
.section-card__placeholder {
  background: linear-gradient(120deg, #f1f5f9, #e2e8f0 45%, #f8fafc);
}
.section-card__title {
  letter-spacing: 0;
  line-height: 1.18;
}
.section-card__date {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.section-card__hint {
  opacity: 0.85;
}
.section-card__link {
  position: absolute;
  inset: 0;
  z-index: 2;
}
.section-card .card-body {
  position: relative;
  z-index: 1;
}

/* --- Navbar: desktop rail + mobile offcanvas --- */
.site-navbar {
  padding-top: .55rem;
  padding-bottom: .55rem;
}

.site-navbar .navbar-brand {
  font-size: clamp(1.05rem, 3.8vw, 1.5em);
  max-width: calc(100% - 3rem);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#navSearchForm {
  transition: opacity .15s ease;
}

.nav-menu-btn {
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.06);
  width: 2.15rem;
  height: 2.15rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: .55rem;
  line-height: 1;
}

.nav-menu-btn .bi {
  font-size: 1.2rem;
}

.nav-menu-btn:hover,
.nav-menu-btn:focus {
  color: #fff;
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.42);
}

.nav-offcanvas {
  width: min(88vw, 340px);
  border-left: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: -12px 0 40px rgba(15, 23, 42, 0.14);
}

.nav-offcanvas .offcanvas-header {
  padding: 1rem 1rem .85rem;
  background: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
  color: #fff;
}

.nav-offcanvas .offcanvas-header .btn-close {
  filter: invert(1) grayscale(1);
  opacity: .8;
}

.nav-offcanvas-brand {
  font-size: 1.15rem;
  line-height: 1.1;
  color: #fff;
}

.nav-offcanvas .offcanvas-body {
  padding: 1rem;
  background: linear-gradient(180deg, #f8fafc 0%, #fff 28%);
}

.nav-offcanvas-search .input-group-text,
.nav-offcanvas-search .form-control {
  border-color: #dbe3ee;
}

.nav-offcanvas-search .form-control:focus {
  box-shadow: none;
  border-color: #94a3b8;
}

.nav-offcanvas-links {
  margin: 0;
}

.nav-offcanvas-link {
  display: flex;
  align-items: center;
  gap: .7rem;
  padding: .72rem .85rem;
  border-radius: .75rem;
  text-decoration: none;
  font-weight: 600;
  color: var(--section-text, #0f172a);
  background: var(--section-bg-soft, #fff);
  border: 1px solid color-mix(in srgb, var(--section-accent, #64748b) 18%, #e5e7eb);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.75) inset;
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease;
}

.nav-offcanvas-link .bi {
  font-size: 1.05rem;
  color: var(--section-accent, #64748b);
}

.nav-offcanvas-link:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
  color: var(--section-text, #0f172a);
}

.nav-offcanvas-link.active {
  background: var(--section-accent, #0f172a);
  border-color: var(--section-accent, #0f172a);
  color: #fff;
}

.nav-offcanvas-link.active .bi {
  color: #fff;
}

@media (min-width: 992px) {
  .nav-rail {
    mask-image: linear-gradient(90deg, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%);
  }
}
