/* ===========================================================
   Teot.fi — luonnos · brändi: sininen + valkoinen
   =========================================================== */
:root{
  --blue:#0052cc;
  --blue-600:#2563eb;
  --blue-700:#1d4ed8;
  --blue-900:#0c2350;
  --blue-050:#eef4ff;
  --blue-100:#dbe7ff;
  --ink:#111827;
  --slate:#4b5563;
  --mut:#6b7280;
  --paper:#ffffff;
  --bg:#f7f9fc;
  --line:#e5e7eb;
  --line-soft:#eef1f6;
  --star:#f5a623;
  --ok:#15803d;
  --ok-bg:#e7f6ec;
  --radius:16px;
  --shadow-sm:0 1px 3px rgba(16,32,80,.06),0 1px 2px rgba(16,32,80,.04);
  --shadow-md:0 10px 24px -12px rgba(16,32,80,.22);
  --shadow-lg:0 28px 60px -28px rgba(16,32,80,.34);
  --font:'Inter',system-ui,-apple-system,sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{line-height:1.12;letter-spacing:-.02em;font-weight:800}
h1{font-size:clamp(2.3rem,5vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.2vw,2.4rem)}
.eyebrow{font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue)}
.lead{font-size:1.18rem;color:var(--slate);line-height:1.55}

