/* css/fissi_main.css */

body {
    background: var(--bg);
    margin: 0;
    font-family: 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
    color: var(--text);
}

.fissi-main-container {
    max-width: 950px;
    margin: 0 auto;
    padding: 10px 20px 60px 20px;
    text-align: center;
}

.fissi-main-container h1,
.fissi-mainpage-header {
    color: var(--accent);
    font-size: 2.5rem;
    margin-bottom: 0.25em;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.fissi-main-container p,
.fissi-mainpage-description {
    color: var(--muted);
    font-size: 1.15rem;
    margin-bottom: 2em;
}

.solutions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 30px;
}

.solution-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 32px 24px 28px 24px;
    background: var(--surface);
    border-radius: 22px;
    box-shadow: 0 2px 12px 0 var(--shadow-weak);
    text-decoration: none;
    color: inherit;
    transition: box-shadow 0.2s, transform 0.2s;
    border: 1.5px solid var(--border);
    min-height: 220px;
    position: relative;
}

.solution-card:hover {
    box-shadow: 0 6px 28px 0 var(--shadow-mid), 0 1.5px 8px 0 var(--shadow-weak);
    transform: translateY(-3px) scale(1.025);
    border-color: color-mix(in oklab, var(--accent) 40%, var(--border));
}

.solution-card h2 {
    color: var(--accent);
    font-size: 1.4rem;
    font-weight: 700;
    margin: 0 0 0.7em 0;
    letter-spacing: 0.01em;
}

.solution-card p {
    font-size: 1.07rem;
    color: var(--text);
    margin: 0;
    line-height: 1.5;
}

.solution-card .icon {
    font-size: 2.7rem;
    color: var(--accent);
    margin-bottom: 18px;
    margin-top: -8px;
    transition: color 0.18s;
}

.solution-card:hover .icon {
    color: color-mix(in oklab, var(--accent) 70%, black);
}

@media (max-width: 700px) {
    .fissi-main-container {
        padding: 24px 5px 40px 5px;
    }

    .solutions-grid {
        gap: 16px;
    }

    .solution-card {
        padding: 22px 8px 18px 8px;
    }

    .solution-card h2 {
        font-size: 1.12rem;
    }

    .solution-card p {
        font-size: 0.99rem;
    }
}
/* --- Info banner --- */
.info-banner {
  --banner-bg: var(--accent, #0a84ff);
  --banner-fg: #fff;
  --banner-border: rgba(255,255,255,0.25);
  --marquee-duration: 22s;

  position: relative;
  width: 100%;
  background: var(--banner-bg);
  color: var(--banner-fg);
  border-bottom: 1px solid var(--banner-border);
  font-size: 0.95rem;
  line-height: 1.2;
}

.info-banner .inner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 40px 10px 12px; /* tilaa sulkunapille oikealle */
  overflow: hidden; /* piilota rullan yli menevä teksti */
}

.info-banner .label {
  font-weight: 600;
  margin-right: 10px;
  white-space: nowrap;
}

.info-banner .marquee {
  position: relative;
  flex: 1 1 auto;
  overflow: hidden;
}

.info-banner .track {
  display: inline-flex;
  gap: 40px;                 /* väli toistojaksojen väliin */
  white-space: nowrap;
  will-change: transform;
  animation: banner-marquee var(--marquee-duration) linear infinite;
}

.info-banner:hover .track {
  animation-play-state: paused; /* pysäytä hoverissa */
}

@keyframes banner-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); } /* koska tuplataan sisältö 2x */
}

/* Sulkunappi */
.info-banner .close-btn {
  position: absolute;
  right: 6px;
  top: 6px;
  width: 28px;
  height: 28px;
  border: 1px solid var(--banner-border);
  border-radius: 6px;
  background: transparent;
  color: var(--banner-fg);
  cursor: pointer;
  display: inline-grid;
  place-items: center;
  font-size: 16px;
}
.info-banner .close-btn:hover { background: rgba(255,255,255,0.12); }

/* Korkea kontrasti ja tumma/vaalea tuki muuttujilla hoituu. Vähennetty liike: ei animaatiota. */
@media (prefers-reduced-motion: reduce) {
  .info-banner .track { animation: none; }
}

/* Pieni ruutu: pienempi fontti */
@media (max-width: 600px) {
  .info-banner { font-size: 0.9rem; }
}
/* Palautuslinkki (näytetään vain kun banneri on piilotettu) */
.info-banner-restore {
  display:none; text-align:right; font-size:12px; margin:4px 8px 0; opacity:.75;
}
.info-banner-restore a { color: var(--text); text-decoration: underline; }
/* CTA-napin peruslook */
.info-banner a.cta {
  display: inline-block;
  margin-left: .5rem;
  padding: 6px 12px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;         /* tärkeä rulla/overflow-tilassa */
  border: 1px solid transparent;
}

