/* Taikkari — Sisko Miettinen, taidepsykoterapia
   Clean hand-written stylesheet. Calm therapy aesthetic.
   Palette: deep teal #205b4f, soft mint #d9e8e5, warm clay #cba590 */

:root{
  --teal:#205b4f;
  --teal-dark:#16433a;
  --mint:#d9e8e5;
  --mint-soft:#eef5f3;
  --clay:#cba590;
  --ink:#21302c;
  --muted:#5d6e69;
  --line:#dfe7e4;
  --bg:#fbfcfb;
  --white:#ffffff;
  --radius:14px;
  --shadow:0 10px 30px rgba(22,67,58,.08);
  --maxw:1080px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden;max-width:100%}
h1,h2,h3{overflow-wrap:break-word;hyphens:auto}
body{
  margin:0;
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Crimson Text',Georgia,serif;font-weight:600;line-height:1.2;color:var(--teal-dark);margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5vw,3.3rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.3rem);margin-top:0}
h3{font-size:1.35rem;color:var(--teal)}
p{margin:0 0 1.1em}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,252,251,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;flex-direction:column;line-height:1.15}
.brand b{font-family:'Crimson Text',serif;font-size:1.4rem;color:var(--teal-dark);font-weight:600}
.brand span{font-size:.78rem;color:var(--muted);letter-spacing:.3px}
.nav-links{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.nav-links a{padding:8px 14px;border-radius:999px;font-size:.95rem;color:var(--ink)}
.nav-links a:hover{background:var(--mint);text-decoration:none}
.nav-links a.active{background:var(--teal);color:#fff}
.nav-cta{background:var(--teal);color:#fff !important;padding:9px 18px !important}
.nav-cta:hover{background:var(--teal-dark) !important}
.menu-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--teal-dark)}

/* ---------- Buttons ---------- */
.btn{display:inline-block;background:var(--teal);color:#fff;padding:13px 28px;border-radius:999px;font-weight:600;font-size:1rem;border:0;cursor:pointer;transition:background .2s,transform .2s}
.btn:hover{background:var(--teal-dark);text-decoration:none;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--teal);border:1.5px solid var(--teal)}
.btn-outline:hover{background:var(--teal);color:#fff}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(22,67,58,.82),rgba(32,91,79,.55))}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:110px 24px 96px}
.hero h1{color:#fff;max-width:18ch}
.hero p.lead{font-size:1.2rem;max-width:46ch;color:#eaf4f1;margin-bottom:1.8em}
.hero .btn{background:#fff;color:var(--teal-dark)}
.hero .btn:hover{background:var(--mint)}

/* ---------- Sections ---------- */
section{padding:64px 0}
.section-soft{background:var(--mint-soft)}
.section-mint{background:var(--mint)}
.eyebrow{text-transform:uppercase;letter-spacing:2px;font-size:.78rem;font-weight:700;color:var(--clay);margin-bottom:.6em}
.lead{font-size:1.12rem;color:var(--muted)}
.center{text-align:center}
.narrow{max-width:760px;margin-left:auto;margin-right:auto}

/* two-column feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:100%;max-height:460px;object-fit:cover}
.split.reverse .split-media{order:2}

/* quote / blockquote */
.pull{border-left:4px solid var(--clay);padding:6px 0 6px 24px;font-family:'Crimson Text',serif;font-size:1.35rem;color:var(--teal-dark);font-style:italic}
.pull cite{display:block;font-size:.85rem;font-style:normal;color:var(--muted);margin-top:.6em;font-family:'Plus Jakarta Sans',sans-serif}

/* numbered process cards */
.steps{display:grid;gap:24px;margin-top:32px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 30px;box-shadow:var(--shadow)}
.step .num{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--mint);color:var(--teal-dark);font-family:'Crimson Text',serif;font-size:1.3rem;font-weight:600;margin-bottom:12px}

/* generic card grid */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.card h3{margin-top:0}

/* lists */
.tidy-list{list-style:none;padding:0;margin:0}
.tidy-list li{padding:10px 0 10px 30px;position:relative;border-bottom:1px solid var(--line)}
.tidy-list li:last-child{border-bottom:0}
.tidy-list li::before{content:"";position:absolute;left:4px;top:18px;width:10px;height:10px;border-radius:50%;background:var(--clay)}

/* ethics / fine list */
.check-list{list-style:none;padding:0;margin:0}
.check-list li{padding:8px 0 8px 30px;position:relative;color:var(--ink)}
.check-list li::before{content:"\2713";position:absolute;left:0;top:8px;color:var(--teal);font-weight:700}

/* small decorative image accents */
.accent-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-top:30px}
.accent-row img{border-radius:10px;width:100%;height:160px;object-fit:cover;box-shadow:var(--shadow)}
.accent-single{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:240px;object-fit:cover}

/* decorative full-width image band */
.band{position:relative;height:340px;background-size:cover;background-position:center;background-attachment:fixed}
.band.short{height:220px}
@media(max-width:820px){.band{background-attachment:scroll;height:240px}}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.gallery figure{margin:0}
.gallery img{border-radius:10px;width:100%;height:220px;object-fit:cover;box-shadow:var(--shadow)}
.gallery figcaption{font-size:.82rem;color:var(--muted);margin-top:6px}

/* info / contact strip */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:32px}
.info-grid h3{display:flex;align-items:center;gap:8px}

/* form */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);max-width:560px}
.form-card label{display:block;font-weight:600;font-size:.92rem;margin:14px 0 6px;color:var(--teal-dark)}
.form-card input,.form-card textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font:inherit;background:var(--bg)}
.form-card input:focus,.form-card textarea:focus{outline:2px solid var(--mint);border-color:var(--teal)}
.form-card .btn{margin-top:20px}
.form-note{font-size:.85rem;color:var(--muted);margin-top:14px}

