/* =========================================================
   DEAF SPACES - shared light theme stylesheet (prototype v4)
   ========================================================= */
:root{
  --bg:#FFFFFF;
  --bg-2:#F7F8FC;
  --surface:#FFFFFF;
  --surface-2:#F1F3F8;
  --line:#E2E5EE;
  --line-2:#C9CEDC;

  --ink:#11152A;
  --muted:#4D556F;
  --faint:#6D748C;

  --green:#147A23;   --green-soft:#E9F7EB;
  --magenta:#B8146A; --magenta-soft:#FCEAF4;
  --violet:#6634B5;  --violet-soft:#F1ECFC;

  --radius:16px;
  --maxw:1160px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;font-size:18px;line-height:1.65;color:var(--muted);background:var(--bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* accessibility */
.skip{position:absolute;left:-9999px;top:0;z-index:300;background:var(--green);color:#fff;padding:14px 20px;border-radius:0 0 12px 0;font-weight:700}
.skip:focus{left:0}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--violet);outline-offset:3px;border-radius:6px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:96px 0}
.section.tight{padding:72px 0}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;color:var(--ink);line-height:1.08;letter-spacing:-.02em}
h2{font-size:clamp(2rem,4.4vw,3rem);font-weight:700}
h3{font-size:1.35rem;font-weight:600}
p{color:var(--muted)}
.lead{font-size:1.2rem;color:var(--muted);max-width:56ch}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:20px}
.eyebrow::before{content:"";width:22px;height:2px;background:currentColor}
.eyebrow.g{color:var(--green)} .eyebrow.m{color:var(--magenta)} .eyebrow.v{color:var(--violet)}
.center{text-align:center} .center .lead{margin-left:auto;margin-right:auto}

/* buttons - solid + glow */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Inter',sans-serif;font-weight:600;font-size:1rem;padding:13px 24px;border-radius:99px;border:2px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease;white-space:nowrap}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{transform:translateY(-2px);box-shadow:0 10px 30px -6px rgba(43,197,58,.5)}
.btn-violet{background:var(--violet);color:#fff}
.btn-violet:hover{transform:translateY(-2px);box-shadow:0 10px 30px -6px rgba(148,96,240,.55)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-sm{padding:10px 18px;font-size:.92rem}

/* header */
header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.88);backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:13px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.28rem;color:var(--ink)}
.gem{width:38px;height:38px;flex:0 0 auto}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-weight:500;font-size:1rem;color:var(--muted)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links .btn-green,.nav-links .btn-green:hover{color:#fff}
.nav-links a.active{position:relative}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--green);border-radius:2px}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.menu-toggle span{display:block;width:26px;height:3px;background:var(--ink);border-radius:2px;margin:5px 0}

/* page hero (inner pages) */
.page-hero{position:relative;overflow:hidden;padding:84px 0 64px;border-bottom:1px solid var(--line)}
.page-hero .glow{position:absolute;border-radius:50%;filter:blur(120px);z-index:0;pointer-events:none;opacity:.5}
.page-hero h1{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:700;position:relative;z-index:1}
.page-hero p{position:relative;z-index:1;margin-top:16px}
.crumbs{position:relative;z-index:1;font-size:.9rem;color:var(--faint);margin-bottom:18px;display:flex;gap:8px;align-items:center}
.crumbs a:hover{color:var(--ink)}

/* home hero with slideshow */
.home-main{position:relative;isolation:isolate;overflow:hidden}
.home-bloom{position:absolute;z-index:1;top:60px;left:-18vw;width:60vw;min-width:760px;max-width:1040px;height:1450px;pointer-events:none;background:
  radial-gradient(ellipse 72% 34% at 22% 12%,rgba(110,39,214,.18) 0%,rgba(110,39,214,.10) 34%,rgba(110,39,214,.04) 57%,transparent 76%),
  radial-gradient(ellipse 58% 46% at 34% 55%,rgba(110,39,214,.11) 0%,rgba(110,39,214,.055) 40%,rgba(110,39,214,.02) 58%,transparent 76%),
  radial-gradient(ellipse 52% 29% at 45% 84%,rgba(221,24,136,.055) 0%,rgba(110,39,214,.035) 43%,transparent 75%);
  filter:blur(16px);transform:rotate(-7deg);transform-origin:top left}
