:root{
  --orange:#f36f21;
  --green:#1f8a5b;
  --green-dark:#136645;
  --bg:#ffffff;
  --text:#0f172a;
  --muted:#475569;
  --card:#ffffff;
  --border:rgba(15,23,42,.10);
  --shadow:0 10px 30px rgba(2,6,23,.08);
  --radius:16px;
  --max:1100px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:linear-gradient(180deg, rgba(243,111,33,.10), rgba(31,138,91,.05) 40%, rgba(255,255,255,1) 75%);
}
a{color:var(--green-dark); text-decoration:none}
a:hover{text-decoration:underline}

.container{max-width:var(--max); margin:0 auto; padding:0 20px}

/* Header */
.header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background:rgba(255,255,255,.80);
  border-bottom:1px solid var(--border);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:12px 0;
}
.brand{display:flex; align-items:center; gap:12px}
.brand img{height:40px; width:auto}
.brand .title{display:flex; flex-direction:column; line-height:1.1}
.brand .title strong{font-size:16px}
.brand .title span{font-size:12px; color:var(--muted)}

.nav-links{display:flex; flex-wrap:wrap; gap:14px; align-items:center}
.nav-links a{font-weight:600; font-size:14px; padding:8px 10px; border-radius:10px}
.nav-links a.active{background:rgba(31,138,91,.10)}

.lang{
  display:flex; align-items:center; gap:8px;
  border:1px solid var(--border); border-radius:999px;
  padding:4px;
}
.lang button{
  border:0; background:transparent; cursor:pointer;
  padding:8px 10px; border-radius:999px;
  font-weight:700; font-size:12px; color:var(--muted);
}
.lang button.active{background:rgba(243,111,33,.14); color:var(--text)}

.mobile-toggle{display:none}

/* Hero */
.hero{padding:44px 0 18px}
.hero-grid{display:grid; grid-template-columns: 1.3fr .7fr; gap:20px; align-items:stretch}
.hero-card{
  display:flex; flex-direction:column;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:calc(var(--radius) + 8px);
  box-shadow:var(--shadow);
  padding:22px;
}
.hero h1{margin:0 0 10px; font-size:34px; letter-spacing:-.02em}
.lead{margin:0; color:var(--muted); font-size:16px; line-height:1.6}
.hero-badges{display:flex; flex-wrap:wrap; gap:10px; margin-top:14px}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.7);
  padding:8px 10px;
  border-radius:999px;
  font-weight:700; font-size:12px; color:var(--muted)
}
.badge .dot{width:10px; height:10px; border-radius:999px; background:var(--green)}
.badge.orange .dot{background:var(--orange)}

.hero-side{
  display:flex; flex-direction:column; gap:14px;
}
.side-image{
  border-radius:calc(var(--radius) + 8px);
  border:1px solid var(--border);
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#fff;
}
.side-image img{display:block; width:100%; height:100%; object-fit:cover}
.side-cta{
  background:linear-gradient(135deg, rgba(31,138,91,.12), rgba(243,111,33,.10));
  border:1px solid var(--border);
  border-radius:calc(var(--radius) + 8px);
  padding:16px;
}
.side-cta p{margin:0 0 0.5cm; color:var(--muted); font-size:14px; line-height:1.5}

.btns{display:flex; flex-wrap:wrap; gap:10px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border-radius:999px; padding:10px 14px;
  font-weight:800; font-size:14px;
  border:1px solid var(--border);
  background:#fff;
  cursor:pointer;
}
.btn.primary{
  border-color:rgba(31,138,91,.25);
  background:linear-gradient(135deg, rgba(31,138,91,.22), rgba(31,138,91,.10));
}
.btn.orange{
  border-color:rgba(243,111,33,.25);
  background:linear-gradient(135deg, rgba(243,111,33,.20), rgba(243,111,33,.08));
}

/* Sections */
.section{padding:22px 0}
.section h2{margin:0 0 10px; font-size:22px}
.section p{margin:0; color:var(--muted); line-height:1.6}

.grid{display:grid; gap:14px; grid-template-columns: repeat(12, 1fr)}
.card{
  grid-column: span 6;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 10px 24px rgba(2,6,23,.05);
  padding:16px;
}
.card h3{margin:0 0 8px; font-size:16px}
.card small{color:var(--muted)}
.list{margin:10px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:10px}
.list a{font-weight:700}

.split{
  display:grid; grid-template-columns: 1fr 1fr; gap:16px;
}

.museum-grid{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:16px;
  align-items:start;
}

.museum-full{grid-column:1 / -1;}
.museum-left{display:flex; flex-direction:column; gap:16px}
.museum-right{display:flex; flex-direction:column}
@media (max-width: 900px){
  .museum-grid{grid-template-columns: 1fr}
}

.table{
  width:100%; border-collapse:separate; border-spacing:0;
  overflow:hidden; border-radius:14px;
  border:1px solid var(--border);
}
.table th, .table td{padding:12px 12px; text-align:left; font-size:14px}
.table th{background:rgba(15,23,42,.04); color:var(--muted); font-weight:800}
.table tr + tr td{border-top:1px solid var(--border)}

.notice{
  border:1px dashed rgba(243,111,33,.45);
  background:rgba(243,111,33,.06);
  border-radius:14px;
  padding:14px;
  color:var(--muted);
  font-size:14px;
  line-height:1.55;
}

