
:root{--bg:#fbf9fd;--surface:#ffffff;--surface-soft:#faf7fd;--text:#241a32;--muted:#655a72;--line:#e6dfed;--primary:#652d90;--primary-dark:#4d236e;--accent:#51b86f;--shadow:0 14px 34px rgba(58,32,85,.08);--radius-lg:24px;--container:1120px;--header-h:84px}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--text);background:radial-gradient(circle at top left,rgba(101,45,144,.06),transparent 26%),radial-gradient(circle at top right,rgba(81,184,111,.07),transparent 24%),var(--bg);line-height:1.6}
img{display:block;max-width:100%} a{color:inherit;text-decoration:none}
.container{width:min(var(--container),calc(100% - 32px));margin:0 auto}
.skip-link{position:absolute;left:-9999px;top:auto}.skip-link:focus{left:16px;top:16px;z-index:100;padding:10px 14px;background:#fff;border-radius:12px;border:1px solid var(--line)}
.site-header{position:sticky;top:0;z-index:30;background:rgba(251,249,253,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-shell{min-height:var(--header-h);display:flex;align-items:center;justify-content:space-between;gap:24px;position:relative}
.brand img{width:260px;max-width:100%;height:auto}
.nav-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;border:1px solid var(--line);background:#fff;cursor:pointer}
.nav-toggle span,.nav-toggle span:before,.nav-toggle span:after{display:block;width:18px;height:2px;background:var(--primary);position:relative;border-radius:2px;content:""}
.nav-toggle span:before{position:absolute;top:-6px}.nav-toggle span:after{position:absolute;top:6px}
.nav-links{display:flex;align-items:center;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.96rem}.nav-links a{padding:8px 0;position:relative}.nav-links a:hover,.nav-links a:focus-visible,.nav-links a.active{color:var(--primary)}.nav-links a.active:after{content:"";position:absolute;left:0;right:0;bottom:-12px;height:2px;background:var(--primary)}
.hero{padding:56px 0 88px}.page-hero{padding:40px 0 52px}.page-hero .lead{max-width:70ch}
.hero-grid,.two-col,.cards-2,.cards-3,.contact-grid,.image-pair,.section-head{display:grid;gap:24px}.hero-grid{grid-template-columns:1.05fr .95fr;align-items:center}.two-col{grid-template-columns:.95fr 1.05fr;align-items:start}.cards-2,.contact-grid{grid-template-columns:1fr 1fr}.image-pair{grid-template-columns:1fr}.cards-3{grid-template-columns:repeat(3,minmax(0,1fr))}.section-head{grid-template-columns:.92fr 1.08fr;align-items:end;margin-bottom:32px}
.eyebrow{display:inline-block;margin-bottom:18px;color:var(--primary);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:.88rem}
h1,h2,h3{margin:0 0 14px;line-height:1.08;letter-spacing:-.03em} h1{font-size:clamp(2.8rem,5.8vw,5rem);max-width:11ch} h2{font-size:clamp(2rem,4vw,3.15rem)} h3{font-size:1.24rem}
p{margin:0 0 16px;color:var(--muted);font-size:1.04rem}.lead{color:var(--text);font-size:1.16rem;max-width:60ch}
.section{padding:88px 0}.section.alt{background:rgba(255,255,255,.74);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.card,.image-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.card{padding:26px}.card.soft{background:var(--surface-soft)}.image-card{overflow:hidden}.image-card img{width:100%;height:100%;object-fit:cover}.hero-visual{position:relative}.hero-visual .image-card{aspect-ratio:4/4.4}
.hero-note{position:absolute;left:20px;bottom:20px;max-width:320px;padding:12px 14px;border-radius:14px;background:rgba(36,26,50,.7);color:#fff;font-size:.94rem}
.button-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:0 22px;border-radius:999px;font-weight:700;border:1px solid transparent;transition:transform .2s ease}.btn:hover{transform:translateY(-1px)}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff}.btn.secondary{background:#fff;border-color:var(--line)}
.mini{color:var(--primary);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;margin-bottom:12px}.kicker{display:inline-block;padding:7px 12px;border-radius:999px;background:rgba(101,45,144,.08);color:var(--primary);font-size:.92rem;font-weight:700;margin-bottom:14px}
.list-clean{margin:0;padding-left:18px;color:var(--muted)} .list-clean li + li{margin-top:10px} .teaser-link{display:inline-flex;align-items:center;gap:8px;margin-top:10px;color:var(--primary);font-weight:700}
.quote{font-size:1.24rem;color:var(--text);line-height:1.45}
.contact-list{display:grid;gap:14px}.contact-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px}.label{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);font-weight:800;margin-bottom:4px}
.note{padding:16px 18px;border-radius:16px;background:rgba(81,184,111,.08);border:1px solid rgba(81,184,111,.2);color:var(--text)}
.footer{padding:28px 0 48px;color:var(--muted);font-size:.92rem}.footer-line{border-top:1px solid var(--line);padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
@media (max-width:980px){.hero-grid,.two-col,.cards-2,.cards-3,.contact-grid,.image-pair,.section-head{grid-template-columns:1fr}.hero h1{max-width:100%}.hero-visual .image-card{aspect-ratio:16/11}}
@media (max-width:760px){:root{--header-h:72px}.brand img{width:198px}.nav-toggle{display:inline-flex}.nav-shell{padding:12px 0}.nav-links{position:absolute;left:16px;right:16px;top:calc(100% + 8px);background:rgba(255,255,255,.98);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:14px 16px;display:none;flex-direction:column;align-items:flex-start;gap:4px}.nav-links.open{display:flex}.nav-links a{width:100%;padding:10px 0}.nav-links a.active:after{display:none}.section,.hero{padding:64px 0}.card{padding:22px}h1{font-size:clamp(2.3rem,10vw,3.6rem)}h2{font-size:clamp(1.8rem,8vw,2.5rem)}}

.figure{margin:0}.figure figcaption{padding:10px 14px;color:var(--muted);font-size:.92rem;border-top:1px solid var(--line);background:rgba(255,255,255,.88)}
.legal-card h3{margin-bottom:12px}.legal-card p:last-child{margin-bottom:0}

.form-card{padding:28px}
.contact-form{display:grid;gap:16px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:grid;gap:8px}
.field label{font-weight:700;color:var(--text)}
.field small{color:var(--muted);font-size:.92rem}
.input,.textarea{width:100%;border:1px solid var(--line);border-radius:14px;background:#fff;padding:14px 16px;font:inherit;color:var(--text)}
.input:focus,.textarea:focus{outline:2px solid rgba(101,45,144,.12);border-color:var(--primary)}
.textarea{min-height:180px;resize:vertical}
.checkbox-row{display:flex;align-items:flex-start;gap:12px;color:var(--muted);font-size:.96rem}
.checkbox-row input{margin-top:4px}
.form-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.status{padding:14px 16px;border-radius:14px;font-weight:600}
.status.ok{background:rgba(81,184,111,.12);border:1px solid rgba(81,184,111,.32);color:#174f29}
.status.error{background:rgba(101,45,144,.08);border:1px solid rgba(101,45,144,.22);color:var(--primary-dark)}
.hp{position:absolute;left:-9999px;opacity:0;pointer-events:none}
@media (max-width:760px){.form-grid{grid-template-columns:1fr}.form-card{padding:22px}}

.cert-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.cert-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.cert-thumb{display:block;background:#fff;border-bottom:1px solid var(--line)}
.cert-thumb img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:top center}
.cert-body{padding:20px 22px 24px}
.cert-body h3{margin-bottom:10px}
@media (max-width:980px){.cert-grid{grid-template-columns:1fr 1fr}}
@media (max-width:760px){.cert-grid{grid-template-columns:1fr}.cert-body{padding:18px 20px 22px}}


.portrait-narrow{max-width:420px;justify-self:center}
.speaking-narrow{max-width:480px;justify-self:center}
.portrait-narrow img{aspect-ratio:4/5;object-position:center 18%}
.speaking-narrow img{aspect-ratio:4/5;object-position:center top}
@media (max-width:980px){.portrait-narrow,.speaking-narrow{max-width:100%}}


.banner-hero{
  position:relative;
  background:
    linear-gradient(rgba(251,249,253,.86), rgba(251,249,253,.92)),
    url("../img/banner.jpg?v=2") center/cover no-repeat;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line)
}
.banner-hero .container{padding-top:8px;padding-bottom:8px}
.full-width-figure{max-width:920px;margin:0 auto}
.full-width-figure img{width:100%;aspect-ratio:16/8;object-fit:cover;object-position:center center}


.image-single{max-width:920px;margin:0 auto}
.image-single img{width:100%;aspect-ratio:16/10;object-fit:cover;object-position:center center}
.collaboration-card{max-width:560px;justify-self:center}
.collaboration-card img{aspect-ratio:4/5;object-position:center center}
.feature-list{display:grid;gap:18px}
.feature-note{max-width:760px}
.cert-grid.compact{grid-template-columns:repeat(4,minmax(0,1fr))}
.key-lines{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:1fr;gap:24px;align-items:stretch}
.key-lines .card{height:100%;display:flex;flex-direction:column;justify-content:flex-start}
.key-lines .card h3{margin-bottom:10px}
.inline-note{font-size:.95rem;color:var(--muted)}
@media (max-width:1100px){.cert-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){.key-lines{grid-template-columns:1fr;grid-auto-rows:auto}.cert-grid.compact{grid-template-columns:1fr}}


/* scroll-reveal */
.site-header.is-condensed{background:rgba(251,249,253,.96);box-shadow:0 10px 24px rgba(58,32,85,.06)}
.card,.image-wrap,.section-head,.hero-grid > div,.page-hero .container > *{transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,opacity .55s ease}
.card:hover,.image-wrap:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(58,32,85,.10)}
.reveal-ready{opacity:0;transform:translateY(18px)}
.reveal-in{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.06s}.reveal-delay-2{transition-delay:.12s}.reveal-delay-3{transition-delay:.18s}.reveal-delay-4{transition-delay:.24s}
.hero .image-wrap img,.banner-hero{transition:transform .8s ease,filter .8s ease}
.hero .image-wrap:hover img,.banner-hero:hover{transform:scale(1.01)}
.teaser-link,.btn{transition:transform .18s ease,color .18s ease}
.teaser-link:hover,.btn:hover{transform:translateY(-1px)}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{animation:none !important;transition:none !important}
  .reveal-ready{opacity:1 !important;transform:none !important}
}


/* robustness against narrow screens and cached old layouts */
.two-col > *, .cards-2 > *, .cards-3 > *, .contact-grid > *, .key-lines > *, .cert-grid > *, .section-head > *{min-width:0}
.card h3, .card p, .cert-body h3, .cert-body p, .section-head p, .lead, .feature-note, .figure figcaption, .contact-item, .list-clean li{overflow-wrap:break-word}
@media (max-width:900px){.cert-grid.compact{grid-template-columns:1fr 1fr}}
.card p,.cert-body p,.lead,.feature-note{font-size:.98rem;line-height:1.55}
  .mini{font-size:.76rem}
  .section-head{margin-bottom:22px}
}



/* Final stable 2x2 grid for learning anchors */
.anchor-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:24px;
  align-items:stretch;
}
.anchor-grid > .card,
.anchor-grid > article,
.anchor-grid > .info-card{
  min-width:0;
  height:100%;
}
.anchor-grid .card h3,
.anchor-grid article h3,
.anchor-grid .info-card h3{
  overflow-wrap:anywhere;
  word-break:normal;
}
@media (max-width: 760px){
  .anchor-grid{
    grid-template-columns:1fr;
  }
}


/* Final hard override: learning anchors must stay 2x2 */
.key-lines{
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  grid-auto-rows:1fr !important;
  gap:24px !important;
  align-items:stretch !important;
}
.key-lines > *{
  min-width:0;
  height:100%;
}
.key-lines .card{
  height:100%;
  display:flex;
  flex-direction:column;
}
.key-lines .card h3,
.key-lines .card p{
  overflow-wrap:anywhere;
}
@media (max-width:760px){
  .key-lines{
    grid-template-columns:1fr !important;
    grid-auto-rows:auto !important;
    gap:16px !important;
  }
}