/* portrait */
.portrait{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:380px;object-fit:cover}

/* accessibility callout */
.callout{background:#fff;border:1px solid var(--line);border-left:4px solid var(--teal);border-radius:var(--radius);padding:26px 30px;box-shadow:var(--shadow)}

/* ---------- Footer ---------- */
.site-footer{background:var(--teal-dark);color:#dceae6;padding:54px 0 28px;margin-top:0}
.site-footer h4{color:#fff;font-size:1.25rem;margin-bottom:.6em}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px}
.site-footer a{color:#bcdcd4}
.site-footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);margin-top:36px;padding-top:18px;font-size:.85rem;color:#9fc1ba;text-align:center}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:8px}

/* skip link */
.skip{position:absolute;left:-999px;top:0;background:#fff;padding:10px 16px;z-index:100}
.skip:focus{left:8px;top:8px}

/* ---------- Responsive ---------- */
@media(max-width:820px){
  .split{grid-template-columns:1fr;gap:28px}
  .split.reverse .split-media{order:0}
  /* never let a stacked image column 'stick' on mobile */
  .split-media{position:static !important;top:auto !important}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .menu-toggle{display:block}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;
    background:var(--white);border-bottom:1px solid var(--line);
    padding:10px 18px 18px;display:none;box-shadow:var(--shadow)
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 10px}
  /* nav cta should not look squeezed in the dropdown */
  .nav-cta{text-align:center}
}

/* phone-specific tightening */
@media(max-width:560px){
  body{font-size:16px}
  .hero-inner{padding:72px 20px 56px}
  section{padding:44px 0}
  .container{padding:0 18px}
  .step{padding:22px 20px}
  .callout{padding:22px 20px}
  .form-card{padding:24px 20px}
  .accent-single{height:200px !important}
  .accent-row img{height:140px}
  /* two stacked ethics images side-by-side instead on small to save vertical space? keep stacked, but cap height */
  .split-media .portrait{max-width:100%}
}
