/* Talmidim Tuki ry — shared styles */

:root{
  --purple:#A613C4;
  --purple-deep:#5B0E73;
  --purple-100:#F8EBFD;
  --purple-200:#EBD5F5;
  --purple-300:#D9B0EC;
  --lavender-text:#F4D9FB;
  --gold:#C9A961;
  --ink:#1F1A24;
  --ink-soft:#4A4452;
  --ink-mute:#6E6678;
  --bg:#FCFAFD;
  --card:#FFFFFF;
  --rule:#EAE0F0;
  --max:1140px;
  --radius:14px;
  --shadow:0 6px 24px -10px rgba(91,14,115,.18);
  --shadow-lg:0 16px 48px -16px rgba(91,14,115,.28);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:var(--purple-deep);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s}
a:hover{border-bottom-color:var(--purple-deep)}
img,svg{display:block;max-width:100%}
section{padding:80px 24px}
.wrap{max-width:var(--max);margin:0 auto}
h1,h2,h3,h4{font-weight:700;letter-spacing:-.01em;color:var(--ink);margin:0}
h1{font-size:clamp(38px,5.5vw,60px);line-height:1.05;letter-spacing:-.02em}
h2{font-size:clamp(28px,3.4vw,40px);line-height:1.15;margin-bottom:18px}
h3{font-size:20px;line-height:1.3;margin-bottom:8px}
p{margin:0 0 14px;color:var(--ink-soft);font-size:17px;line-height:1.65}
.eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--purple);margin-bottom:14px}