.home-main > section{position:relative;z-index:auto}
.home-main > section > .wrap{position:relative;z-index:2}
.hero{position:relative;overflow:hidden;padding:84px 0 92px}
.glow{position:absolute;border-radius:50%;filter:blur(120px);z-index:0;pointer-events:none}
.glow.g{width:520px;height:520px;background:rgba(43, 197, 58, 0.35);top:-160px;right:-60px;animation:pulse 9s ease-in-out infinite alternate}
.glow.v{width:440px;height:440px;background:rgba(149, 96, 240, 0.332);bottom:-180px;left:-120px;animation:pulse 11s ease-in-out infinite alternate-reverse}
@keyframes pulse{from{transform:scale(1);opacity:.75}to{transform:scale(1.16);opacity:1}}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.6rem,5.6vw,4.2rem);font-weight:700;letter-spacing:-.03em;color:var(--ink)}
.hero h1 .hi{color:var(--green);text-shadow:0 0 34px rgba(20,122,35,.18)}
.hero p.lead{margin-top:22px;font-size:1.26rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-tag{display:inline-flex;align-items:center;gap:10px;margin-bottom:24px;font-weight:600;color:var(--ink);background:var(--surface);border:1px solid var(--line);padding:9px 16px;border-radius:99px;font-size:.95rem}
.hero-tag .dot{width:9px;height:9px;border-radius:50%;background:var(--green)}
.bsl-inline{display:inline-flex;align-items:center;gap:10px;margin-top:26px;font-weight:600;color:var(--violet)}
.bsl-inline .play{width:34px;height:34px;border-radius:50%;background:var(--violet);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.bsl-inline .play svg{width:14px;height:14px}

/* hero slideshow (crossfade + ken burns) */
.shot{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:4/3.4;border:1px solid var(--line);box-shadow:0 30px 70px -30px rgba(17,21,42,.3)}
.shot .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.8s ease-in-out;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px}
.shot .slide img{width:100%;height:100%;object-fit:cover;transform:scale(1);transition:transform 7s ease-out}
.shot .slide.on{opacity:1}
.shot .slide.on img{transform:scale(1.08)}
.shot .slide.s1{background:radial-gradient(120% 120% at 20% 20%,#1d6f2a,#0c3a16)}
.shot .slide.s2{background:radial-gradient(120% 120% at 80% 20%,#8a1560,#3a0a2a)}
.shot .slide.s3{background:radial-gradient(120% 120% at 50% 80%,#4a1a9e,#1c0a3a)}
.shot .dots{position:absolute;bottom:16px;left:0;right:0;z-index:3;display:flex;gap:8px;justify-content:center}
.shot .dots i{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);transition:background .3s,width .3s}
.shot .dots i.on{background:#fff;width:22px;border-radius:99px}
.shot .tagvinyl{position:absolute;top:16px;left:16px;z-index:3;display:flex;align-items:center;gap:9px;background:rgba(10,14,36,.55);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.16);padding:7px 13px 7px 8px;border-radius:99px;font-weight:600;font-size:.82rem;color:#fff}
.shot .tagvinyl .g{width:22px;height:22px}

/* trust strip */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.trust-row{display:flex;align-items:center;justify-content:center;gap:18px 44px;flex-wrap:wrap;padding:24px 0}
.trust-item{display:flex;align-items:center;gap:11px;font-weight:600;color:var(--ink);font-size:.98rem}
.trust-item svg{width:22px;height:22px;flex:0 0 auto}
.trust-badge{display:flex;align-items:center;justify-content:center;height:46px;padding:0 18px;border:1.5px dashed var(--line-2);border-radius:10px;color:var(--faint);font-size:.82rem;font-weight:600}

/* stat strip */
.strip{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:38px 0}
.strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;text-align:center}
.strip .n{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:2.1rem}
.strip div:nth-child(1) .n{color:var(--green)}
.strip div:nth-child(2) .n{color:var(--magenta)}
.strip div:nth-child(3) .n{color:var(--violet)}
.strip div:nth-child(4) .n{color:var(--ink)}
.strip .t{font-size:.96rem;color:var(--muted);margin-top:6px}

/* about points */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:62px;align-items:center}
.about-points{display:grid;gap:20px}
.point{display:flex;gap:16px;align-items:flex-start}
.point .ic{flex:0 0 auto;width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.point:nth-child(1) .ic{background:var(--green-soft)}
.point:nth-child(2) .ic{background:var(--magenta-soft)}
.point:nth-child(3) .ic{background:var(--violet-soft)}
.point .ic svg{width:23px;height:23px}
.point h3{font-size:1.12rem;margin-bottom:3px}
.point p{font-size:1rem}

/* service cards */
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.serv{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:32px;transition:transform .18s ease,box-shadow .2s ease,border-color .2s ease}
.serv .ic{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.serv:nth-child(1) .ic{background:var(--green-soft)} .serv:nth-child(1):hover{transform:translateY(-4px);border-color:rgba(43,197,58,.4);box-shadow:0 16px 40px -18px rgba(43,197,58,.4)}
.serv:nth-child(2) .ic{background:var(--magenta-soft)} .serv:nth-child(2):hover{transform:translateY(-4px);border-color:rgba(255,69,168,.4);box-shadow:0 16px 40px -18px rgba(255,69,168,.35)}
.serv:nth-child(3) .ic{background:var(--violet-soft)} .serv:nth-child(3):hover{transform:translateY(-4px);border-color:rgba(148,96,240,.4);box-shadow:0 16px 40px -18px rgba(148,96,240,.35)}
.serv .ic svg{width:28px;height:28px}
.serv h3{margin-bottom:8px}
.serv p{font-size:1rem}
.serv .more{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-weight:600;font-size:.96rem}
.serv:nth-child(1) .more{color:var(--green)} .serv:nth-child(2) .more{color:var(--magenta)} .serv:nth-child(3) .more{color:var(--violet)}
.serv .scope{margin-top:14px;font-size:.9rem;color:var(--muted);background:var(--bg-2);padding:12px 15px;border-radius:0 10px 10px 0;border-left:3px solid var(--line-2)}

/* course cards */
.course-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:44px}
.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.course{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;display:flex;flex-direction:column;position:relative;transition:transform .18s ease,box-shadow .2s ease}
.course .lvl{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.course.c1{border-top:4px solid var(--green)} .course.c1 .lvl{color:var(--green)}
.course.c2{border-top:4px solid var(--magenta)} .course.c2 .lvl{color:var(--magenta)}
.course.c3{border-top:4px solid var(--violet)} .course.c3 .lvl{color:var(--violet)}
.course.c1:hover{transform:translateY(-5px);box-shadow:0 16px 40px -18px rgba(43,197,58,.4)}
.course.c2:hover{transform:translateY(-5px);box-shadow:0 16px 40px -18px rgba(255,69,168,.35)}
.course.c3:hover{transform:translateY(-5px);box-shadow:0 16px 40px -18px rgba(148,96,240,.35)}
.badge{position:absolute;top:-13px;left:30px;background:var(--green);color:#fff;font-weight:700;font-size:.74rem;letter-spacing:.05em;text-transform:uppercase;padding:6px 14px;border-radius:99px;box-shadow:0 6px 18px -6px rgba(20,122,35,.45)}
.course h3{font-size:1.5rem;margin-bottom:6px}
.price{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:2rem;color:var(--ink);margin:12px 0 2px}
.price .was{font-size:1rem;font-weight:600;color:var(--faint);text-decoration:line-through;margin-left:8px}
.price-note{font-size:.9rem;font-weight:600;margin-bottom:20px}
.course.c1 .price-note{color:var(--magenta)}
.course.c2 .price-note,.course.c3 .price-note{color:var(--muted)}
.course ul{list-style:none;display:grid;gap:11px;margin:4px 0 28px}
.course li{display:flex;gap:11px;align-items:flex-start;font-size:1rem;color:var(--muted)}
.course li svg{flex:0 0 auto;width:19px;height:19px;margin-top:3px}
.course .btn{margin-top:auto;justify-content:center}

/* upcoming dates (home preview) */
.dates-band{background:var(--bg-2)}
.date-list{display:grid;gap:14px;margin-top:40px}
.date-row{display:grid;grid-template-columns:118px 1fr auto;gap:24px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:20px 26px;transition:border-color .2s ease}
.date-row:hover{border-color:var(--green)}
.date-when{display:flex;flex-direction:column}
.date-when .d{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.5rem;color:var(--ink);line-height:1}
.date-when .mo{font-size:.85rem;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.date-info h3{color:var(--ink);font-size:1.15rem;margin-bottom:4px}
.date-info .meta{font-size:.95rem;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px 18px}
.date-info .mode{display:inline-flex;align-items:center;gap:7px}
.date-info .mode .pip{width:8px;height:8px;border-radius:50%}
.mode.zoom .pip{background:var(--magenta)} .mode.inperson .pip{background:var(--green)} .mode.advice .pip{background:var(--violet)}
.date-row .btn{justify-self:end}

/* team - colour-fade banners */
.team-stack{position:relative;isolation:isolate;display:grid;gap:28px;margin-top:48px;padding:clamp(26px,4vw,48px);overflow:hidden;border:1px solid var(--line);border-radius:30px;background:
  radial-gradient(circle at 4% 8%,rgba(43,197,58,.28) 0%,rgba(43,197,58,.12) 17%,transparent 38%),
  radial-gradient(circle at 98% 49%,rgba(221,24,136,.25) 0%,rgba(221,24,136,.11) 18%,transparent 40%),
  radial-gradient(circle at 5% 96%,rgba(110,39,214,.29) 0%,rgba(110,39,214,.13) 19%,transparent 41%),
  #faf9fd;
  box-shadow:0 24px 60px -42px rgba(102,52,181,.4)}
.member{position:relative;z-index:1;border-radius:22px;overflow:hidden;border:1px solid var(--line);background:var(--surface);opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.member.in{opacity:1;transform:none}
.member .bg{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease .15s}
.member.in .bg{opacity:1}
.member.r .bg{background:linear-gradient(100deg,#159e22 0%,#36c243 46%,#d6f5da 100%)}
.member.j .bg{background:linear-gradient(100deg,#cc1580 0%,#f23da0 46%,#fcdcee 100%)}
.member.f .bg{background:linear-gradient(100deg,#5d1ec4 0%,#9460f0 46%,#e7dafb 100%)}
.member .row{position:relative;z-index:2;display:grid;grid-template-columns:280px 1fr;gap:0;align-items:stretch}
.member .photo{position:relative;min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#fff}
.member .photo::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.14)}
.member .photo svg{position:relative;z-index:1;width:76px;height:76px;opacity:.95}
.member .photo .ph-label{position:relative;z-index:1;font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.92}
.member .info{padding:38px 42px;display:flex;flex-direction:column;justify-content:center;color:#fff;background:linear-gradient(90deg,rgba(7,10,28,.62),rgba(7,10,28,.74))}
.member .info h3{color:#fff;font-size:1.7rem;margin-bottom:6px}
.member .info .role{font-weight:700;font-size:.98rem;margin-bottom:16px;color:#fff;opacity:.9}
.member .info .bio{color:rgba(255,255,255,.94);font-size:1.02rem;line-height:1.6;max-width:54ch;margin-bottom:18px}
.member .meta{display:flex;flex-wrap:wrap;gap:10px 22px;border-top:1px solid rgba(255,255,255,.28);padding-top:16px}
.member .meta span{display:flex;gap:9px;align-items:center;font-size:.95rem;color:rgba(255,255,255,.92)}
.member .meta b{color:#fff;font-weight:700}
.member .pill{display:inline-block;font-size:.68rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#fff;background:rgba(12,17,48,.7);padding:3px 9px;border-radius:99px;margin-left:4px}
.member .meta .pill{color:#fff}

/* testimonials */
.tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.tm{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px;position:relative}
.tm .quote{font-size:2.6rem;font-family:'Space Grotesk',sans-serif;font-weight:700;line-height:.6;margin-bottom:10px}
.tm:nth-child(1) .quote{color:var(--green)} .tm:nth-child(2) .quote{color:var(--magenta)} .tm:nth-child(3) .quote{color:var(--violet)}
.tm p{font-size:1.02rem;color:var(--ink)}
.tm .who{margin-top:18px;font-weight:600;color:var(--ink);font-size:.96rem}
.tm .who span{display:block;font-weight:400;color:var(--faint);font-size:.9rem}
.tm .ex{position:absolute;top:16px;right:16px;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);background:var(--bg-2);padding:3px 8px;border-radius:99px}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:start}
.contact-info{display:grid;gap:22px;margin-top:24px}
.ci{display:flex;gap:16px;align-items:flex-start}
.ci .ic{flex:0 0 auto;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.ci:nth-child(1) .ic{background:var(--green-soft)}
.ci:nth-child(2) .ic{background:var(--magenta-soft)}
.ci:nth-child(3) .ic{background:var(--violet-soft)}
.ci:nth-child(4) .ic{background:var(--green-soft)}
.ci .ic svg{width:23px;height:23px}
.ci h3{font-size:1.05rem;margin-bottom:2px}
.ci p{font-size:1rem}
.ci a{color:var(--violet);font-weight:600}
form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:36px}
.field{margin-bottom:18px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;font-weight:600;color:var(--ink);margin-bottom:7px;font-size:.98rem}
input,textarea,select{width:100%;font-family:'Inter',sans-serif;font-size:1rem;color:var(--ink);padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;background:var(--bg-2)}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,textarea:focus,select:focus{border-color:var(--green)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%234D556F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
textarea{resize:vertical;min-height:120px}
.proto-flag{font-size:.82rem;color:var(--faint);margin-top:14px;text-align:center}

/* generic CTA band */
.cta-band{background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:54px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.cta-band h2{margin-bottom:8px}
.cta-band p{max-width:50ch}

/* footer */
footer{background:#F4F6FA;color:var(--muted);padding:56px 0 30px;border-top:1px solid var(--line)}
.foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
.foot-brand{display:flex;align-items:center;gap:12px;font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--ink);font-size:1.25rem}
.foot-links{display:flex;gap:48px;flex-wrap:wrap}
.foot-col h4{color:var(--ink);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;font-family:'Inter',sans-serif;font-weight:700}
.foot-col a,.foot-col p{display:block;font-size:.96rem;margin-bottom:9px;color:var(--faint)}
.foot-col a:hover{color:var(--ink)}
.foot-bottom{border-top:1px solid var(--line);margin-top:42px;padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.88rem;color:var(--faint)}

/* floating watch-in-BSL */
.bsl-fab{position:fixed;right:24px;bottom:24px;z-index:200;display:inline-flex;align-items:center;gap:11px;background:var(--violet);color:#fff;font-weight:600;font-size:.96rem;padding:13px 20px 13px 14px;border:0;border-radius:99px;cursor:pointer;box-shadow:0 12px 30px -8px rgba(148,96,240,.65);transition:transform .15s ease}
.bsl-fab:hover{transform:translateY(-3px)}
.bsl-fab .hands{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.bsl-fab .hands svg{width:17px;height:17px}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ===== COURSES PAGE ===== */
.course-detail{display:grid;grid-template-columns:1fr;gap:28px;margin-top:8px}
.cd{background:var(--surface);border:1px solid var(--line);border-radius:20px;overflow:hidden}
.cd-top{display:grid;grid-template-columns:200px 1fr auto;gap:28px;align-items:center;padding:30px 34px;border-bottom:1px solid var(--line)}
.cd-badge{width:200px;height:120px;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#fff}
.cd.l1 .cd-badge{background:linear-gradient(135deg,#159e22,#36c243)}
.cd.l2 .cd-badge{background:linear-gradient(135deg,#cc1580,#f23da0)}
.cd.l3 .cd-badge{background:linear-gradient(135deg,#5d1ec4,#9460f0)}
.cd-badge .lv{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.7rem;line-height:1}
.cd-badge .lb{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;opacity:.9}
.cd-head h3{font-size:1.6rem;margin-bottom:6px}
.cd-head p{font-size:1rem}
.cd-price{text-align:right}
.cd-price .p{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.8rem;color:var(--ink)}
.cd-price .was{color:var(--faint);text-decoration:line-through;font-size:.95rem}
.cd-body{display:grid;grid-template-columns:1.4fr 1fr;gap:34px;padding:32px 34px}
.cd-body h4{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:14px;font-family:'Inter',sans-serif;font-weight:700}
.topic-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}
.topic{display:flex;gap:10px;align-items:flex-start;font-size:1rem;color:var(--muted);margin-bottom:6px}
.topic svg{flex:0 0 auto;width:18px;height:18px;margin-top:3px}
.cd.l1 .topic svg{stroke:var(--green)} .cd.l2 .topic svg{stroke:var(--magenta)} .cd.l3 .topic svg{stroke:var(--violet)}
.cd-side{background:var(--bg-2);border-radius:14px;padding:24px;border:1px solid var(--line)}
.cd-fact{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);font-size:.96rem}
.cd-fact:last-of-type{border-bottom:0}
.cd-fact .k{color:var(--faint)} .cd-fact .v{color:var(--ink);font-weight:600;text-align:right}
.cd-teacher{display:flex;align-items:center;gap:14px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.cd-teacher .av{width:48px;height:48px;border-radius:12px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Space Grotesk',sans-serif;font-weight:700}
.cd.l1 .cd-teacher .av,.cd.l2 .cd-teacher .av,.cd.l3 .cd-teacher .av{background:var(--green)}
.cd-teacher .tn{color:var(--ink);font-weight:600;font-size:.98rem}
.cd-teacher .tr{color:var(--faint);font-size:.86rem}
.cd-foot{padding:24px 34px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.cd-foot .note{font-size:.92rem;color:var(--faint)}

/* ===== DATES PAGE (calendar) ===== */
.cal-toolbar{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:24px}
.cal-month{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.5rem;color:var(--ink)}
.cal-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:.88rem;color:var(--muted)}
.cal-legend span{display:flex;align-items:center;gap:7px}
.cal-legend .pip{width:9px;height:9px;border-radius:50%}
.cal{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--surface)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-dow{padding:14px 10px;text-align:center;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);font-weight:700;border-bottom:1px solid var(--line);background:var(--bg-2)}
.cal-cell{min-height:118px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:8px;display:flex;flex-direction:column;gap:5px}
.cal-cell:nth-child(7n){border-right:0}
.cal-cell.empty{background:var(--bg-2)}
.cal-cell .dn{font-size:.8rem;color:var(--faint);font-weight:600;margin-bottom:2px}
.cal-cell.today .dn{color:var(--green)}
.ev{display:block;border-radius:7px;padding:5px 8px;font-size:.74rem;font-weight:600;line-height:1.25;color:#fff;cursor:pointer;transition:transform .12s ease}
.ev:hover{transform:translateX(2px)}
.ev .t{display:block;font-weight:700}
.ev .h{display:block;opacity:.85;font-weight:500}
.ev.green{background:#1c7a27} .ev.green:hover{background:#1FA82C}
.ev.magenta{background:#a8166a} .ev.magenta:hover{background:#cc1580}
.ev.violet{background:#5a25b0} .ev.violet:hover{background:#6E27D6}
.cal-list{margin-top:46px}
.cal-list h3{margin-bottom:20px}

@media (max-width:920px){
  .home-bloom{top:40px;left:-48vw;width:120vw;min-width:0;max-width:none;height:1650px;background:
    radial-gradient(ellipse 78% 31% at 25% 12%,rgba(110,39,214,.11) 0%,rgba(110,39,214,.055) 36%,rgba(110,39,214,.02) 58%,transparent 76%),
    radial-gradient(ellipse 62% 45% at 36% 55%,rgba(110,39,214,.07) 0%,rgba(110,39,214,.03) 43%,transparent 76%),
    radial-gradient(ellipse 55% 27% at 46% 84%,rgba(221,24,136,.03) 0%,rgba(110,39,214,.018) 44%,transparent 75%);
    filter:blur(12px);transform:rotate(-5deg)}
  .nav-links{position:fixed;inset:78px 0 auto 0;background:var(--bg);border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;gap:0;padding:10px 0;display:none;box-shadow:0 18px 40px -18px rgba(0,0,0,.6)}
  .nav-links.open{display:flex}.nav-links a{padding:14px 28px}.nav-links a.active::after{display:none}.nav-links .btn{margin:12px 28px}
  .menu-toggle{display:block}
  .hero-grid{grid-template-columns:1fr;gap:36px}.shot{order:-1;aspect-ratio:16/11}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:38px}
  .serv-grid,.course-grid,.tm-grid{grid-template-columns:1fr}
  .strip-grid{grid-template-columns:1fr 1fr;gap:30px 18px}
  .member .row{grid-template-columns:1fr}.member .photo{min-height:200px}
  .team-stack{gap:22px;padding:18px;border-radius:24px;background:
    radial-gradient(circle at 0% 5%,rgba(43,197,58,.22) 0%,rgba(43,197,58,.09) 19%,transparent 40%),
    radial-gradient(circle at 100% 50%,rgba(221,24,136,.19) 0%,rgba(221,24,136,.08) 20%,transparent 42%),
    radial-gradient(circle at 0% 97%,rgba(110,39,214,.23) 0%,rgba(110,39,214,.10) 21%,transparent 43%),
    #faf9fd}
  .member .bg{background-position:center}
  .member.r .bg{background:linear-gradient(160deg,#159e22 0%,#36c243 55%,#d6f5da 100%)}
  .member.j .bg{background:linear-gradient(160deg,#cc1580 0%,#f23da0 55%,#fcdcee 100%)}
  .member.f .bg{background:linear-gradient(160deg,#5d1ec4 0%,#9460f0 55%,#e7dafb 100%)}
  .date-row{grid-template-columns:64px 1fr;gap:14px}.date-row .btn{grid-column:1/-1;justify-self:stretch;justify-content:center}
  .cd-top{grid-template-columns:1fr;gap:18px}.cd-badge{width:100%}.cd-price{text-align:left}
  .cd-body{grid-template-columns:1fr;gap:26px}.topic-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .cta-band{padding:36px;flex-direction:column;align-items:flex-start}
  .section{padding:72px 0}
  .cal-cell{min-height:auto;padding:6px}.cal-dow{font-size:.62rem;padding:10px 4px}
  .ev{font-size:.6rem;padding:3px 5px}.ev .h{display:none}
}
@media (max-width:480px){body{font-size:17px}.wrap{padding:0 20px}.member .info{padding:28px 24px}.bsl-fab span{display:none}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal,.member{opacity:1;transform:none}.member .bg{opacity:1}.shot .slide.on{animation:none}}
