/* Dr. Malvika Iyer — one-page landing site · Lilac / pastel edition */
:root{
  --bg:#FCF8FB; --bg2:#F3E9F3;
  --lilac:#7E3F96; --lilac-deep:#3D1F4E; --lilac-soft:#D3BBDF;
  --rose:#159E8A; --mint:#5FC6AE; --sky:#4FB3C0; --gold:#C5982B;
  --ink:#2B2034; --muted:#7C7186;
  --card:#FFFFFF;
  --t-lilac:#F1E8F5; --t-rose:#E2F4EF; --t-mint:#E6F6F0; --t-sky:#E6F3F5; --t-gold:#F7EED7;
  --shadow:0 18px 40px -22px rgba(61,31,78,.48);
  --shadow-sm:0 8px 22px -14px rgba(61,31,78,.42);
  --maxw:1080px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:32px}
@media(max-width:560px){html{scroll-padding-top:118px}}
body{
  font-family:'Lora',-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.display{font-family:'Playfair Display','Cormorant Garamond',Georgia,serif;font-weight:600;line-height:1.12;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-family:'Lora',sans-serif;font-weight:700;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--lilac)}
.section{padding:86px 0}
.section h2{font-size:clamp(1.9rem,3.6vw,2.9rem);margin:.35em 0 .15em}
.lead{color:var(--muted);font-size:1.05rem;max-width:620px}
.center{text-align:center}.center .lead{margin-inline:auto}