/* Header */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(252,250,253,.86);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--rule);
}
.nav{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;gap:16px;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--ink)}
.brand:hover{border-bottom:none}
.brand-mark{width:38px;height:38px;display:grid;place-items:center;flex:none}
.brand-mark img{width:100%;height:100%;object-fit:contain}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text small{font-size:11px;color:var(--ink-mute);font-weight:500;letter-spacing:.04em}
.nav-links{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.nav-links a:not(.btn){color:var(--ink-soft);font-size:14.5px;font-weight:500;border-bottom:none}
.nav-links a:not(.btn):hover{color:var(--purple-deep)}
.nav-links a.current{color:var(--purple-deep);font-weight:600}
.lang-toggle{
  display:inline-flex;border:1px solid var(--rule);border-radius:999px;padding:3px;background:#fff;
}
.lang-toggle button{
  appearance:none;border:0;background:transparent;
  font:600 12px/1 -apple-system,BlinkMacSystemFont,sans-serif;
  letter-spacing:.05em;color:var(--ink-mute);
  padding:7px 12px;border-radius:999px;cursor:pointer;
}
.lang-toggle button.active{background:var(--purple);color:#fff}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--purple);color:#fff !important;
  border:0;font:600 14.5px/1 -apple-system,BlinkMacSystemFont,sans-serif;
  padding:12px 18px;border-radius:999px;cursor:pointer;
  transition:transform .12s ease, box-shadow .15s ease, background .15s, border-color .15s;
  box-shadow:0 4px 12px -4px rgba(166,19,196,.5);
  text-decoration:none;
}
/* Override the global a:hover underline for buttons */
a.btn,a.btn:hover{border-bottom:0 !important}
.btn:hover{background:var(--purple-deep);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn.ghost{background:transparent;color:var(--purple-deep) !important;border:1.5px solid var(--purple-deep) !important;box-shadow:none}
.btn.ghost:hover{background:var(--purple-deep);color:#fff !important;border-color:var(--purple-deep) !important}
.btn.dark{background:var(--purple-deep)}
.btn.dark:hover{background:#3F0850}

/* Hero */
.hero{
  position:relative;overflow:hidden;
  padding:100px 24px 90px;
  background:
    radial-gradient(1200px 500px at 80% -10%, rgba(166,19,196,.18), transparent 60%),
    radial-gradient(800px 400px at 0% 100%, rgba(91,14,115,.14), transparent 60%),
    var(--bg);
}
.hero .wrap{display:grid;grid-template-columns:1.2fr .9fr;gap:64px;align-items:center}
.hero h1 span{color:var(--purple)}
.hero p.lead{font-size:19px;color:var(--ink-soft);max-width:540px;margin:18px 0 28px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-visual{
  background:linear-gradient(160deg,var(--purple-100) 0%,#fff 100%);
  border-radius:24px;padding:32px;text-align:center;
  border:1px solid var(--rule);
}
.hero-visual .big-mark{
  width:200px;height:200px;display:grid;place-items:center;margin:0 auto 20px;
}
.hero-visual .big-mark img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 16px 32px rgba(91,14,115,.22))}
.hero-visual h3{color:var(--purple-deep);margin-bottom:6px}
.hero-visual p{margin:0;font-size:15px}

/* Photo / illustration containers */
.media{
  border-radius:20px;overflow:hidden;background:var(--purple-100);
  position:relative;box-shadow:var(--shadow);
  aspect-ratio:4/3;
}
.media img{width:100%;height:100%;object-fit:cover;display:block}
.media.tall{aspect-ratio:3/4}
.media.square{aspect-ratio:1/1}
.media.wide{aspect-ratio:16/9}

/* Image caption underneath */
.media-cap{
  font-size:13.5px;color:var(--ink-mute);margin-top:10px;text-align:center;
}

/* Inline media inside the dark Nemes Fund card */
.fund{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:center;padding:40px}
.fund .fund-text{position:relative;z-index:1}
.fund .fund-media{
  border-radius:14px;overflow:hidden;aspect-ratio:1/1;
  background:#0F0418;box-shadow:0 12px 32px -10px rgba(0,0,0,.4);
}
.fund .fund-media img{width:100%;height:100%;object-fit:cover}

/* Stacked dual-image layout for school activities side */
.media-stack{display:grid;gap:14px}
.media-stack .media{aspect-ratio:16/9}

/* Responsive image overrides */
@media (max-width:880px){
  .fund{grid-template-columns:1fr;padding:32px}
}

/* Page header (for non-home pages) */
.pagehead{
  padding:70px 24px 50px;
  background:linear-gradient(180deg,var(--purple-100) 0%,var(--bg) 100%);
  border-bottom:1px solid var(--rule);
}
.pagehead .wrap{max-width:760px;text-align:center}
.pagehead h1{font-size:clamp(34px,4.5vw,52px)}
.pagehead p{font-size:18px;margin-top:14px;color:var(--ink-soft)}

/* Pillars / cards grid */
.pillars{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;
}
.pillar{
  background:var(--card);border-radius:var(--radius);
  padding:28px;border:1px solid var(--rule);
}
.pillar .icon{
  width:44px;height:44px;border-radius:10px;
  background:var(--purple-100);color:var(--purple-deep);
  display:grid;place-items:center;margin-bottom:14px;
}
.pillar h3{margin-bottom:6px}
.pillar p{margin:0;font-size:15px}

/* Two-column layout */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.two-col.center{align-items:center}

/* Quote */
.quote{
  border-left:3px solid var(--purple);
  padding:8px 0 8px 22px;font-style:italic;color:var(--purple-deep);
  font-size:18px;margin-top:18px;
}

/* Activities list */
.activities-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
.activity{
  background:var(--card);border:1px solid var(--rule);
  border-radius:12px;padding:16px;
  display:flex;gap:12px;align-items:flex-start;
}
.activity .dot{
  width:8px;height:8px;border-radius:50%;background:var(--purple);
  margin-top:7px;flex:none;
}
.activity span{font-weight:600;color:var(--ink);font-size:14.5px;line-height:1.4}

/* Fund highlight */
.fund{
  background:linear-gradient(135deg,var(--purple-deep) 0%,#3F0850 100%);
  color:#fff;border-radius:24px;padding:48px;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-lg);margin-top:48px;
}
.fund::before{
  content:"";position:absolute;top:0;left:0;width:60px;height:4px;background:var(--gold);
}
.fund .label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:12px;display:block}
.fund h3{color:#fff;font-size:28px;margin-bottom:14px}
.fund p{color:var(--lavender-text);font-size:17px;margin:0;max-width:680px}

/* Membership tiers */
.tiers{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}
.tier{
  background:#fff;border:2px solid var(--rule);border-radius:18px;
  padding:32px;position:relative;
}
.tier.primary{border-color:var(--purple);background:linear-gradient(180deg,#fff,var(--purple-100))}
.tier .label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--purple);font-weight:700}
.tier .price{font-size:42px;font-weight:800;color:var(--ink);margin:6px 0 4px;letter-spacing:-.02em}
.tier .per{color:var(--ink-mute);font-size:14px;margin-bottom:18px}
.tier ul{list-style:none;padding:0;margin:0 0 22px}
.tier li{padding:6px 0 6px 26px;position:relative;color:var(--ink-soft);font-size:15px}
.tier li::before{
  content:"";position:absolute;left:6px;top:13px;width:8px;height:4px;
  border-left:2px solid var(--purple);border-bottom:2px solid var(--purple);
  transform:rotate(-45deg);
}

/* Membership IBAN card (membership fee context only) */
.fee-card{
  background:linear-gradient(135deg,var(--purple) 0%,var(--purple-deep) 100%);
  color:#fff;border-radius:20px;padding:36px;
  display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:center;
  margin-top:40px;box-shadow:var(--shadow-lg);
}
.fee-card h3{color:#fff;font-size:22px;margin-bottom:8px}
.fee-card p{color:var(--lavender-text);margin:0;font-size:15.5px}
.fee-card .iban-box{background:rgba(255,255,255,.12);border-radius:12px;padding:18px}
.fee-card .iban-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--lavender-text);font-weight:700;margin-bottom:6px}
.fee-card .iban-num{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:18px;font-weight:700;letter-spacing:.04em}
.fee-card .iban-meta{font-size:12.5px;color:var(--lavender-text);margin-top:10px}
.fee-card .iban-meta div{padding:2px 0}
.fee-card .copy-btn{
  appearance:none;background:rgba(255,255,255,.18);
  color:#fff;border:0;padding:8px 12px;border-radius:8px;
  font:600 12px/1 -apple-system,sans-serif;cursor:pointer;margin-top:12px;
}
.fee-card .copy-btn:hover{background:rgba(255,255,255,.3)}

/* Steps (how to join) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.step{
  background:var(--card);border:1px solid var(--rule);border-radius:14px;padding:24px;
  position:relative;
}
.step .num{
  width:32px;height:32px;border-radius:50%;background:var(--purple);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:14px;margin-bottom:12px;
}
.step h3{font-size:17px;margin-bottom:6px}
.step p{font-size:14.5px;margin:0}

/* FAQ */
.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:32px}
.faq-item{background:#fff;border:1px solid var(--rule);border-radius:12px;padding:22px}
.faq-item h4{font-size:16px;color:var(--ink);margin-bottom:8px}
.faq-item p{font-size:14.5px;margin:0}

/* Contact card */
.contact-card{background:var(--purple-100);border-radius:18px;padding:32px}
.contact-row{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.contact-row:last-child{border-bottom:none}
.contact-row .ic{
  width:36px;height:36px;border-radius:10px;
  background:#fff;color:var(--purple-deep);
  display:grid;place-items:center;flex:none;
}
.contact-row .meta{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--purple);font-weight:700}
.contact-row .val{font-size:16px;font-weight:600;color:var(--ink)}

/* Forms (Netlify-hosted) */
.form{
  display:grid;gap:18px;max-width:580px;
  background:#fff;border:1px solid var(--rule);border-radius:18px;
  padding:32px;box-shadow:var(--shadow);
}
.form h3{margin-bottom:6px}
.form .form-row{display:grid;gap:6px}
.form .form-row.two{grid-template-columns:1fr 1fr;gap:14px}
.form label.field{display:grid;gap:6px}
.form label.field > span:first-child{
  font-size:13px;font-weight:600;color:var(--ink);letter-spacing:.01em;
}
.form label.field > span .opt{color:var(--ink-mute);font-weight:500;font-size:12px;margin-left:4px}
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form select,
.form textarea{
  font:400 15px/1.45 inherit;
  color:var(--ink);background:#fff;
  border:1.5px solid var(--rule);border-radius:10px;
  padding:11px 14px;outline:none;
  transition:border-color .15s, box-shadow .15s;
  width:100%;
}
.form input:focus,
.form select:focus,
.form textarea:focus{
  border-color:var(--purple);
  box-shadow:0 0 0 3px rgba(166,19,196,.12);
}
.form textarea{resize:vertical;min-height:96px;font-family:inherit}
.form .radio-group{display:grid;gap:10px;margin:4px 0 0}
.form .radio{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;border:1.5px solid var(--rule);border-radius:12px;
  cursor:pointer;transition:border-color .15s, background .15s;
}
.form .radio:hover{border-color:var(--purple-300)}
.form .radio input{accent-color:var(--purple);width:18px;height:18px;flex:none;margin:0}
.form .radio:has(input:checked){border-color:var(--purple);background:var(--purple-100)}
.form .radio-text{display:flex;flex-direction:column;gap:2px}
.form .radio-text strong{color:var(--ink);font-size:15px}
.form .radio-text small{color:var(--ink-mute);font-size:13px}
.form .submit-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.form .form-note{font-size:13px;color:var(--ink-mute);margin:0}
.form button[type="submit"]{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--purple);color:#fff;
  border:0;font:600 15px/1 -apple-system,BlinkMacSystemFont,sans-serif;
  padding:14px 22px;border-radius:999px;cursor:pointer;
  box-shadow:0 4px 12px -4px rgba(166,19,196,.5);
  transition:transform .12s, background .15s;
}
.form button[type="submit"]:hover{background:var(--purple-deep);transform:translateY(-1px)}
.form .honeypot{position:absolute;left:-9999px;visibility:hidden}

@media (max-width:560px){
  .form{padding:24px}
  .form .form-row.two{grid-template-columns:1fr}
}

/* Section anchor padding so sticky header doesn't hide form when scrolled to */
[id="join-form"], [id="contact-form"]{scroll-margin-top:80px}

/* Compliance note */
.note{
  background:#fff;border:1px solid var(--rule);border-radius:12px;
  padding:18px 22px;margin-top:24px;
  font-size:14px;color:var(--ink-mute);line-height:1.5;
}
.note strong{color:var(--ink)}

/* Footer */
footer{background:var(--purple-deep);color:var(--lavender-text);padding:60px 24px 30px}
footer .wrap{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px}
footer h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
footer a{color:var(--lavender-text);display:block;padding:4px 0;font-size:14.5px;border-bottom:none}
footer a:hover{color:#fff}
footer .brand{color:#fff}
footer .legal{
  border-top:1px solid rgba(255,255,255,.12);
  margin-top:40px;padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:13px;color:rgba(244,217,251,.7);
}

/* Toggle hide/show */
[data-lang="en"] [lang="fi"]{display:none}
[data-lang="fi"] [lang="en"]{display:none}

/* Toast */
.copied{
  position:fixed;left:50%;bottom:30px;transform:translateX(-50%);
  background:var(--ink);color:#fff;padding:10px 18px;border-radius:999px;
  font-size:14px;font-weight:600;
  opacity:0;transition:opacity .2s;z-index:100;pointer-events:none;
}
.copied.show{opacity:1}

/* Responsive */
@media (max-width:880px){
  section{padding:60px 20px}
  .nav-links a:not(.btn):not(.lang-btn){display:none}
  .hero{padding:60px 20px 50px}
  .hero .wrap,.two-col{grid-template-columns:1fr;gap:36px}
  .pillars,.tiers,.activities-list,.faq-grid,.steps{grid-template-columns:1fr}
  .fee-card{grid-template-columns:1fr;padding:28px}
  footer .wrap{grid-template-columns:1fr;gap:24px}
  h1{font-size:34px}
  .pagehead{padding:48px 20px 36px}
}
