/* ===================== DESKTOP (≥981px) ===================== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{height:100%;margin:0}

:root{
  /* --- LOGOT DESKTOP --- */
  --nyrkki-h: 72px;
  --nyrkki-w: auto;
  --headerlogo-h: 48px;
  --headerlogo-w: 220px;
  --nyrkki-offset-x: 0px;
  --nyrkki-offset-y: 0px;
  --headerlogo-offset-x: 0px;
  --headerlogo-offset-y: 0px;

  /* Header layout */
  --brand-gap: 12px;
  --brand-align: center;
  --brand-justify: flex-start;

  /* General */
  --containerW: 1150px;
  --headerH: 68px;

  /* Cards glass */
  --glass-bg: rgba(255,255,255,.20);
  --glass-bd: rgba(255,255,255,.25);
}

body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:#eaeaf0;background:#0b0b0c;
  overflow:hidden; /* desktop: ei sivun scrollia */
}
html,body{overflow-x:hidden;max-width:100%;position:relative;}
.container{max-width:var(--containerW);margin:0 auto;padding:0 20px}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;height:var(--headerH);
  background:rgba(255,255,255,.20);backdrop-filter:blur(6px);
  border-bottom:1px solid rgba(255,255,255,.25);z-index:100
}
.header-inner{ display:flex;align-items:center;justify-content:space-between;height:100% }
.brand{ display:flex; gap:var(--brand-gap); align-items:var(--brand-align); justify-content:var(--brand-justify); color:#fff;text-decoration:none }
.brand .nyrkki{ height:var(--nyrkki-h); width:var(--nyrkki-w); transform: translate(var(--nyrkki-offset-x), var(--nyrkki-offset-y)); }
.brand .headerlogo{ height:var(--headerlogo-h); width:var(--headerlogo-w); transform: translate(var(--headerlogo-offset-x), var(--headerlogo-offset-y)); }
.nav{display:flex;gap:28px;font-weight:600}
.nav a{color:#fff;text-decoration:none;opacity:.95;padding:6px 0}
.nav a:hover{opacity:1}
.menu{display:none;background:#161a24;border:1px solid #2b3242;color:#fff;padding:10px 14px;border-radius:10px;cursor:pointer}

/* ---------- Panels desktop ---------- */
main#app{position:relative;height:100vh;width:100vw}
section.panel{
  position:absolute;inset:0;display:grid;place-items:center;
  opacity:0;transition:opacity .35s ease;isolation:isolate
}
section.panel.active{opacity:1}
section.panel:first-of-type{opacity:1} /* fallback */

/* Backgrounds */
.panel picture,.panel picture *,.panel .bg,.panel .overlay{
  position:absolute;inset:0;width:100%;height:100%;pointer-events:none !important;
}
.panel picture{overflow:hidden}
.panel .bg{ object-fit:cover; object-position:center center !important; z-index:-2; }
@supports not (object-fit: cover){
  .panel .bg{ width:auto;height:100%; left:50%;top:50%; transform:translate(-50%,-50%); min-width:100%;min-height:100%; }
}
.panel .overlay{background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.55));z-index:-1}
#hero .overlay{display:none !important;}
.content{position:relative;z-index:20;pointer-events:auto}

/* Hero copy hidden on desktop */
.hero-content{padding:0; display:none;}

/* Cards & grids */
h2{font-family:Cinzel,serif;font-size:32px;margin:0 0 18px;color:#fff}
.grid.two{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.cards{display:grid;gap:20px}
.cards.three{grid-template-columns:repeat(3,1fr)}
.card,.box{
  background:var(--glass-bg);border:1px solid var(--glass-bd);
  border-radius:14px;padding:22px;color:#fff;backdrop-filter:blur(6px)
}
.card .slogan{color:#eef0f6;margin:8px 0 0}
.bullets,.benefits{padding-left:18px;margin:8px 0 0}
.benefits li{margin:10px 0}
.lead{color:#eef0f6}
.inline-cta{margin-top:14px;position:relative;z-index:40;pointer-events:auto}

/* Steps */
#tyonantajalle .steps{list-style:decimal inside;margin:0;padding-left:18px;color:#fff}
#tyonantajalle .steps>li{margin:10px 0;border-left:3px solid #10b981;padding-left:8px}

/* Buttons */
.button{display:inline-block;padding:12px 18px;border-radius:12px;text-decoration:none}
.button.primary{background:#10b981;color:#062315;border:1px solid #10b981}
.button.ghost{border:1px solid rgba(255,255,255,.7);color:#fff}

/* Apply form */
.apply-card{
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);border-radius:20px;
  padding:clamp(16px,2.5vw,28px);
  display:grid;grid-template-columns:1.1fr 1.3fr;gap:clamp(16px,2vw,28px);
  box-shadow:0 10px 30px rgba(0,0,0,.25);backdrop-filter:blur(6px);color:#fff;
  position:relative;z-index:30;pointer-events:auto;
}
.apply-card *{position:relative;z-index:31;pointer-events:auto}
.form-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.form-grid .col-6{grid-column:span 6}
.form-grid .col-12{grid-column:span 12}
.field{display:grid;gap:6px}
.field label{font-size:14px;opacity:.95}
.field input,.field select,.field textarea{
  width:100%;border-radius:12px;border:1px solid rgba(255,255,255,.35);
  background:rgba(0,0,0,.25);color:#fff;padding:12px 14px;outline:none
}
.dropzone{grid-column:span 12;border:2px dashed rgba(255,255,255,.55);border-radius:14px;padding:18px;text-align:center;background:rgba(255,255,255,.10)}
.dropzone input[type="file"]{display:none}
.dz-title{font-weight:600;margin-bottom:4px}

html.js section.panel:first-of-type:not(.active) { opacity: 0; }


/* Desktop-hero – pidä peitto, mutta siirrä fokusta ylemmäs */
@media (min-width: 981px) {
  #hero .bg {
    object-fit: cover;
    /* siirrä hieman ylöspäin, jotta otsikkotekstit eivät leikkaannu */
    object-position: 50% 25%;
  }

  /* halutessa hieman lisää tilaa herolle pienissä läppärikorkeuksissa */
  #hero {
    min-height: calc(100vh - var(--headerH));
  }
}

