/* ========================
   PERUSASETUKSET
======================== */
:root{
  --green-800:#0b5d0b;
  --green-700:#0f700f;
  --green-650:#1f7a1f;
  --green-600:#2e6b2e;
  --green-500:#3f8c3f;
  --text:#1b3b1b;
  --bg:#f7f7f5;
  --shadow:0 8px 24px rgba(0,0,0,.08);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:'Poppins',sans-serif;
  color:var(--text);
  background-color:var(--bg);
  scroll-behavior:smooth;
  padding-bottom:90px; /* evästebanneria varten */
}

/* ========================
   HEADER – paksu ja keskitetty
======================== */
.top-header{
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 84px;                           /* vähän korkeampi */
  background: var(--green-700);
  color: #fff;
  z-index: 1000;
  box-shadow: 0 3px 10px rgba(0,0,0,.25);
  display: grid;
  align-items: center;
  /* iPhone / notch turvavara */
  padding-top: max(0px, env(safe-area-inset-top));
}

.header-inner{
  max-width: 1200px;
  width: 100%;
  height: 84px;
  margin: 0 auto;
  padding: 0 28px;                        /* hiukan leveämmät reunat */
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}

/* NAV keskelle */
.main-nav{
  grid-column: 2;
  justify-self: center;
  display: flex;
  align-items: center;
  gap: 34px;                              /* enemmän väliä linkeille */
}

.main-nav a{
  display: flex;
  align-items: center;
  justify-content: center;
  height: 52px;                           /* suurempi korkeus */
  padding: 0 18px;
  line-height: 1;
  color: #fff;
  text-decoration: none;
  font-weight: 700;                       /* paksumpi fontti */
  font-size: 1.05rem;                     /* vähän isompi */
  border-radius: 8px;
  transition: background .2s, transform .2s;
}
.main-nav a:hover{
  background: rgba(255,255,255,.15);
  transform: translateY(-1px);
}

/* Nappi oikealle */
.login-btn{
  grid-column: 3;
  justify-self: end;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  padding: 0 15px;                        /* vähän leveämpi */
  line-height: 1;
  background: #fff;
  color: var(--green-700);
  font-weight: 700;
  font-size: 1.05rem;
  border-radius: 10px;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.2);
  transition: background .2s, transform .2s, box-shadow .2s;
}
.login-btn:hover{
  background: #eaf4ea;
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(0,0,0,.12);
}

/* ettei hero jää alle */
main{ padding-top: 84px; }

@media (max-width: 900px){
  .top-header{ height: 70px; }
  .header-inner{ height: 70px; padding: 0 14px; }
  .main-nav{ gap: 20px; }
  .main-nav a{ height: 44px; font-size: .95rem; }
  .login-btn{ height: 44px; padding: 0 16px; font-size: .95rem; }
}

/* Pienimmät ruudut – vähän tiiviimpi nav */
@media (max-width: 600px){
  .main-nav{
    gap: 12px;
  }
  .main-nav a{
    padding: 0 10px;
    font-size: 0.9rem;
  }
  .login-btn{
    font-size: 0.9rem;
    padding: 0 12px;
  }
}

/* ========================
   HERO (ETUSIVU)
======================== */
.hero{
  position:relative;
  height:100vh;
  min-height:520px;
  display:grid;
  place-items:center;
  overflow:hidden;
  color:#fff;
}