.gallery{display:grid; grid-template-columns: repeat(12, 1fr); gap:12px}
.thumb{grid-column: span 4; border-radius:16px; overflow:hidden; border:1px solid var(--border); background:#fff; box-shadow:0 10px 24px rgba(2,6,23,.05)}
.thumb img{display:block; width:100%; height:210px; object-fit:contain; background:#fff}
.thumb .cap{padding:10px 12px; font-size:13px; color:var(--muted)}

.article{
  background:#fff;
  border:1px solid var(--border);
  border-radius:calc(var(--radius) + 8px);
  box-shadow:var(--shadow);
  padding:20px;
}
.article figure{margin:16px 0}
.article figure img{display:block; width:100%; height:auto; max-width:780px; margin:0; border-radius:14px}
.article .float-right{float:right; margin:0 0 12px 16px; max-width:200px}
.article::after{content:""; display:block; clear:both}

.article h1{margin:0 0 6px; font-size:26px}
.article .meta{color:var(--muted); font-size:13px; margin-bottom:14px}
.article img{max-width:100%; border-radius:16px; border:1px solid var(--border)}
.article figure{margin:16px 0}
.article figcaption{color:var(--muted); font-size:13px; margin-top:8px}
.article p{line-height:1.7; color:#0b1220}
.article blockquote{margin:14px 0; padding:10px 14px; border-left:4px solid rgba(31,138,91,.45); background:rgba(31,138,91,.06); border-radius:12px; color:var(--muted)}

.footer{padding:26px 0 40px; color:var(--muted); font-size:13px}
.footer .row{display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap}

/* Responsive */
@media (max-width: 900px){
  .hero-grid{grid-template-columns:1fr}
  .card{grid-column: span 12}
  .split{grid-template-columns:1fr}
  .thumb{grid-column: span 6}
  .nav-links{display:none}
  .mobile-toggle{display:inline-flex}
}
@media (max-width: 520px){
  .hero h1{font-size:28px}
  .thumb{grid-column: span 12}
}

/* Mobile menu */
.mobile-menu{display:none; padding:10px 0 14px}
.mobile-menu a{display:block; padding:10px 10px; border-radius:12px; font-weight:800}
.mobile-menu a.active{background:rgba(31,138,91,.10)}
.mobile-menu.show{display:block}


/* Hero fill */
.hero-fill{margin-top:auto; padding-top:16px; border-top:1px solid var(--border)}
.mini-grid{display:grid; grid-template-columns: 1.15fr 0.85fr; gap:14px}
.mini-block{background:rgba(2,6,23,.02); border:1px solid rgba(15,23,42,.08); border-radius:16px; padding:14px}
.mini-title{margin:0 0 6px; font-size:16px}
.mini-text{margin:0; color:var(--muted); font-size:14px; line-height:1.55}
.list.compact{margin:0; padding-left:16px}
.list.compact li{margin:0 0 6px}
@media (max-width: 920px){
  .mini-grid{grid-template-columns:1fr}
}


/* Bulleted list for homepage 'Mitä nyt julkaistaan?' */
.bullets{margin:0; padding-left:18px; display:grid; gap:8px;}
.bullets li{margin:0;}


/* =========================================================
   Brand tighten (orange-green-grey) — v20
   ========================================================= */
:root{
  --bg:#f5f6f7;
  --text:#0b1220;
  --muted:#334155;
  --border:rgba(15,23,42,.14);
  --shadow:0 8px 22px rgba(2,6,23,.10);
  --radius:14px;
}

/* overall surface */
body{
  background:
    linear-gradient(180deg,
      rgba(243,111,33,.14),
      rgba(31,138,91,.08) 32%,
      var(--bg) 78%);
}

.header{
  background:rgba(245,246,247,.88);
  border-bottom:1px solid rgba(15,23,42,.12);
}

.nav-links a{
  color:var(--text);
  font-weight:700;
  opacity:.86;
}
.nav-links a:hover{
  opacity:1;
  color:var(--green-dark);
  text-decoration:none;
}
.nav-links a.active{
  background:rgba(31,138,91,.14);
  box-shadow:inset 0 0 0 1px rgba(31,138,91,.22);
}

/* cards + sections */
.card{
  box-shadow:var(--shadow);
}
.card h3{
  letter-spacing:.2px;
}

/* buttons */
.btn{
  transition:transform .05s ease, background .15s ease, border-color .15s ease, filter .15s ease;
}
.btn:hover{ text-decoration:none; }
.btn:active{ transform:translateY(1px); }

.btn.primary{
  background:var(--green);
  border-color:transparent;
  color:#fff;
}
.btn.primary:hover{ background:var(--green-dark); }

.btn.orange{
  background:var(--orange);
  border-color:transparent;
  color:#fff;
}
.btn.orange:hover{ filter:brightness(.95); }

/* subtle separators on light grey */
.section{ padding:24px 0; }

/* --- Article readability spacing (no content changes) --- */
.article h1,
.article h2,
.article h3 {
  margin-top: 28px;
}

.article p {
  margin: 14px 0;
}

.article blockquote {
  margin: 18px 0;
}

.article figure {
  margin: 22px 0;
}

.article ul,
.article ol {
  margin: 12px 0 16px 22px;
}