/* ---- top nav ---- */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(251,248,254,.82);border-bottom:1px solid #EFE6F8}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:64px;flex-wrap:wrap}
.brand{font-family:'Playfair Display',serif;font-weight:600;font-size:1.18rem;color:var(--lilac-deep);white-space:nowrap}
.brand span{color:inherit}
.brand{transition:opacity .35s ease, transform .35s ease}
@media(min-width:561px){ .nav.at-top .brand{opacity:0;transform:translateY(-4px);pointer-events:none} }
.nav nav{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.nav nav a{font-size:.9rem;color:var(--muted);font-weight:500;transition:color .2s;white-space:nowrap}
.nav nav a:hover{color:var(--lilac-deep)}
.nav .cta{background:var(--lilac);color:#fff;padding:8px 18px;border-radius:999px;font-size:.85rem;font-weight:600}
.nav .cta:hover{background:var(--lilac-deep);color:#fff}
@media(max-width:760px){
  .nav .wrap{flex-direction:column;align-items:center;gap:9px;padding-top:10px;padding-bottom:10px}
  .nav nav{gap:7px 13px;justify-content:center;flex-wrap:wrap;font-size:.78rem;width:100%}
  .nav .cta{flex-basis:100%;max-width:170px;margin:2px auto 0;text-align:center}
}
@media(max-width:380px){ .nav nav{font-size:.72rem;gap:6px 10px} }

/* ---- hero ---- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(60% 50% at 85% 12%,var(--t-rose),transparent 70%),
  radial-gradient(55% 50% at 8% 80%,var(--t-mint),transparent 70%),
  linear-gradient(180deg,#FDF9FC, #F1E7F2)}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;padding-top:74px;padding-bottom:84px}
.hero h1{font-size:clamp(2.6rem,6vw,4.3rem);margin:.18em 0 .26em}
.hero .sub{font-size:1.12rem;color:var(--lilac-deep);font-weight:500;margin-bottom:1.5em}
.hero .sub b{color:inherit;font-weight:inherit}
.btnrow{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;border-radius:999px;font-weight:600;font-size:.95rem;transition:transform .15s, box-shadow .2s}
.btn-primary{background:var(--lilac);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--lilac-deep);border:1.5px solid var(--lilac-soft)}
.btn-ghost:hover{border-color:var(--lilac)}
.hero-photo{position:relative;justify-self:center}
.hero-photo .carousel{position:relative;width:350px;height:460px;border-radius:120px 120px 24px 24px;
  border:8px solid #fff;box-shadow:var(--shadow);overflow:hidden;background:var(--t-lilac)}
.hero-photo .carousel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:center 25%;opacity:0;transition:opacity 1.1s ease}
.hero-photo .carousel img.active{opacity:1}
.hero-photo .carousel img[src*="hero16"]{object-position:60% center}
.hero-photo .blob{position:absolute;inset:auto;width:120px;height:120px;border-radius:50%;
  background:var(--t-gold);right:-26px;top:30px;z-index:-1}
.hero-photo .ring{position:absolute;width:90px;height:90px;border:3px dashed var(--lilac-soft);border-radius:50%;left:-34px;bottom:60px}
.ribbon{display:inline-block;margin-top:26px;background:#fff;color:var(--lilac-deep);font-style:italic;
  padding:10px 20px;border-radius:14px;font-size:.95rem;box-shadow:var(--shadow-sm);
  border:1px solid var(--lilac-soft);border-left:4px solid var(--lilac)}
@media(max-width:820px){.hero .wrap{grid-template-columns:1fr;text-align:center}
  .btnrow{justify-content:center}.hero-photo{order:-1}.hero-photo .carousel{width:270px;height:360px}}

/* hero entrance + scroll reveal */
@keyframes riseIn{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.hero .eyebrow,.hero h1,.hero .sub,.hero .btnrow,.hero .ribbon,.hero-photo{animation:riseIn .8s both}
.hero h1{animation-delay:.12s}.hero .sub{animation-delay:.26s}.hero .btnrow{animation-delay:.4s}
.hero .ribbon{animation-delay:.54s}.hero-photo{animation-duration:1s;animation-delay:.2s}
.js-reveal{opacity:0;transform:translateY(26px)}
.js-reveal.in{opacity:1;transform:none;transition:opacity .7s ease,transform .7s ease}
@media(prefers-reduced-motion:reduce){.hero .eyebrow,.hero h1,.hero .sub,.hero .btnrow,.hero .ribbon,.hero-photo{animation:none}.js-reveal{opacity:1;transform:none}}

/* ---- stats ---- */
.stats{background:var(--bg2);color:var(--ink)}
.stats .row{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;text-align:center}
.stats .stat{background:#fff;border:1px solid #EEE3F1;border-radius:18px;padding:26px 12px;
  box-shadow:var(--shadow-sm);transition:transform .2s, box-shadow .25s}
.stats .stat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.stat .num{font-family:'Playfair Display',serif;font-size:clamp(1.9rem,4vw,2.7rem);font-weight:700;
  font-variant-numeric:tabular-nums;line-height:1;color:var(--lilac)}
.stats .stat:nth-child(2) .num{color:var(--rose)}
.stats .stat:nth-child(3) .num{color:var(--gold)}
.stats .stat:nth-child(4) .num{color:var(--sky)}
.stats .stat:nth-child(5) .num{color:var(--lilac-deep)}
.stat .lbl{font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:8px}
@media(max-width:680px){.stats .row{grid-template-columns:repeat(2,1fr);gap:14px}
  .stats .stat:last-child:nth-child(odd){grid-column:1 / -1}}

/* ---- story ---- */
.story .wrap{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.story p{margin-bottom:1em;color:#473758}
.story .quote{margin-top:1.1em;padding-left:18px;border-left:3px solid var(--rose);font-style:italic;color:var(--lilac-deep)}
.story-photo img{width:100%;height:520px;object-fit:cover;object-position:top center;border-radius:26px;border:7px solid #fff;box-shadow:var(--shadow)}
@media(max-width:820px){.story .wrap{grid-template-columns:1fr;gap:34px}.story-photo img{height:420px}}

/* ---- honour cards ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px}
.card{background:var(--card);border-radius:16px;overflow:hidden;position:relative;
  box-shadow:var(--shadow-sm);border:1px solid #F0E8F8;transition:transform .18s,box-shadow .25s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ph{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:center 22%;display:block;background:var(--t-lilac)}
.card .ph.contain{object-fit:contain;object-position:center;background:#fff}
.card .ph[src*="hon_wef"]{object-position:88% center}
.card .ph-empty{background:linear-gradient(135deg,var(--lilac),var(--rose))}
.card .badge{position:absolute;left:11px;top:11px;width:34px;height:34px;border-radius:11px;
  display:grid;place-items:center;color:#fff;font-family:'Playfair Display',serif;font-weight:700;font-size:1rem;box-shadow:var(--shadow-sm)}
.card .body{padding:14px 16px}
.card h3{font-size:.98rem;line-height:1.25;margin-bottom:5px}
.card p{font-size:.84rem;color:var(--muted);line-height:1.45}
.card .more{display:inline-block;margin-top:9px;font-size:.8rem;font-weight:600;color:var(--lilac);font-family:'Lora',sans-serif}
.card a.more:hover{color:var(--lilac-deep)}
.card.c0 .badge{background:var(--lilac)}.card.c1 .badge{background:var(--rose)}
.card.c2 .badge{background:var(--mint)}.card.c3 .badge{background:var(--sky)}
@media(max-width:1000px){.cards{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.cards{grid-template-columns:repeat(2,1fr)}}

/* ---- awards: clean grid (all visible; hovered card pops, no dimming) ---- */
.awards-spot{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:40px}
.awards-spot .award{position:relative;background:#fff;border-radius:16px;overflow:hidden;
  border:1px solid #EFE6F6;box-shadow:var(--shadow-sm);text-align:left;
  transition:transform .32s cubic-bezier(.2,.7,.25,1),box-shadow .3s,border-color .3s}
.awards-spot .award .ph{width:100%;aspect-ratio:1/1;object-fit:contain;background:#FBF8FD;
  padding:12px;display:block;transition:transform .45s cubic-bezier(.2,.7,.25,1)}
.awards-spot .award .ph-empty{padding:0;background:linear-gradient(135deg,var(--lilac),var(--rose))}
.awards-spot .award .body{padding:13px 15px;border-top:3px solid var(--lilac)}
.awards-spot .award:nth-child(3n+2) .body{border-top-color:var(--rose)}
.awards-spot .award:nth-child(3n) .body{border-top-color:var(--mint)}
.awards-spot .award h3{font-size:.92rem;line-height:1.24;margin-bottom:5px;transition:color .25s}
.awards-spot .award p{font-size:.78rem;color:var(--muted);line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:-webkit-line-clamp .25s}
/* hovered card pops — others are untouched */
.awards-spot .award:hover{transform:translateY(-6px) scale(1.04);
  box-shadow:0 22px 44px rgba(61,31,78,.26);z-index:3;border-color:var(--gold)}
.awards-spot .award:hover .ph{transform:scale(1.07)}
.awards-spot .award:hover h3{color:var(--lilac-deep)}
.awards-spot .award:hover p{-webkit-line-clamp:4}
@media(max-width:860px){.awards-spot{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.awards-spot{grid-template-columns:repeat(2,1fr)}}

/* ---- honours + awards: motion + graphics ---- */
/* robust transition-based stagger: uses the `translate` property so it never
   conflicts with the hover `transform`, and the visible end-state is guaranteed */
.awards-grid.stagger .award{opacity:0;translate:0 16px}
.awards-grid.stagger.in .award{opacity:1;translate:0 0;
  transition:opacity .6s cubic-bezier(.2,.7,.25,1),translate .6s cubic-bezier(.2,.7,.25,1);
  transition-delay:calc(var(--d,0)*65ms)}
/* awards: expressive bloom-in (fade + rise + gentle scale-up), plays on its own — no hover */
.awards-spot.stagger .award,.cards.stagger .card{translate:0 46px;scale:.7;opacity:0}
.awards-spot.stagger .award.in,.cards.stagger .card.in{translate:0 0;scale:1;opacity:1;
  transition:opacity .5s ease-out,
             translate .62s cubic-bezier(.34,1.5,.55,1),
             scale .62s cubic-bezier(.34,1.5,.55,1)}
.card .ph,.award .ph{transition:transform .5s cubic-bezier(.2,.7,.25,1)}
.card:hover .ph{transform:scale(1.06)}
.award:hover .ph{transform:scale(1.05)}
.card:hover{box-shadow:0 16px 38px rgba(197,152,43,.24),var(--shadow)}
.award:hover{box-shadow:0 16px 38px rgba(197,152,43,.24),var(--shadow)}
.award{position:relative}
.card h3 .hstar{display:inline-block;width:15px;height:15px;margin-right:7px;vertical-align:-2px;fill:var(--gold)}
@media(prefers-reduced-motion:reduce){
  .cards.stagger .card,.awards-grid.stagger .award,.awards-spot.stagger .award{opacity:1;translate:none;scale:none}
  .card:hover .ph,.award:hover .ph{transform:none}}

/* ---- pill topics ---- */
.pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:30px 0 8px}
.pill{background:#fff;border:1.5px solid var(--lilac-soft);color:var(--lilac-deep);
  padding:9px 18px;border-radius:999px;font-weight:600;font-size:.9rem}

/* ---- regions ---- */
.regions{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:34px}
.region{background:#fff;border-radius:18px;padding:22px 24px;box-shadow:var(--shadow-sm);border:1px solid #F0E8F8}
.region.wide{grid-column:1 / -1}
.region h3{display:flex;align-items:center;gap:10px;font-size:1.08rem;margin-bottom:10px;color:var(--lilac-deep)}
.region h3::before{content:"";width:12px;height:12px;border-radius:50%;background:var(--rose)}
.region.r1 h3::before{background:var(--lilac)}.region.r2 h3::before{background:var(--mint)}
.region.r3 h3::before{background:var(--sky)}.region.r4 h3::before{background:var(--gold)}
.region p{font-size:.86rem;color:#5b5070;line-height:1.6}
@media(max-width:680px){.regions{grid-template-columns:1fr}}

/* ---- galleries ---- */
.gal{display:grid;gap:14px;margin-top:34px}
.gal.g-port{grid-template-columns:repeat(5,1fr)}
.gal.g-port a,.gal.g-port figure{aspect-ratio:3/4}
.gal.g-wide{grid-template-columns:repeat(4,1fr)}
.gal img{width:100%;height:100%;object-fit:cover;border-radius:14px;border:4px solid #fff;
  box-shadow:var(--shadow-sm);transition:transform .2s}
.gal a:hover img{transform:scale(1.03)}
@media(max-width:760px){.gal.g-port{grid-template-columns:repeat(3,1fr)}.gal.g-wide{grid-template-columns:repeat(2,1fr)}}

/* In the Media — article clipping + logo + title + read more */
/* In the Media — same format as Awards (clean grid, whole clipping, no crop) */
.mediagrid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:34px;text-align:left}
.mclip-card{position:relative;display:flex;flex-direction:column;background:#fff;border-radius:16px;overflow:hidden;
  border:1px solid #EFE6F6;box-shadow:var(--shadow-sm);transition:transform .32s cubic-bezier(.2,.7,.25,1),box-shadow .3s,border-color .3s}
.mclip-card .mclip{width:100%;aspect-ratio:1/1;object-fit:contain;background:#FBF8FD;
  padding:12px;display:block;transition:transform .45s cubic-bezier(.2,.7,.25,1)}
.mclip-card .mfoot{display:flex;align-items:center;gap:9px;padding:12px 14px;margin-top:auto;border-top:3px solid var(--lilac)}
.mclip-card:nth-child(3n+2) .mfoot{border-top-color:var(--rose)}
.mclip-card:nth-child(3n) .mfoot{border-top-color:var(--mint)}
.mclip-card .mlogo{width:30px;height:30px;border-radius:7px;flex:0 0 auto;object-fit:contain;background:#F6F0FA;padding:3px}
.mclip-card .minfo{min-width:0;display:flex;flex-direction:column}
.mclip-card .mt{font-weight:600;font-size:.84rem;color:var(--ink);line-height:1.25;transition:color .25s;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mclip-card .md{font-size:.74rem;color:var(--lilac);margin-top:2px}
.mclip-card:hover{transform:translateY(-6px) scale(1.04);box-shadow:0 22px 44px rgba(61,31,78,.26);z-index:3;border-color:var(--gold)}
.mclip-card:hover .mclip{transform:scale(1.07)}
.mclip-card:hover .mt{color:var(--lilac-deep)}
@media(max-width:860px){.mediagrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.mediagrid{grid-template-columns:repeat(2,1fr)}}
/* Interviews — sub-section under In the Media */
.subsection{margin-top:56px;padding-top:38px;border-top:1px solid #EFE6F6}
.subsection .subhead{font-family:'Playfair Display',serif;font-weight:700;
  font-size:clamp(1.35rem,2.6vw,1.9rem);color:var(--lilac-deep);margin:.35em 0 .15em}

/* media masonry */
.media{columns:4;column-gap:14px;margin-top:34px}
.media a{display:block;margin:0 0 14px;break-inside:avoid;position:relative;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);border:3px solid #fff}
.media img{width:100%;transition:transform .25s,filter .25s}
.media a::after{content:"↗ Read";position:absolute;left:0;right:0;bottom:0;padding:18px 12px 9px;
  font-size:.78rem;font-weight:600;color:#fff;background:linear-gradient(transparent,rgba(50,30,75,.78));opacity:0;transition:opacity .25s}
.media a:hover img{transform:scale(1.05)}
.media a:hover::after{opacity:1}
@media(max-width:900px){.media{columns:3}}
@media(max-width:600px){.media{columns:2}}

/* ---- connect / footer ---- */
.connect{background:linear-gradient(135deg,var(--bg2),#E7F3EF);color:var(--ink);text-align:center}
.connect h2{color:var(--lilac-deep)}
.connect .lead{color:var(--muted);margin:0 auto}
.social{display:flex;justify-content:center;gap:22px;flex-wrap:wrap;margin-top:34px}
.social a{display:flex;flex-direction:column;align-items:center;gap:10px;width:84px;font-size:.78rem;color:var(--ink)}
.social .ic{width:50px;height:50px;display:grid;place-items:center;transition:transform .18s}
.social a:hover .ic{transform:translateY(-4px) scale(1.05)}
.social .ic img{width:50px;height:50px;object-fit:contain}
footer{background:#2C1F40;color:#fff;text-align:center;padding:26px;font-size:.84rem}
footer b{color:#fff}

/* ---- about: credentials + education ---- */
.about .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:50px;align-items:start}
.about p{margin-bottom:1em;color:#473758}
.creds{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 4px}
.creds .tag{background:var(--t-lilac);color:var(--lilac-deep);font-size:.8rem;font-weight:600;padding:6px 13px;border-radius:999px}
.edu{background:#fff;border-radius:18px;padding:26px 26px 12px;box-shadow:var(--shadow-sm);border:1px solid #F0E8F8}
.edu h3{font-size:1.05rem;color:var(--lilac-deep);margin-bottom:14px}
.edu .item{position:relative;padding:0 0 18px 22px;border-left:2px solid var(--lilac-soft)}
.edu .item:last-child{border-left-color:transparent}
.edu .item::before{content:"";position:absolute;left:-7px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--lilac);border:2px solid #fff}
.edu .item b{display:block;font-size:.95rem;color:var(--ink)}
.edu .item span{font-size:.82rem;color:var(--muted)}
.roles{margin-top:18px;font-size:.9rem;color:#5b5070}
.edu .edu-note{margin-top:16px;padding-top:14px;border-top:1px solid #EFE4F4}
.edu .edu-note .en-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--lilac);margin-bottom:6px}
.edu .edu-note p{font-size:.85rem;color:#5b5070;line-height:1.55}
.roles b{color:var(--lilac-deep)}
@media(max-width:820px){.about .wrap{grid-template-columns:1fr;gap:30px}}

/* ---- video / watch cards ---- */
.videos{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
#interviews .videos{grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:980px){#interviews .videos{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){#interviews .videos{grid-template-columns:repeat(2,1fr)}}
.vcard{background:#fff;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid #F0E8F8;transition:transform .18s,box-shadow .25s}
.vcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.vthumb{position:relative;aspect-ratio:16/9;background:#1c1230 center/cover no-repeat;display:block}
.vthumb::after{content:"";position:absolute;inset:0;background:rgba(50,30,75,.18)}
.vthumb .play{position:absolute;right:12px;bottom:12px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.94);display:grid;place-items:center;z-index:2;box-shadow:var(--shadow-sm)}
.vthumb .play::before{content:"";border-style:solid;border-width:8px 0 8px 14px;border-color:transparent transparent transparent var(--lilac-deep);margin-left:3px}
.vmeta{padding:15px 17px}
.vmeta .src{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--lilac)}
.vmeta h3{font-size:.98rem;line-height:1.3;margin-top:4px}
@media(max-width:820px){.videos{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.videos{grid-template-columns:1fr}}

/* ---- portrait Short cards (Watch & Learn + How I Do It) ---- */
.videos.portrait{grid-template-columns:repeat(3,1fr);gap:30px 26px;justify-items:center}
.videos.portrait .vcard{background:none;border:0;border-radius:0;box-shadow:none;overflow:visible;text-align:center;width:100%;max-width:204px}
.videos.portrait .vcard:hover{transform:translateY(-5px)}
.videos.portrait .vthumb{aspect-ratio:9/16;width:100%;border-radius:22px;box-shadow:var(--shadow);transition:box-shadow .25s}
.videos.portrait .vcard:hover .vthumb{box-shadow:0 18px 40px rgba(61,31,78,.32)}
.videos.portrait .vthumb::after{border-radius:22px;background:linear-gradient(180deg,rgba(40,20,60,0) 55%,rgba(40,20,60,.45) 100%)}
.videos.portrait .vthumb .play{width:44px;height:44px}
.videos.portrait .vmeta{padding:13px 6px 0;max-width:200px;margin:0 auto}
@media(max-width:820px){.videos.portrait{gap:18px}}
@media(max-width:560px){.videos.portrait{grid-template-columns:repeat(2,1fr)}}

/* ---- one-line video carousel ---- */
.vcarousel{position:relative;margin-top:34px}
.videos.portrait.vtrack{display:flex;grid-template-columns:none;justify-content:safe center;
  overflow-x:auto;gap:24px;margin-top:0;
  padding:8px 4px 26px;-ms-overflow-style:none;scrollbar-width:none}
.videos.portrait.vtrack::-webkit-scrollbar{display:none}
.videos.portrait.vtrack .vcard{flex:0 0 auto;width:204px;max-width:204px}
.vnav{position:absolute;top:44%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;
  border:0;background:#fff;box-shadow:var(--shadow);color:var(--lilac-deep);font-family:'Lora',serif;
  font-size:1.5rem;line-height:1;cursor:pointer;z-index:5;display:grid;place-items:center;
  transition:opacity .2s,transform .15s}
.vnav.prev{left:-8px}.vnav.next{right:-8px}
.vnav:hover{transform:translateY(-50%) scale(1.09)}
.vnav[disabled]{opacity:0;pointer-events:none}
@media(max-width:560px){.vnav{width:38px;height:38px;font-size:1.3rem}.vnav.prev{left:-4px}.vnav.next{right:-4px}}
/* Watch & Learn: hide the "Watch & Learn" eyebrow under each card */
#learn .vmeta .src{display:none}
/* How I Do It uses self-titled designed covers: no caption, no overlay tint */
#howto .videos.portrait .vmeta{display:none}
#howto .videos.portrait .vthumb::after{display:none}
#howto .videos.portrait .vthumb{border-radius:14px}

/* ---- books & MAI ---- */
.mai{display:grid;grid-template-columns:1fr 1.3fr;gap:30px;align-items:center;background:#fff;border-radius:22px;padding:30px;box-shadow:var(--shadow-sm);border:1px solid #F0E8F8;margin-top:34px}
.mai .cover{aspect-ratio:3/4;border-radius:14px;background:#0b0b0d;overflow:hidden;box-shadow:var(--shadow)}
.mai .cover img{width:100%;height:100%;object-fit:contain;display:block}
.mai .cover .big{font-family:'Playfair Display',serif;font-size:3.4rem;line-height:1;font-weight:700}
.mai .cover .sm{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin-top:10px;opacity:.9}
.mai h3{font-size:1.5rem;color:var(--lilac-deep);margin-bottom:8px}
.mai p{color:#473758;margin-bottom:14px}
.mai .links{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.mlink{display:inline-flex;align-items:center;gap:9px;font-size:.86rem;font-weight:600;
  color:var(--lilac-deep);background:#fff;border:1px solid #EFE6F6;box-shadow:var(--shadow-sm);
  padding:8px 13px;border-radius:12px;transition:transform .15s,box-shadow .2s,border-color .2s}
.mlink:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--gold)}
.mlink-ico{width:22px;height:22px;border-radius:6px;flex:0 0 auto;object-fit:contain;background:#F6F0FA;padding:2px}
.mlink-go{color:var(--lilac);font-weight:700}
.books{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}
.book{background:#fff;border-radius:14px;padding:18px;box-shadow:var(--shadow-sm);border:1px solid #F0E8F8;border-left:4px solid var(--rose)}
.book h4{font-size:.98rem;line-height:1.25;margin-bottom:5px}
.book span{font-size:.8rem;color:var(--muted)}
.book a{display:inline-block;margin-top:9px;font-size:.8rem;font-weight:600;color:var(--lilac)}
@media(max-width:760px){.mai{grid-template-columns:1fr}.books{grid-template-columns:1fr}}

/* ---- press archive ---- */
.archive{margin-top:34px;columns:3;column-gap:26px}
.outlet{break-inside:avoid;margin-bottom:22px;background:#fff;border-radius:14px;padding:16px 18px;box-shadow:var(--shadow-sm);border:1px solid #F2EAFA}
.outlet h4{font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--lilac-deep);margin-bottom:9px;padding-bottom:7px;border-bottom:1px solid #F0E8F8}
.outlet ul{list-style:none}
.outlet li{margin-bottom:7px;font-size:.84rem;line-height:1.3;overflow-wrap:anywhere;word-break:break-word}
.outlet li a{color:#4b3d63}
.outlet li a:hover{color:var(--lilac)}
.outlet li .dom{display:block;font-size:.72rem;color:#a99ec0}
.archive-note{text-align:center;color:var(--muted);font-size:.92rem;margin-top:8px}
@media(max-width:900px){.archive{columns:2}}
@media(max-width:600px){.archive{columns:1}}

/* ---- enquiry form ---- */
.form-card{max-width:560px;margin:34px auto 0;background:#fff;border-radius:20px;padding:30px;box-shadow:var(--shadow);text-align:left}
.form-card label{display:block;font-size:.84rem;font-weight:600;color:var(--lilac-deep);margin:14px 0 5px}
.form-card input,.form-card textarea{width:100%;border:1.5px solid #E4D8F3;border-radius:11px;padding:11px 13px;font:inherit;font-size:.95rem;color:var(--ink);background:#FCFAFE}
.form-card input:focus,.form-card textarea:focus{outline:none;border-color:var(--lilac)}
.form-card textarea{min-height:120px;resize:vertical}
.form-card .btn{margin-top:20px;width:100%;justify-content:center;border:none;cursor:pointer}
.is-hidden{display:none !important}

/* ---- testimonials ---- */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px;text-align:left}
.tcard{background:#fff;border-radius:18px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid #F0E8F8;position:relative}
.tcard::before{content:"\201C";position:absolute;top:6px;left:16px;font-family:'Playfair Display',serif;font-size:3.4rem;color:var(--lilac-soft);line-height:1}
.tcard blockquote{font-size:.96rem;color:#473758;line-height:1.55;margin:14px 0 14px;font-style:italic}
.tcard figcaption b{color:var(--lilac-deep);font-size:.92rem}
.tcard figcaption span{display:block;font-size:.8rem;color:var(--muted)}
@media(max-width:760px){.tgrid{grid-template-columns:1fr}}

/* ---- on-stage sliding photo band ---- */
.onstage .marquee-wrap{margin-top:30px;display:flex;flex-direction:column;gap:18px}
.onstage .marquee{overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.onstage .track{display:flex;width:max-content;animation:marq 60s linear infinite}
.onstage .track.rev{animation:marqRev 60s linear infinite}
.onstage .marquee:hover .track{animation-play-state:paused}
.onstage .ocard{flex:0 0 auto;width:248px;height:330px;margin-right:18px;border-radius:16px;
  overflow:hidden;border:6px solid #fff;box-shadow:var(--shadow-sm);background:var(--t-lilac)}
.onstage .ocard img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes marqRev{from{transform:translateX(-50%)}to{transform:translateX(0)}}
@media(max-width:680px){.onstage .ocard{width:188px;height:250px;margin-right:14px}}
@media(prefers-reduced-motion:reduce){.onstage .track,.onstage .track.rev{animation:none}}