.hero-bg{
  position:absolute; inset:0;
  background:url('uusihero-pg.png') center /cover no-repeat; /* uusi tausta */
  transform:scale(1);
  will-change:transform;
  z-index:0;
}
.hero-overlay{
  position:absolute; inset:0;
  pointer-events:none;
  z-index:1;
  background:
    radial-gradient(60% 60% at 50% 52%, rgba(0,0,0,.12) 0%, rgba(0,0,0,.38) 100%),
    linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.42) 85%, rgba(0,0,0,.5) 100%);
}
.hero-content{
  position:relative; z-index:2; text-align:center;
  max-width:980px; padding:0 24px; animation:fadeUp .6s ease-out both;
}
.kicker{
  font-size:.8rem; letter-spacing:.22em; text-transform:uppercase; opacity:.9;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  border-radius:999px; padding:6px 12px; display:inline-block; margin-bottom:10px;
}
.hero-content h1{
  font-weight:800; letter-spacing:-.01em; line-height:1.07;
  font-size:clamp(34px,5.1vw,62px);
  max-width:18ch; margin:6px auto 10px;
  text-shadow:0 2px 20px rgba(0,0,0,.35);
}
.hero-content p{
  font-size:clamp(16px,1.6vw,20px); opacity:.95; margin:0 auto 22px;
  text-shadow:0 2px 12px rgba(0,0,0,.45);
}
.hero-ctas{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.btn{
  display:inline-block; padding:14px 24px; border-radius:999px; text-decoration:none;
  font-weight:700; transition:transform .18s, box-shadow .18s, background .18s, color .18s;
}
.btn-primary{ background:linear-gradient(90deg,var(--green-600),var(--green-500)); color:#fff; box-shadow:0 10px 24px rgba(46,107,46,.35); }
.btn-primary:hover{ transform:translateY(-1px) scale(1.02); box-shadow:0 12px 28px rgba(46,107,46,.45); }
.btn-ghost{ background:rgba(255,255,255,.08); color:#fff; border:1px solid rgba(255,255,255,.4); backdrop-filter:blur(2px); }
.btn-ghost:hover{ background:rgba(255,255,255,.16); }

@keyframes fadeUp{
  from{ opacity:0; transform:translateY(40px); }
  to{ opacity:1; transform:translateY(0); }
}

@media (max-width:900px){
  .hero{ height:80vh; min-height:520px; }
  .hero-content{ padding:0 16px; }
}
@media (max-width:640px){
  .hero{ height:78vh; }
  .kicker{ font-size:.78rem; }
}

/* ========================
   PAGE HERO (SISÄSIVUT)
======================== */
.page-hero{
  position: relative;
  height: 40vh;
  min-height: 320px;
  display: grid;
  place-items: center;         /* keskitys pysty+vaaka */
  color: #fff;
  overflow: hidden;
}

/* tausta (pidä polku samana kuin tietoa-sivulla!) */
.page-hero .hero-bg{
  position: absolute;
  inset: 0;
  z-index: 0;
  background: url('uusihero-pg.png') center/cover no-repeat;
  transform: scale(1.02);
}

.page-hero .hero-overlay{
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(60% 60% at 50% 52%, rgba(0,0,0,.18) 0%, rgba(0,0,0,.50) 100%),
    linear-gradient(180deg, rgba(0,0,0,.22) 0%, rgba(0,0,0,.55) 85%);
}

.page-hero .hero-content{
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 20px;
  max-width: 900px;
}

.page-hero h1{
  margin: 0 0 10px;            /* poistaa mahdollisen ylä-marginaalin */
  font-size: clamp(34px, 4vw, 56px);
  font-weight: 800;
  letter-spacing: -0.01em;
  text-shadow: 0 2px 20px rgba(0,0,0,.35);
}

.page-hero p{
  margin: 0;
  font-size: clamp(16px, 1.4vw, 18px);
  line-height: 1.7;
  text-shadow: 0 2px 12px rgba(0,0,0,.45);
}

@media (max-width: 768px){
  .page-hero{ height: 36vh; min-height: 260px; }
}

/* ========================
   SECTIONS / SISÄLTÖ
======================== */
.section{
  max-width:1100px;
  margin:0 auto;
  padding:64px 20px;
}
.section h2{
  margin:0 0 18px;
  font-size:clamp(26px,2.8vw,40px);
  color:var(--text);
  letter-spacing:-.01em;
}
.center{ text-align:center; margin-top:10px; }

/* === Myyntiblokki (otsikko + lead) === */
.course-section{
  max-width:1100px;
  margin:0 auto;
  padding:72px 20px 52px;
  text-align:center;
}
.course-section h2 {
  font-size: clamp(34px, 3.8vw, 50px);
  line-height: 1.22;
  letter-spacing: -0.012em;
  max-width: 32ch;               /* hieman leveämpi, mahtuu kahdelle riville */
  margin: 0 auto 18px;
  text-align: center;
  text-wrap: balance;
  word-break: keep-all;
  hyphens: none;
}
.course-section .lead{
  max-width:820px;
  margin:8px auto 36px;
  font-size:clamp(18px,1.6vw,21px);
  line-height:1.55;
  opacity:.95;
  text-wrap:pretty;
}

/* === Hinnastoruudukko (tasakorkuiset kortit) === */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  align-items:stretch;              /* venytä solut samaan korkeuteen */
}
@media (max-width:960px){
  .pricing-grid{ grid-template-columns:1fr; }
}

.price-card{
  background:#fff;
  border-radius:16px;
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.06);
  padding:22px 22px 24px;

  /* tasakorkeus + CTA alas */
  height:100%;
  display:flex;
  flex-direction:column;
  text-align:left;
}
.price-card header h3{ margin:0 0 6px; font-size:18px; color:#245d24; }
.price-card .price{ display:flex; align-items:baseline; gap:10px; margin-bottom:12px; }
.price-card .amount{ font-size:30px; font-weight:800; color:#173f17; }
.price-card .once{ font-size:12px; color:#567556; }

.muted-card{ opacity:.82; filter:grayscale(.08); border-style:dashed; }
.badge{ display:inline-block; font-size:12px; padding:4px 10px; border-radius:999px; }
.badge-soon{ background:#fff4d7; color:#6b5200; border:1px solid #ead79e; }

/* lista venyy täyttämään kortin, jotta CTA pysyy alhaalla */
.feature-list{
  list-style:none;
  padding:8px 0 6px;
  margin:0 0 16px;
  flex:1 1 auto;
}
.feature-list li{
  display:grid;
  grid-template-columns:22px 1fr;
  align-items:start;
  gap:10px;
  padding:10px 0;
  border-top:1px solid rgba(0,0,0,.06);
}
.feature-list li:first-child{ border-top:none; }
.feature-list li::before{
  content:"✓";
  color:var(--green-600);
  font-weight:800;
  line-height:1;
  margin-top:2px;
}

.card-cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:auto;                  /* ankkuroi napit alareunaan */
}
.card-cta .btn{ width:auto; }

.btn-disabled{
  background:rgba(0,0,0,.06);
  color:#5f5f5f;
  border:1px solid rgba(0,0,0,.08);
  border-radius:999px;
  padding:12px 22px;
  cursor:not-allowed;
}
.muted{ color:#5d7a5d; }
.smallprint{ font-size:12px; margin-top:16px; }

/* === Miksi valita -kortit === */
.cards-3{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:18px;
}
.feature-card{
  background:#fff;
  border-radius:16px;
  padding:20px;
  box-shadow:0 6px 18px rgba(0,0,0,.08);
  border:1px solid rgba(0,0,0,.06);
}
.feature-card .icon{
  width:40px; height:40px;
  display:grid; place-items:center;
  background:#eaf4ea; color:var(--green-600);
  border-radius:10px; margin-bottom:10px;
}
.feature-card h3{ margin:0 0 6px; color:#214a21; font-size:18px; }
.feature-card p{ margin:0; color:#3f5f3f; }

/* ========================
   VIDEOT
======================== */
.video-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:2rem;
  margin-top:2rem;
}
.video-card{
  background:#fff; border-radius:16px; overflow:hidden; box-shadow:0 6px 16px rgba(0,0,0,0.1);
  transition:transform .2s ease, box-shadow .2s ease;
}
.video-card:hover{ transform:translateY(-5px); box-shadow:0 8px 20px rgba(0,0,0,0.15); }
.video-wrapper{ position:relative; aspect-ratio:16 / 9; overflow:hidden; }
.video-wrapper iframe{ width:100%; height:100%; border:none; }
.video-body{ padding:1.2rem 1.5rem 1.5rem; }
.video-body h3{ margin-top:.5rem; font-size:1.2rem; color:#1a3317; }
.video-body p{ margin-top:.3rem; font-size:.95rem; color:#444; }
.pill{ display:inline-block; background-color:var(--green-600); color:#fff; padding:.2rem .6rem; border-radius:999px; font-size:.8rem; letter-spacing:.5px; text-transform:uppercase; }

/* Yksi kolumni kaikista pienimmillä ruuduilla */
@media (max-width:480px){
  .video-grid{
    grid-template-columns:1fr;
  }
}

/* ========================
   UUDISTUKSET + TUKI
======================== */
.changelog{ list-style:none; margin:0 0 24px; padding:0; }
.changelog li{
  background:#fff; border-radius:12px; padding:12px 14px;
  border:1px solid rgba(0,0,0,.06); box-shadow:0 4px 14px rgba(0,0,0,.06);
  display:flex; gap:10px; align-items:center; margin-bottom:10px;
}
.changelog .date{
  font-size:12px; color:var(--green-600); background:#eaf4ea; border:1px solid #d7ead8;
  padding:3px 8px; border-radius:999px; white-space:nowrap;
}
.support-cta{
  max-width:980px; margin:24px auto 48px; padding:36px 24px; border-radius:16px;
  background:var(--green-600); color:#fff; text-align:center; box-shadow:0 8px 22px rgba(0,0,0,.12);
}
.support-cta .emoji{ font-size:28px; margin-bottom:6px; }

/* ========================
   INFO/TIETOA (listat yms.)
======================== */
.info-section{
  max-width:900px;
  margin:0 auto;
  padding:40px 20px;
  line-height:1.7;
  font-size:16px;
}
.info-section h2,
.info-section h3{
  color:#204b20;
  margin-top:32px;
  margin-bottom:10px;
  font-weight:700;
}
.info-section .lead{
  font-size:18px;
  opacity:.9;
  margin-bottom:20px;
}
.info-section p{
  margin:10px 0 18px;
  color:#1f1f1f;
}
.info-section .feature-list{
  list-style:none;
  padding-left:0;
  margin:20px 0;
}
.info-section .feature-list li{
  position:relative;
  padding-left:28px;
  margin-bottom:12px;
  font-size:16px;
  color:#1f1f1f;
  display:block;
  width:100%;
  line-height:1.6;
}
.info-section .feature-list li::before{
  content:"✔";
  position:absolute;
  left:0;
  top:0;
  color:#256d25;
  font-weight:600;
}

/* Pienet ruudut – vähän tiiviimpi */
@media (max-width:600px){
  .info-section{
    padding:32px 16px;
    font-size:15px;
  }
}

/* Kurssilista dt/dd -rakenne (kurssit-sivu) */
.course-list{ margin:0 0 10px; padding:0; }
.course-list .row{
  display:grid;
  grid-template-columns:minmax(10ch,14ch) 1fr;
  gap:16px;
  align-items:start;
  padding:12px 0;
  border-top:1px solid rgba(0,0,0,.06);
}
.course-list .row:first-child{ border-top:none; }
.course-list dt{ font-weight:700; color:#214a21; }
.course-list dd{ margin:0; color:#2b3e2b; line-height:1.6; }

/* Kurssilista päällekkäin mobiilissa */
@media (max-width:600px){
  .course-list .row{
    grid-template-columns:1fr;
  }
}

/* CTA-kortit tietoa-sivulle */
.cta-section{ max-width:1100px; margin:40px auto 96px; padding:0 20px; }
.cta-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.cta-card{
  background:#2e6b2e; color:#fff; border-radius:16px; padding:28px 24px; text-align:center;
  box-shadow:0 10px 28px rgba(0,0,0,.14);
}
.cta-card h3{ margin:8px 0 8px; font-size:clamp(18px,2.2vw,22px); font-weight:700; }
.cta-card p{ margin:0 0 16px; opacity:.96; }
.cta-card .btn{ padding:12px 20px; }
@media (max-width:900px){
  .cta-grid{ grid-template-columns:1fr; }
}

/* ========================
   FOOTER + SOME
======================== */
footer{
  text-align:center;
  padding:20px;
  background-color:var(--green-700);
  color:#fff;
  margin-top:40px;
}
body.auth-page footer{
  margin-top:0;
}
.social-icons{ margin-top:10px; }
.social-icons a{
  text-decoration:none;
  color:#fdfdfd;
  font-size:28px;
  margin:0 10px;
  transition:transform .2s;
}
.social-icons a:hover{ transform:scale(1.2); }

/* ========================
   EVÄSTEBANNERI
======================== */
.privacy-banner{
  position:fixed; left:0; right:0; bottom:0;
  display:flex; justify-content:center; align-items:center; gap:10px; flex-wrap:wrap;
  padding:14px 16px; background:var(--green-600); color:#fff; z-index:2000;
  box-shadow:0 -6px 18px rgba(0,0,0,.16);
}
#accept-cookies{
  background:#fff; color:var(--green-600); border:0; padding:8px 14px; border-radius:8px; font-weight:700; cursor:pointer;
}
#accept-cookies:hover{ background:#eaf4ea; }

/* Varmistetaan, että sisäsivujen (page-hero) H1 ei peri kotisivun 18ch tms. rajoja */
.page-hero .hero-content{
  text-align:center;
}
.page-hero .hero-content h1{
  margin-left:auto;
  margin-right:auto;
  max-width:none;     /* ylittää kotisivun .hero-content h1 max-widthin */
  transform:none;
  text-align:center;  /* varmistus */
}

/* ========================
   LOGIN / AUTH HERO
======================== */
.auth-hero{
  position: relative;
  min-height: 100vh;
  padding: 96px 16px 40px;   /* vähän enemmän tilaa ylös, sama alas */
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #052913;       /* varaväri jos kuva ei lataudu */
}

/* Taustakuva – sama kuin etusivulla */
.auth-bg{
  position: absolute;
  inset: 0;
  background: url('uusihero-pg.png') center/cover no-repeat;
  transform: scale(1.05);
  filter: blur(4px);
}

/* Tummennus + vignette, että kortti erottuu */
.auth-overlay{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(80% 80% at 50% 35%, rgba(0, 0, 0, 0.15) 0%, rgba(0, 0, 0, 0.75) 100%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.7) 100%);
  opacity: 0.95;
}

.auth-inner{
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 420px;
}

/* Login-kortti */
.auth-card{
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  background: rgba(10, 36, 18, 0.78);
  border-radius: 24px;
  padding: 28px 26px 30px;
  box-shadow: 0 22px 40px rgba(0, 0, 0, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.06);
  color: #ffffff;
  text-align: left;
}

.auth-card h1{
  margin: 0 0 6px;
  font-size: clamp(22px, 2.4vw, 26px);
  font-weight: 700;
  letter-spacing: -0.02em;
}

.auth-lead{
  margin: 0 0 18px;
  font-size: 14px;
  opacity: 0.9;
}

.auth-form{
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 18px;
}

.auth-label{
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 4px;
  color: rgba(255, 255, 255, 0.9);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.auth-input{
  width: 100%;
  padding: 11px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  background: rgba(8, 24, 14, 0.75);
  color: #ffffff;
  font-size: 14px;
  outline: none;
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease;
}

.auth-input::placeholder{
  color: rgba(255, 255, 255, 0.45);
}

.auth-input:focus{
  border-color: #7fda7f;
  box-shadow: 0 0 0 1px rgba(127, 218, 127, 0.65);
  background: rgba(8, 24, 14, 0.95);
}

.auth-btn{
  width: 100%;
  margin-top: 6px;
  font-weight: 600;
}

.auth-footer-text{
  margin: 0;
  font-size: 13px;
  text-align: center;
  color: rgba(255, 255, 255, 0.9);
}

.auth-link{
  color: #c2ffbf;
  font-weight: 600;
  text-decoration: none;
}

.auth-link:hover{
  text-decoration: underline;
}

@media (max-width: 600px){
  .auth-card{
    padding: 24px 20px 26px;
  }
}