/* Värit severiteetin mukaan – säädä omaan palettiisi */
.info-info    a.cta { background: #2563eb; color: #fff; }
.info-success a.cta { background: #16a34a; color: #fff; }
.info-warning a.cta { background: #d97706; color: #151515; border-color: rgba(0,0,0,.1); }
.info-danger  a.cta { background: #dc2626; color: #fff; }

.info-banner a.cta:hover {
  filter: brightness(0.9);
}

/* Jos sulla on gradientteja/maskeja trackissa, estä “leikkaantuminen” */
.info-banner .marquee .text a.cta {
  position: relative;
  z-index: 1;
}
/* --- Peruslayout --- */
.info-banner {
  width: 100%;
  color: var(--text);
 /*padding: 10px 16px;*/
  border-radius: 8px;
  /*margin-bottom: 8px;*/
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.95rem;
  line-height: 1.4;
  box-sizing: border-box;
  overflow: hidden;
}

/* --- Severitykohtaiset värit --- */

/* INFO – sinertävä */
.info-banner.info-info {
  background: #e0f2fe;          /* vaalea sininen */
  border: 1px solid #38bdf8;   /* cyan-border */
  color: #0c4a6e;
}

/* SUCCESS – vihertävä */
.info-banner.info-success {
  background: #ecfdf5;
  border: 1px solid #34d399;
  color: #064e3b;
}

/* WARNING – keltainen/oranssi */
.info-banner.info-warning {
  background: #fefce8;
  border: 1px solid #facc15;
  color: #78350f;
}

/* DANGER – punainen */
.info-banner.info-danger {
  background: #fef2f2;
  border: 1px solid #f87171;
  color: #7f1d1d;
}

/* --- CTA linkki sopii jokaisen päälle --- */
.info-banner a.cta {
  display: inline-block;
  margin-left: .5rem;
  padding: 6px 12px;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 600;
  white-space: nowrap;
  background: rgba(255,255,255,0.2);
  color: inherit;
  border: 1px solid rgba(0,0,0,0.1);
}

.info-banner a.cta:hover {
  background: rgba(255,255,255,0.3);
}
@media (prefers-color-scheme: dark) {
  .info-banner.info-info    { background: #0c4a6e; color: #e0f2fe; border-color: #38bdf8; }
  .info-banner.info-success { background: #064e3b; color: #dcfce7; border-color: #34d399; }
  .info-banner.info-warning { background: #78350f; color: #fef9c3; border-color: #facc15; }
  .info-banner.info-danger  { background: #7f1d1d; color: #fee2e2; border-color: #f87171; }

  .info-banner a.cta {
    background: rgba(255,255,255,0.15);
    color: #fff;
  }
}
/* --- Severity badge --- */
.sev-badge{
  display:inline-block;
  padding:.15rem .45rem;
  border-radius:6px;
  border:1px solid var(--border);
  font-size:.85rem;
  white-space:nowrap;
}
.sev-info   { background:#0ea5e922; border-color:#0ea5e955; }
.sev-success{ background:#16a34a22; border-color:#16a34a55; }
.sev-warning{ background:#f59e0b22; border-color:#f59e0b55; }
.sev-danger { background:#dc262622; border-color:#dc262655; }
/* Bannerin scrolleri */
.info-banner .marquee {
  position: relative;
  overflow: hidden;
  width: 100%;
  white-space: nowrap;
}

/* Liikkuva nauha (kaksi kopiota sisällä) */
.info-banner .marquee .track {
  display: inline-block;
  white-space: nowrap;
  will-change: transform;
  animation: marqueeLoop var(--marquee-duration, 20s) linear infinite;
}

/* Yksittäinen kopio (väli kopioiden väliin) */
.info-banner .marquee .text {
  display: inline-block;
  padding-right: 2rem;
}

/* Saumaton looppi: siirrä tasan -50% (2 kopiota = 200% leveys) */
@keyframes marqueeLoop {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Esteettömyys: käyttäjä voi vähentää liikettä */
@media (prefers-reduced-motion: reduce) {
  .info-banner .marquee .track {
    animation: none;
    transform: none;
  }
}

/* (Valinnainen) pysäytä hover/focus */
.info-banner .marquee:hover .track,
.info-banner .marquee:focus-within .track {
  animation-play-state: paused;
}