/* highlight (korvaa keltaisen — brändisininen) */
.hl{position:relative;white-space:nowrap;color:var(--blue)}
.hl::after{content:"";position:absolute;left:-.02em;right:-.02em;bottom:-.12em;height:.2em;background:var(--blue-100);z-index:-1;border-radius:3px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:1rem;padding:.85rem 1.5rem;border-radius:12px;border:1.5px solid transparent;cursor:pointer;transition:transform .15s,box-shadow .15s,background .15s;font-family:inherit}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-700);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-ghost{background:#fff;color:var(--blue);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--blue)}
.btn-white{background:#fff;color:var(--blue)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn .arr{transition:transform .15s}
.btn:hover .arr{transform:translateX(3px)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.3rem;letter-spacing:-.03em;color:var(--blue)}
.logo img{width:34px;height:34px}
.nav-menu{display:flex;align-items:center;gap:1.7rem}
.nav-menu>a{font-weight:600;font-size:.96rem;color:var(--slate)}
.nav-menu>a:hover{color:var(--ink)}
.nav-cta{background:var(--blue);color:#fff!important;padding:.55rem 1.1rem;border-radius:10px}
.nav-cta:hover{background:var(--blue-700)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* mobile menu */
.mobile-menu{display:none;flex-direction:column;padding:8px 24px 20px;border-bottom:1px solid var(--line-soft);background:#fff}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:.6rem 0;font-weight:600;color:var(--slate);border-bottom:1px solid var(--line-soft)}
.mobile-menu a.sub{padding-left:1rem;font-weight:500;font-size:.92rem}
@media(max-width:880px){
  .nav-menu{display:none}
  .burger{display:flex}
}

/* ---------- context bar ---------- */
.context-bar{background:var(--blue-050);color:var(--blue);text-align:center;font-size:.86rem;font-weight:600;padding:.55rem 1rem;border-bottom:1px solid var(--blue-100)}

/* ---------- sections ---------- */
section{padding:84px 0}
.sec-bg{background:var(--bg)}
.sec-dark{background:linear-gradient(165deg,var(--blue-900),#102a54);color:#fff}
.sec-dark h2,.sec-dark h3{color:#fff}
.sec-dark .eyebrow{color:#9fc0ff}
.sec-dark .lead{color:#c3d2ee}
.sec-head{max-width:680px;margin:0 auto 48px;text-align:center}
.sec-head .eyebrow{display:block;margin-bottom:.8rem}
.sec-head .lead{margin-top:1rem}
.sec-head.left{margin-left:0;text-align:left}

/* ---------- hero (etusivu) ---------- */
.hero{position:relative;padding:64px 0 88px;overflow:hidden;background:
  radial-gradient(700px 360px at 85% 0%,var(--blue-050),transparent 55%),#fff}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:52px;align-items:center}
.hero h1 span.line{display:block}
.hero .lead{margin:1.4rem 0 2rem;max-width:34ch}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;align-items:center}
.coming{margin-top:1.3rem;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;font-size:.82rem;color:var(--mut);font-weight:500}
.os-tag{border:1px solid var(--line);border-radius:8px;padding:.25rem .6rem;display:inline-flex;gap:.35rem;align-items:center}
.os-tag b{color:var(--slate)}

/* pinned note cards */
.board{position:relative;min-height:560px}
.note{position:absolute;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:0 14px 32px -18px rgba(16,32,80,.28),0 2px 6px rgba(16,32,80,.05);width:290px}
.note::before{content:"";position:absolute;top:-9px;left:50%;transform:translateX(-50%);width:16px;height:16px;border-radius:50%;background:var(--blue);box-shadow:inset 0 -2px 3px rgba(0,0,0,.25),0 2px 5px rgba(16,32,80,.3)}
.note .row{display:flex;align-items:center;gap:.7rem}
.note .notecat{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--blue)}
.note h4{font-size:1.2rem;margin:.4rem 0 .15rem}
.note .meta{font-size:.86rem;color:var(--mut)}
.note .price{font-weight:800;font-size:1.05rem;margin-top:.8rem}
.note .price small{font-weight:600;color:var(--mut);font-size:.78rem}
.note-job{top:0;left:0;transform:rotate(-3deg);z-index:2}
.note-bid{top:188px;right:0;transform:rotate(2.5deg);z-index:1}
.note-worker{top:372px;left:18px;transform:rotate(-2deg);z-index:3}
.badge-bid{display:inline-flex;align-items:center;gap:.4rem;margin-top:.7rem;font-size:.78rem;font-weight:700;color:var(--blue);background:var(--blue-050);border:1px solid var(--blue-100);border-radius:99px;padding:.3rem .7rem}
.avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--blue-600),var(--blue-900));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem}
.stars{color:var(--star);font-size:.92rem;letter-spacing:1px}
.stars small{color:var(--mut);font-weight:600}
.chips{margin-top:.7rem;display:flex;flex-wrap:wrap;gap:.35rem}
.chip{font-size:.72rem;font-weight:600;background:var(--ok-bg);color:var(--ok);padding:.2rem .55rem;border-radius:99px}
.chip.b{background:var(--blue-050);color:var(--blue)}
.dash{position:absolute;left:120px;top:140px;width:130px;height:120px;border:2px dashed var(--blue-100);border-radius:50% 50% 50% 0;transform:rotate(45deg)}
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .dash{display:none}
  /* mobiilissa kortit normaaliin virtaukseen (ei absolute -> ei katkea), mutta säilytä vino ilmoitustaulu-tyyli */
  .board{min-height:0;margin-top:24px;display:flex;flex-direction:column;gap:26px;overflow:visible}
  .note{position:static;width:88%;transform:none;box-shadow:0 12px 28px -16px rgba(16,32,80,.28),0 2px 6px rgba(16,32,80,.05)}
  .note-job{top:auto;left:auto;right:auto;transform:rotate(-2.5deg);align-self:flex-start;margin-left:2%}
  .note-bid{top:auto;left:auto;right:auto;transform:rotate(2.5deg);align-self:flex-end;margin-right:2%}
  .note-worker{top:auto;left:auto;right:auto;transform:rotate(-1.5deg);align-self:flex-start;margin-left:4%}
}

/* ---------- steps (näin se toimii) ---------- */
.toggle{display:inline-flex;gap:4px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:12px;padding:5px;margin:0 auto 40px}
.sec-bg .toggle,.toggle.light{background:#fff;border-color:var(--line)}
.toggle button{border:none;background:none;font:inherit;font-weight:700;font-size:.95rem;color:#9fc0ff;padding:.55rem 1.3rem;border-radius:8px;cursor:pointer}
.toggle.light button{color:var(--slate)}
.toggle button.active{background:var(--blue);color:#fff}
.toggle-wrap{text-align:center}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:8px}
.step{position:relative;padding-top:20px}
.step::before{content:"";position:absolute;top:0;left:0;width:40px;height:3px;background:var(--blue);border-radius:2px}
.sec-dark .step::before{background:#9fc0ff}
.step .n{font-size:.8rem;font-weight:800;letter-spacing:.1em;color:var(--blue)}
.sec-dark .step .n{color:#9fc0ff}
.step h3{font-size:1.32rem;margin:.5rem 0 .5rem}
.step p{color:var(--slate)}
.sec-dark .step p{color:#c3d2ee}
@media(max-width:760px){.steps{grid-template-columns:1fr;gap:30px}}

/* ---------- escrow flow ---------- */
.flow{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:stretch;gap:12px;margin-top:8px}
.fnode{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 22px;text-align:center;box-shadow:var(--shadow-sm)}
.fnode .ic{width:52px;height:52px;border-radius:13px;background:var(--blue-050);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto .9rem}
.fnode.lock{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-050),var(--shadow-sm)}
.fnode.lock .ic{background:var(--blue);color:#fff}
.fnode h3{font-size:1.18rem}
.fnode p{font-size:.92rem;color:var(--mut);margin-top:.35rem}
.farr{display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:1.6rem;font-weight:800}
@media(max-width:820px){.flow{grid-template-columns:1fr}.farr{transform:rotate(90deg)}}

/* ---------- maksutavat ---------- */
.pay{margin-top:40px;text-align:center}
.pay .lbl{font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--mut);margin-bottom:1rem}
.pay-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.pay-badge{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:11px;padding:.55rem .9rem;font-weight:600;font-size:.9rem;color:var(--ink);box-shadow:var(--shadow-sm)}
.pay-badge img{height:18px;width:auto;display:block}
.pay-badge.card svg{height:18px;width:24px;color:var(--slate)}
.pay-note{margin-top:1.1rem;display:inline-flex;align-items:center;gap:.45rem;font-size:.85rem;color:var(--mut)}
.pay-note img{height:16px;opacity:.8}

/* ---------- palaute (footer) ---------- */
.feedback{background:var(--blue-050);border-top:1px solid var(--blue-100)}
.feedback .wrap{max-width:760px;text-align:center}
.feedback h2{margin-bottom:.6rem}
.feedback p{color:var(--slate);margin-bottom:1.4rem}
.fb-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.fb-form{max-width:560px;margin:0 auto;text-align:left}
.fb-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.fb-form input,.fb-form textarea{width:100%;font-family:inherit;font-size:.98rem;padding:.8rem 1rem;border:1px solid var(--line);border-radius:11px;background:#fff;color:var(--ink)}
.fb-form textarea{margin-bottom:14px;resize:vertical}
.fb-form input:focus,.fb-form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-050)}
.fb-form .btn{width:100%;justify-content:center}
.fb-ok{margin-top:1rem;text-align:center;color:var(--ok);font-weight:600}
@media(max-width:560px){.fb-row{grid-template-columns:1fr}}

/* ---------- app showcase ---------- */
.app-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.phone{width:270px;margin:0 auto;border:11px solid #0c1730;border-radius:40px;background:#0c1730;box-shadow:var(--shadow-lg);position:relative}
.phone .notch{display:none}
.phscreen{border-radius:30px;overflow:hidden;background:#fff;aspect-ratio:9/19.3;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.phimg{width:100%;height:100%;object-fit:contain;display:block;background:#fff}
.phfallback{display:none;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:22px;height:100%}
.phscreen .ph-ic{font-size:2rem}
.phscreen .ph-t{font-weight:800;color:var(--blue-900);font-size:1.02rem}
.ph-note{font-size:.72rem;color:var(--mut)}
.ph-tag{font-size:.62rem;font-weight:700;background:var(--blue);color:#fff;padding:.2rem .55rem;border-radius:6px}
.os-row{display:flex;gap:12px;margin:1.4rem 0;flex-wrap:wrap}
.os-pill{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.95rem;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:.65rem 1rem;color:#c3d2ee}
.os-pill .soon{font-size:.6rem;font-weight:700;background:rgba(255,255,255,.14);color:#dce7ff;padding:.14rem .5rem;border-radius:99px;letter-spacing:.04em}
@media(max-width:820px){.app-grid{grid-template-columns:1fr;gap:40px}}

/* ---------- category grid ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}
.cat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;transition:transform .15s,box-shadow .15s,border-color .15s}
.cat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--blue-100)}
.cat .ic{font-size:1.7rem}
.cat h3{font-size:1.08rem;margin:.6rem 0 .4rem}
.cat p{font-size:.92rem;color:var(--slate)}
.cat.more{background:var(--blue-050);border-color:var(--blue-100)}

/* ---------- feature/benefit grid ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.feat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow-sm)}
.feat .ic{width:46px;height:46px;border-radius:11px;background:var(--blue-050);display:flex;align-items:center;justify-content:center;font-size:1.35rem;margin-bottom:1rem}
.feat h3{font-size:1.16rem;margin-bottom:.5rem}
.feat p{color:var(--slate);font-size:.96rem}
.feat p+p{margin-top:.6rem}

/* ---------- trust grid ---------- */
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.trust .ti{background:#fff;padding:30px 26px}
.trust .ti .ic{width:42px;height:42px;border-radius:11px;background:var(--blue-050);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem;color:var(--blue)}
.trust .ti .ic.ok{background:var(--ok-bg);color:var(--ok)}
.trust .ti h3{font-size:1.1rem;margin-bottom:.4rem}
.trust .ti p{font-size:.93rem;color:var(--slate)}
@media(max-width:860px){.trust{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.trust{grid-template-columns:1fr}}

/* ---------- kevytyrittäjyys ---------- */
.kev-list{list-style:none;margin:1.2rem 0 0;display:flex;flex-direction:column;gap:.5rem}
.kev-list li{color:var(--slate);font-weight:500}
.kev-price h3{font-size:1.16rem;margin-bottom:1rem}
.kev-rows{display:flex;flex-direction:column;gap:.1rem;margin-bottom:1rem}
.kev-row{display:flex;justify-content:space-between;align-items:baseline;padding:.7rem 0;border-bottom:1px solid var(--line-soft)}
.kev-row span{color:var(--slate)}
.kev-row b{font-weight:700;font-size:1.05rem}
.kev-row.total{border-bottom:none;border-top:2px solid var(--ink);margin-top:.2rem;padding-top:.8rem}
.kev-row.total b{color:var(--blue);font-size:1.4rem}
.kev-note{font-size:.88rem;color:var(--mut)}

/* ---------- pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;max-width:760px;margin:0 auto}
.pcard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:34px 26px;text-align:center;box-shadow:var(--shadow-sm)}
.pcard .label{font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mut)}
.pcard .big{font-size:2.6rem;font-weight:800;color:var(--blue);margin:.7rem 0}
.pcard p{font-size:.92rem;color:var(--slate)}
.price-note{text-align:center;margin-top:1.4rem;color:var(--mut);font-size:.9rem}

/* ---------- callout / cta band ---------- */
.cta-band{background:linear-gradient(165deg,var(--blue-900),#102a54);border-radius:24px;padding:54px 40px;text-align:center;color:#fff;margin:0 auto;max-width:var(--maxw)}
.cta-band h2{color:#fff;margin-bottom:.8rem}
.cta-band p{color:#c3d2ee;max-width:50ch;margin:0 auto 1.8rem}

/* ---------- prose (missio) ---------- */
.prose{max-width:760px;margin:0 auto}
.prose h2{margin:2.2rem 0 1rem}
.prose p{color:var(--slate);font-size:1.08rem;margin-bottom:1.1rem}
.prose .lead-text{font-size:1.18rem;color:var(--ink)}
.prose a{color:var(--blue);text-decoration:underline}
.sources li{margin-bottom:.7rem;font-size:.92rem;color:var(--slate)}
.sources a{color:var(--blue)}
.src-author{color:var(--mut)}

/* subpage hero */
.subhero{padding:64px 0 40px;background:radial-gradient(800px 360px at 80% 0,var(--blue-050),transparent 60%),#fff;text-align:center}
.subhero .lead{max-width:620px;margin:1.1rem auto 1.8rem}

/* ---------- footer ---------- */
footer{background:var(--blue-900);color:#aebfdd;padding:60px 0 40px}
.foot-top{text-align:center;margin-bottom:36px}
.foot-cols{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.1);padding-top:30px}
footer .logo{color:#fff}
.foot-links{display:flex;gap:40px;flex-wrap:wrap}
.foot-links h4{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:#7e93bd;margin-bottom:.8rem}
.foot-links a{display:block;color:#aebfdd;font-size:.93rem;padding:.2rem 0}
.foot-links a:hover{color:#fff}
.social{display:flex;gap:12px;margin-top:14px}
.social a{width:36px;height:36px;border:1px solid rgba(255,255,255,.18);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#aebfdd}
.social a:hover{border-color:#fff;color:#fff}
.social svg{width:17px;height:17px;fill:currentColor}
.foot-meta{margin-top:30px;font-size:.85rem;color:#7e93bd}
.foot-meta a{color:#aebfdd}

/* ---------- palveluhakemisto (SEO sitemap) ---------- */
/* HUOM: linkit aina HTML-lähteessä, ei display:none. Haitari klampaa vain visuaalisesti. */
.dir-wrap{display:flex;flex-direction:column;gap:26px}
.dir-sec{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);padding:0}
.dir-banner{height:128px;background-size:cover;background-position:center;position:relative;display:flex;align-items:flex-end}
.dir-banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,35,80,.15) 30%,rgba(12,35,80,.78))}
.dir-banner h2{position:relative;z-index:1;color:#fff;font-size:1.5rem;padding:20px 24px;display:flex;align-items:center;gap:.7rem;text-shadow:0 2px 12px rgba(12,35,80,.6)}
.dir-banner .cnt{font-size:.78rem;font-weight:700;background:#fff;color:var(--blue);border-radius:99px;padding:.18rem .6rem;letter-spacing:0}
.dir-listwrap{position:relative;padding:20px 24px}
.dir-list{list-style:none;margin:0;columns:3;column-gap:28px}
.dir-list li{break-inside:avoid;padding:.28rem 0;border-bottom:1px solid var(--line-soft)}
.dir-list a{font-size:.94rem;color:var(--slate);display:block}
.dir-list a:hover{color:var(--blue)}
/* clamp: vain iso lista (big). overflow piilottaa visuaalisesti, teksti SÄILYY DOM-lähteessä boteille */
.dir-listwrap.big .dir-list{max-height:286px;overflow:hidden}
.dir-listwrap.big.open .dir-list{max-height:none}
.dir-listwrap.big::after{content:"";position:absolute;left:0;right:0;bottom:54px;height:70px;background:linear-gradient(transparent,#fff);pointer-events:none}
.dir-listwrap.big.open::after{display:none}
.dir-toggle{margin-top:16px;font-family:inherit;font-weight:700;font-size:.92rem;color:var(--blue);background:var(--blue-050);border:1px solid var(--blue-100);border-radius:10px;padding:.6rem 1.1rem;cursor:pointer;position:relative;z-index:1}
.dir-toggle:hover{background:var(--blue-100)}
.dir-toggle::after{content:" ↓";font-weight:800}
.dir-listwrap.open .dir-toggle::after{content:" ↑"}
@media(max-width:820px){.dir-list{columns:2}}
@media(max-width:520px){.dir-list{columns:1}.dir-banner h2{font-size:1.25rem}}

/* ---------- suositut tekijät / avoimet työt (live-data SEO-sivuilla) ---------- */
.live-sec{margin:2.2rem 0}
.live-sec h2{margin-bottom:1rem}
.worker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.wcard{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s,border-color .15s}
.wcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--blue-100)}
.wc-top{display:flex;align-items:center;gap:.7rem;margin-bottom:.6rem}
.wc-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue-600),var(--blue-900));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;flex:0 0 auto;background-size:cover;background-position:center}
.wc-name{font-weight:700;font-size:1.02rem}
.wc-stars{font-size:.86rem;color:var(--star);font-weight:600}
.wc-stars span{color:var(--mut);font-weight:500}
.wc-meta{font-size:.86rem;color:var(--slate)}
.wc-tags{margin-top:.5rem;display:flex;gap:.3rem;flex-wrap:wrap}
.wc-tag{font-size:.68rem;font-weight:600;background:var(--blue-050);color:var(--blue);border-radius:99px;padding:.15rem .5rem}
.wcard.more,.jcard.more{display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--blue);background:var(--blue-050);border-color:var(--blue-100)}
.job-list{display:flex;flex-direction:column;gap:10px}
.jcard{display:flex;justify-content:space-between;align-items:center;gap:1rem;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 18px;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}
.jcard:hover{border-color:var(--blue-100);box-shadow:var(--shadow-md)}
.jc-title{font-weight:700}
.jc-meta{font-size:.86rem;color:var(--mut)}
.jc-price{font-weight:800;color:var(--blue);white-space:nowrap}
.jc-price small{font-weight:600;color:var(--mut);font-size:.78rem}

/* ---------- SEO landing page ---------- */
.seo-hero{position:relative;min-height:340px;display:flex;align-items:flex-end;background-size:cover;background-position:center;color:#fff}
.seo-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,35,80,.45),rgba(12,35,80,.82))}
.seo-hero .wrap{position:relative;z-index:1;padding-top:60px;padding-bottom:44px}
.seo-hero .eyebrow{color:#9fc0ff}
.seo-hero h1{color:#fff;max-width:18ch;margin:.7rem 0 1rem}
.seo-hero p{color:#dce7ff;max-width:52ch;font-size:1.12rem}
.seo-body{max-width:780px}
.seo-body h2{margin:2rem 0 .9rem}
.seo-body p{color:var(--slate);font-size:1.06rem;margin-bottom:1rem}
.seo-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow-sm);margin:1.4rem 0}
.seo-price{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap}
.seo-price .num{font-size:2.2rem;font-weight:800;color:var(--blue)}
.seo-price .lbl{color:var(--mut);font-size:.95rem}
.seo-rel{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.6rem}
.seo-rel a{font-size:.9rem;font-weight:600;background:var(--blue-050);color:var(--blue);border:1px solid var(--blue-100);border-radius:99px;padding:.35rem .8rem}
.seo-rel a:hover{background:var(--blue-100)}
.faq{border:1px solid var(--line);border-radius:12px;margin-bottom:.7rem;background:#fff;overflow:hidden}
.faq summary{padding:1rem 1.2rem;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--blue);font-weight:800}
.faq[open] summary::after{content:"–"}
.faq .a{padding:0 1.2rem 1.1rem;color:var(--slate)}

/* ---------- subpage hero taustateema ---------- */
.subhero{position:relative;overflow:hidden}
.subhero::before{content:"";position:absolute;inset:0;z-index:0;
  background-image:radial-gradient(circle at 1px 1px,var(--blue-100) 1px,transparent 0);
  background-size:24px 24px;opacity:.5;
  -webkit-mask-image:radial-gradient(70% 70% at 50% 30%,#000,transparent);mask-image:radial-gradient(70% 70% at 50% 30%,#000,transparent)}
.subhero .wrap{position:relative;z-index:1}

/* draft banner */
.draft{background:#0c1730;color:#9fc0ff;text-align:center;font-size:.75rem;padding:6px;letter-spacing:.02em}

/* reduced motion */
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}
