*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
:root{--bg:#c9f0f0;--bg2:#daf5f5;--teal:#1aafa0;--teal-h:#159e90;--tl:rgba(26,175,160,.1);--navy:#0d2a4a;--body:#1a3a5c;--w:#fff;--card:#f0fafa;--sh:0 4px 20px rgba(13,42,74,.07)}
body{font-family:'DM Sans',sans-serif;color:var(--body);background:var(--bg);line-height:1.65;overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:'Poppins',sans-serif;color:var(--navy);line-height:1.25}

/* NAV */
.nb{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(201,240,240,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);transition:all .3s;padding:8px 0}
.nb.sc{box-shadow:0 2px 24px rgba(13,42,74,.1);background:rgba(201,240,240,.96)}
.ni{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 24px}
.nl img{height:70px;width:auto;cursor:pointer;transition:transform .2s;border-radius:8px}
.nl img:hover{transform:scale(1.05)}
.nk{display:flex;align-items:center;gap:28px;list-style:none}
.nk a{text-decoration:none;color:var(--navy);font-weight:500;font-size:15px;transition:color .2s;cursor:pointer;font-family:'Poppins',sans-serif;position:relative}
.nk a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--teal);transition:width .2s}
.nk a:hover::after,.nk a.act::after{width:100%}
.nk a:hover,.nk a.act{color:var(--teal)}
.dd{position:relative}
.dm{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--w);border-radius:12px;box-shadow:0 8px 30px rgba(13,42,74,.12);padding:8px 0;min-width:220px;opacity:0;visibility:hidden;transition:all .2s}
.dd:hover .dm,.dd.open .dm{opacity:1;visibility:visible}
.dm a{display:block;padding:10px 20px;font-size:14px;white-space:nowrap}
.dm a::after{display:none}
.dm a:hover{background:var(--tl);color:var(--teal)}
.dm-sub{position:relative}
.dm-sub > a{padding-right:34px}
.dm-sub > a::before{content:'\203A';position:absolute;right:16px;top:50%;transform:translateY(-55%);color:var(--teal);font-weight:700;font-size:1.05rem;line-height:1}
.dm-fly{position:absolute;top:-8px;left:100%;background:var(--w);border-radius:12px;box-shadow:0 8px 30px rgba(13,42,74,.12);padding:8px 0;min-width:240px;opacity:0;visibility:hidden;transition:all .2s}
.dm-sub:hover .dm-fly,.dm-sub.open .dm-fly{opacity:1;visibility:visible}
.dm-fly a{display:block;padding:10px 20px;font-size:14px;white-space:nowrap;color:var(--navy);text-decoration:none;font-family:'Poppins',sans-serif;font-weight:500;position:relative}
.dm-fly a::after{display:none}
.dm-fly a:hover{background:var(--tl);color:var(--teal)}
.cb{background:var(--teal);color:var(--w)!important;padding:10px 28px;border-radius:50px;font-weight:600;border:none;cursor:pointer;font-size:15px;transition:all .2s;text-decoration:none;display:inline-block;font-family:'Poppins',sans-serif}
.cb:hover{transform:scale(1.04);box-shadow:0 4px 18px rgba(26,175,160,.35);background:var(--teal-h)}
.cb::after{display:none!important}
.hb{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.hb span{display:block;width:24px;height:2.5px;background:var(--navy);border-radius:2px;transition:all .3s}
.hb.act span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hb.act span:nth-child(2){opacity:0}
.hb.act span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mn{display:none;position:fixed;top:86px;left:0;right:0;background:var(--w);box-shadow:0 8px 30px rgba(13,42,74,.1);padding:20px 24px;z-index:999}
.mn.show{display:block}
.mn a{display:block;padding:12px 0;color:var(--navy);text-decoration:none;font-weight:500;font-size:16px;font-family:'Poppins',sans-serif;border-bottom:1px solid var(--bg2)}
.mn a:hover{color:var(--teal)}
.mn .ms{padding-left:16px}
.mn .ms a{font-size:14px;color:var(--body)}
.mn .ms-sub{padding-left:14px;border-left:2px solid var(--bg2);margin:2px 0 6px 4px}
.mn .ms-sub a{font-size:13.5px;color:var(--body);opacity:.9;padding:9px 0;border-bottom:none}
.mn .ms-sub a::before{content:'\21B3 ';color:var(--teal);margin-right:4px;font-weight:700}
.ps{display:none}.ps.act{display:block}
section{padding:80px 24px}
.ct{max-width:1100px;margin:0 auto}
.voyager {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
/* HERO */
.hero{padding:140px 24px 70px;text-align:center;background:var(--bg);position:relative;overflow:hidden}
.hero-logo{width:280px;height:auto;margin:0 auto 20px;display:block;border-radius:16px;animation:hfi .8s ease-out}
.hero h1{font-size:clamp(1.8rem,4.5vw,2.8rem);font-weight:800;margin-bottom:16px;animation:hfi .8s ease-out .15s both}
.uw{position:relative;display:inline}
.uw-ex{position:relative}
.hero h1{position:relative;z-index:1}
@keyframes hfi{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 0 0 rgba(26,175,160,.3)}50%{box-shadow:0 0 0 12px rgba(26,175,160,0)}}
.hero .tl{font-size:clamp(1rem,2.5vw,1.15rem);color:var(--body);max-width:640px;margin:0 auto 28px;font-style:normal;animation:hfi .8s ease-out .3s both}
.hero .hc{animation:hfi .8s ease-out .45s both}

/* Floating boats */
.fb{position:absolute;bottom:30px;right:8%;opacity:.1;pointer-events:none}
.fb svg{width:100px;height:auto;animation:fl 4s ease-in-out infinite}
.fb2{position:absolute;bottom:50px;left:5%;opacity:.06;pointer-events:none}
.fb2 svg{width:70px;height:auto;animation:fl 5s ease-in-out infinite .5s}
@keyframes fl{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-14px) rotate(2deg)}}

/* Hero decorative dots */
.hero-dots{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden;z-index:0}
.hero-dots span{position:absolute;border-radius:50%;background:var(--teal);opacity:.05;animation:heroDotPulse 7s ease-in-out infinite}
.hero-dots .d1{width:200px;height:200px;top:-60px;right:-40px}
.hero-dots .d2{width:120px;height:120px;bottom:20px;left:10%;opacity:.04;animation-delay:-2.5s;animation-duration:9s}
.hero-dots .d3{width:80px;height:80px;top:40%;right:15%;opacity:.06;animation-delay:-4.5s;animation-duration:6s}
@keyframes heroDotPulse{0%,100%{transform:translate(0,0) scale(1);opacity:var(--dotMax,.06)}50%{transform:translate(6px,-8px) scale(1.08);opacity:var(--dotMin,.03)}}
.hero-dots .d1{--dotMax:.07;--dotMin:.03}
.hero-dots .d2{--dotMax:.05;--dotMin:.02}
.hero-dots .d3{--dotMax:.08;--dotMin:.04}
.hero .sh-canvas{z-index:0}
.hero-logo,.hero h1,.hero .tl,.hero .hc{position:relative;z-index:1}
.hero-logo{animation:hfi .8s ease-out both,heroLogoDrift 7s ease-in-out 1s infinite}
@keyframes heroLogoDrift{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
/* Animated underline keyframes for mobile "Excellence" */
@keyframes uwExMobile{0%{width:0;opacity:1}32%{width:100%;opacity:1}70%{width:100%;opacity:1}88%{width:100%;opacity:0}100%{width:0;opacity:0}}

/* MISSION */
.mi-s{background:var(--w);padding:56px 24px;text-align:center}
.mi-s p{max-width:700px;margin:0 auto;font-size:1.05rem;line-height:1.75}

/* TRIAL BANNER */
.trial-banner{background:linear-gradient(135deg,var(--navy) 0%,#1a4a6a 100%);padding:40px 24px;text-align:center;color:var(--w)}
.trial-banner .trial-inner{max-width:700px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:16px}
.trial-banner .trial-icon{width:52px;height:52px;border-radius:50%;background:rgba(26,175,160,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.trial-banner .trial-icon svg{width:24px;height:24px;color:var(--teal)}
.trial-banner .trial-text-wrap{text-align:center}
.trial-banner .trial-text-wrap h3{font-size:1.15rem;color:var(--w);margin-bottom:6px;font-family:'Poppins',sans-serif}
.trial-banner .trial-text-wrap p{font-size:.92rem;color:rgba(255,255,255,.8);margin:0;max-width:500px}
.trial-banner .cb{margin-top:4px;animation:pulseGlow 2s infinite}

/* SERVICES */
.sv-s{padding:80px 24px;background:var(--bg);position:relative}
.sv-s h2{text-align:center;font-size:clamp(1.5rem,3vw,2rem);margin-bottom:40px}
.sg{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;max-width:1100px;margin:0 auto}
.sc{background:var(--w);border-radius:16px;padding:32px 24px;box-shadow:var(--sh);transition:all .3s;cursor:pointer;border:2px solid transparent}
.sc:hover{transform:translateY(-5px);box-shadow:0 12px 35px rgba(13,42,74,.1);border-color:var(--teal)}
.sc .ci{width:48px;height:48px;margin-bottom:16px}
.sc h3{font-size:1.15rem;margin-bottom:10px}
.sc p{font-size:.93rem;line-height:1.6;margin-bottom:14px}
.sc .lm{color:var(--teal);font-weight:600;text-decoration:none;font-size:.93rem;font-family:'Poppins',sans-serif;display:inline-flex;align-items:center;gap:4px;transition:gap .2s}
.sc:hover .lm{gap:8px}

/* WHY CHOOSE */
.wy-s{padding:80px 24px;background:var(--w)}
.wy-s h2{text-align:center;font-size:clamp(1.5rem,3vw,2rem);margin-bottom:40px}
.wg{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;max-width:1100px;margin:0 auto}
.wc{padding:28px;border-radius:16px;background:var(--card);border-left:4px solid var(--teal);transition:all .3s;cursor:default}
.wc:hover{transform:translateY(-5px);box-shadow:0 12px 35px rgba(13,42,74,.1);background:var(--w);border-left-color:var(--teal-h)}
.wc:hover h3 svg{transform:scale(1.2)}
.wc h3{font-size:1.05rem;margin-bottom:8px;display:flex;align-items:center;gap:10px}
.wc h3 svg{width:22px;height:22px;color:var(--teal);flex-shrink:0;transition:transform .3s}
.wc p{font-size:.93rem}

/* FOUNDER */
.about-hero{padding:140px 24px 60px;background:linear-gradient(135deg,var(--navy) 0%,#1a4a6a 100%);position:relative;overflow:hidden;text-align:center}
.about-hero-bg{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}
.ah-circle{position:absolute;border-radius:50%;background:rgba(26,175,160,.08)}
.ah-c1{width:280px;height:280px;top:-80px;right:-60px;animation:floatSlow 8s ease-in-out infinite}
.ah-c2{width:180px;height:180px;bottom:-40px;left:-30px;opacity:.06;animation:floatSlow 10s ease-in-out infinite 1s}
.ah-c3{width:100px;height:100px;top:40%;left:15%;opacity:.05;animation:floatSlow 7s ease-in-out infinite 2s}
.ah-boat{position:absolute;bottom:20px;right:8%;width:80px;opacity:.1;animation:fl 4s ease-in-out infinite}
@keyframes floatSlow{0%,100%{transform:translate(0,0)}50%{transform:translate(8px,-12px)}}
.about-hero-content{position:relative;z-index:1;animation:fadeSlideUp .7s ease-out both}
.about-hero-content h1{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;margin-bottom:16px;color:var(--w)}
.about-hero-content p{font-size:1.1rem;line-height:1.8;max-width:700px;margin:0 auto;color:rgba(255,255,255,.85)}
.fo-s{padding:80px 24px;background:var(--bg)}
.fo-s h2{text-align:center;font-size:clamp(1.5rem,3vw,2rem);margin-bottom:40px}
.fo-s-bg{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}
.fo-bg-c1{position:absolute;width:250px;height:250px;border-radius:50%;background:var(--teal);opacity:.03;top:-60px;left:-80px;animation:floatSlow 9s ease-in-out infinite}
.fo-bg-c2{position:absolute;width:180px;height:180px;border-radius:50%;background:var(--teal);opacity:.04;bottom:-50px;right:-40px;animation:floatSlow 11s ease-in-out infinite 1.5s}
.fl{display:grid;grid-template-columns:310px minmax(0,1fr);gap:50px;max-width:1080px;margin:0 auto;align-items:center}
.fpw{text-align:center;background:rgba(255,255,255,.36);border:1px solid rgba(255,255,255,.48);border-radius:24px;padding:24px 20px 22px;box-shadow:0 18px 42px rgba(13,42,74,.08);align-self:center}
.fi{width:100%;max-width:260px;border-radius:18px;box-shadow:0 8px 30px rgba(13,42,74,.12);display:block;margin:0 auto}
.fn{font-size:1.4rem;font-weight:700;font-family:'Poppins',sans-serif;color:var(--navy);margin-top:16px}
.ft{color:var(--teal);font-weight:600;font-size:.95rem;font-family:'Poppins',sans-serif}
.ab{display:flex;gap:0;margin:24px 0;border-radius:16px;overflow:hidden;box-shadow:var(--sh)}
.ai{flex:1;background:var(--w);padding:20px 12px;text-align:center;border-right:1px solid var(--bg2)}
.ai:last-child{border-right:none}
.ai .an{font-family:'Poppins',sans-serif;font-size:1.5rem;font-weight:800;color:var(--teal);line-height:1.1}
.ai .al{font-size:.7rem;color:var(--body);margin-top:4px;line-height:1.3;text-transform:uppercase;letter-spacing:.5px;font-weight:500}
.fb-bio p{font-size:.95rem;line-height:1.7;margin-bottom:10px}
.fo-off{margin-top:16px;padding:16px 20px;background:var(--w);border-radius:14px;box-shadow:var(--sh);font-size:.9rem}
.fo-off .ot{font-family:'Poppins',sans-serif;font-weight:700;color:var(--navy);font-size:.85rem;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.fo-off .ot svg{width:18px;height:18px;color:var(--teal)}
.otg{display:flex;flex-wrap:wrap;gap:6px}
.otg span{background:var(--tl);color:var(--teal);padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:600;font-family:'Poppins',sans-serif}

/* TESTIMONIALS */
.te-s{padding:80px 24px;background:var(--w)}
.te-s h2{text-align:center;font-size:clamp(1.5rem,3vw,2rem);margin-bottom:40px}
.cw{position:relative;max-width:780px;margin:0 auto;overflow:hidden}
.ck{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.tc{min-width:100%;padding:0 12px;box-sizing:border-box}
.ti{background:var(--card);border-radius:16px;padding:32px 28px;box-shadow:var(--sh);border-top:4px solid var(--teal)}
.tn{color:var(--teal);font-weight:700;font-family:'Poppins',sans-serif;font-size:.95rem;margin-bottom:14px}
.tt{color:var(--body);font-style:italic;font-size:.92rem;line-height:1.7}
.cn{position:absolute;top:50%;transform:translateY(-50%);background:var(--w);border:2px solid var(--teal);color:var(--teal);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;transition:all .2s;z-index:2}
.cn:hover{background:var(--teal);color:var(--w)}
.cp{left:-4px}.cx{right:-4px}
.cd{text-align:center;margin-top:20px;display:flex;gap:8px;justify-content:center}
.co{width:10px;height:10px;border-radius:50%;background:#b8ddd8;cursor:pointer;transition:all .2s;border:none}
.co.act{background:var(--teal);transform:scale(1.2)}

/* SUBJECT PAGES */
.sh{padding:130px 24px 50px;background:var(--bg);position:relative;overflow:hidden}
.sh .sh-bg{position:absolute;top:0;right:0;bottom:0;width:40%;pointer-events:none;opacity:.06}
.sh-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}
.sh-in{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 200px;gap:40px;align-items:center;position:relative;z-index:1}
.sh h1{font-size:clamp(1.6rem,3.5vw,2.4rem);margin-bottom:10px;animation:fadeSlideUp .6s ease-out both}
.sh p{font-size:1rem;color:var(--body);line-height:1.6;animation:fadeSlideUp .6s ease-out .1s both}
.sh-icon{text-align:center;animation:fadeSlideUp .6s ease-out .2s both}
.sh-icon svg{width:100%;max-width:160px;height:auto}

/* Subject body - improved layout */
.sb{padding:60px 24px;background:var(--w);position:relative;overflow:hidden}
.sb::before{content:'';position:absolute;top:-100px;right:-100px;width:300px;height:300px;border-radius:50%;background:var(--tl);pointer-events:none}
.sb::after{content:'';position:absolute;bottom:-80px;left:-80px;width:200px;height:200px;border-radius:50%;background:rgba(26,175,160,.04);pointer-events:none}
.sb-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 240px;gap:48px;align-items:start;position:relative;z-index:1}
.sb-text{animation:fadeSlideUp .5s ease-out both}
.sb-text p{font-size:.97rem;line-height:1.75;margin-bottom:16px}
.sb-text ul,.sb-text ol{margin:0 0 20px 20px}
.sb-text li{margin-bottom:8px;line-height:1.65;font-size:.97rem}
.sb-side{display:flex;flex-direction:column;gap:16px;animation:fadeSlideUp .5s ease-out .15s both}
.sb-card{background:var(--card);border-radius:16px;padding:24px 18px;text-align:center;box-shadow:var(--sh);transition:transform .2s}
.sb-card:hover{transform:translateY(-3px)}
.sb-card svg{width:44px;height:44px;color:var(--teal);margin-bottom:8px}
.sb-card p{font-size:.8rem;color:var(--body);font-weight:600;line-height:1.3}

/* Mocks availability */
.mocks-grid{margin-top:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
.mock-item{background:var(--card);border-radius:10px;padding:10px 12px;text-align:center;font-size:.82rem;font-weight:600;color:var(--navy);border:1px solid rgba(26,175,160,.15);transition:all .2s;cursor:default}
.mock-item:hover{background:var(--tl);border-color:var(--teal);transform:translateY(-2px);box-shadow:0 4px 12px rgba(26,175,160,.15)}
.mock-item .mock-num{font-family:'Poppins',sans-serif;font-size:1.1rem;font-weight:800;color:var(--teal)}

/* Pricing */
.pr-s{padding:60px 24px;background:var(--bg)}
.pr-s h2{text-align:center;font-size:clamp(1.3rem,2.5vw,1.7rem);margin-bottom:36px}
.pg{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:24px;max-width:1000px;margin:0 auto}
.pc{background:var(--w);border-radius:16px;padding:32px 24px;box-shadow:var(--sh);text-align:center;transition:all .3s;border:2px solid transparent}
.pc:hover{border-color:var(--teal);transform:translateY(-3px)}
.pc.feat{border-color:var(--teal);position:relative}
.pc.feat::before{content:'Best Value';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--teal);color:var(--w);padding:4px 16px;border-radius:20px;font-size:.75rem;font-weight:700;font-family:'Poppins',sans-serif}
.pc h3{font-size:1.1rem;margin-bottom:10px}
.pc .pr{font-family:'Poppins',sans-serif;font-size:1.8rem;font-weight:800;color:var(--teal);margin-bottom:4px}
.pc .op{text-decoration:line-through;color:#999;font-size:1.1rem;font-family:'Poppins',sans-serif}
.pc ul{list-style:none;text-align:left;margin-top:16px}
.pc li{padding:7px 0;font-size:.9rem;display:flex;gap:8px;align-items:flex-start;border-bottom:1px solid var(--bg2)}
.pc li::before{content:'\2713';color:var(--teal);font-weight:700;flex-shrink:0;font-size:.85rem}
.pc .pn{font-size:.8rem;color:var(--teal);font-weight:600;font-family:'Poppins',sans-serif;margin-bottom:4px}

/* Resources */
.re-s{padding:60px 24px;background:var(--w)}
.re-s h2{text-align:center;font-size:clamp(1.3rem,2.5vw,1.7rem);margin-bottom:36px}
.rg{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1100px;margin:0 auto}
.rc{background:var(--card);border-radius:16px;overflow:hidden;box-shadow:var(--sh);transition:all .3s}
.rc:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(13,42,74,.1)}
.rp{background:linear-gradient(135deg,var(--bg) 0%,#b5e8e4 100%);padding:28px 20px;min-height:160px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.rp svg{width:40px;height:40px;margin-bottom:12px;color:var(--teal)}
.rp h3{font-size:1rem;color:var(--navy);margin-bottom:6px}
.rp p{font-size:.8rem;color:var(--body)}
.ri{padding:16px 20px;text-align:center}
.db{background:var(--teal);color:var(--w);padding:10px 24px;border-radius:50px;border:none;font-weight:600;cursor:pointer;font-size:.88rem;transition:all .2s;font-family:'Poppins',sans-serif;-webkit-appearance:none;touch-action:manipulation}
.db:hover{transform:scale(1.04);box-shadow:0 4px 15px rgba(26,175,160,.35);background:var(--teal-h)}

/* CONTACT */
.co-s{padding:132px 24px 80px;background:linear-gradient(180deg,#f7fdfd 0%,var(--bg) 100%)}
.cg{max-width:920px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:18px}
.cf{background:var(--w);border-radius:20px;padding:36px;box-shadow:0 18px 48px rgba(13,42,74,.08);border:1px solid rgba(207,243,239,.9)}
.form-head{margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--bg2)}
.form-head h1{font-size:clamp(1.8rem,4.5vw,2.45rem);margin-bottom:8px}
.form-head p{font-size:.96rem;line-height:1.6;color:var(--body);max-width:520px}
.form-head .privacy-note{margin-top:8px;color:var(--teal);font-weight:700;font-size:.9rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 16px}
.fg{margin:0}
.fg label,.fg legend{display:block;font-size:.83rem;font-weight:700;color:var(--navy);margin-bottom:7px;font-family:'Poppins',sans-serif}
.optional-label{font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:600;color:var(--body);opacity:.7}
.fg input:not([type="radio"]):not([type="checkbox"]),.fg textarea,.fg select{width:100%;min-height:46px;padding:11px 14px;border:2px solid var(--bg2);border-radius:11px;font-size:.94rem;font-family:'DM Sans',sans-serif;transition:border-color .2s,box-shadow .2s;background:var(--w);color:var(--body)}
.fg input:not([type="radio"]):not([type="checkbox"]):focus,.fg textarea:focus,.fg select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(26,175,160,.12)}
.fg textarea{resize:vertical;min-height:126px;line-height:1.55}
.role-field,.subject-field{border:0;padding:0;min-width:0}
.choice-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.choice-pill{position:relative;margin:0!important;cursor:pointer}
.choice-pill input{position:absolute;opacity:0;pointer-events:none}
.choice-pill span{display:flex;align-items:center;justify-content:center;min-height:46px;border:2px solid var(--bg2);border-radius:11px;background:#fbffff;color:var(--body);font-family:'Poppins',sans-serif;font-weight:700;font-size:.9rem;transition:all .18s}
.choice-pill input:checked + span{border-color:var(--teal);background:var(--tl);color:var(--navy);box-shadow:0 0 0 4px rgba(26,175,160,.08)}
.choice-pill input:focus + span{outline:2px solid rgba(26,175,160,.35);outline-offset:2px}
.subject-field,.msg-field{grid-column:1/-1}
.subject-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.subject-options label{display:flex;align-items:center;gap:8px;min-height:42px;margin:0;padding:10px 12px;border:1px solid var(--bg2);border-radius:11px;background:#fbffff;font-family:'DM Sans',sans-serif;font-size:.92rem;font-weight:600;color:var(--body)}
.subject-options input{width:16px;height:16px;accent-color:var(--teal);flex:0 0 auto}
.other-subject-field{display:none;grid-column:1/-1}
.other-subject-field.show{display:block}
.hp-field{display:none!important}
.fs{margin-top:22px;background:var(--teal);color:var(--w);padding:13px 32px;border-radius:50px;border:none;font-weight:800;cursor:pointer;font-size:.95rem;font-family:'Poppins',sans-serif;transition:all .2s;width:100%}
.fs:hover{background:var(--teal-h);box-shadow:0 8px 20px rgba(26,175,160,.28);transform:translateY(-1px)}
.fs:disabled{opacity:.68;cursor:not-allowed;transform:none;box-shadow:none}
.form-status{display:none;margin-top:14px;padding:12px 14px;border-radius:12px;font-size:.9rem;line-height:1.45;text-align:center}
.form-status.ok{display:block;background:rgba(46,160,67,.1);color:#1a4a23;border:1px solid rgba(46,160,67,.18)}
.form-status.warn{display:block;background:rgba(231,76,60,.08);color:#8b2518;border:1px solid rgba(231,76,60,.16)}
.contact-strip{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:12px}
.contact-strip > div{background:rgba(255,255,255,.82);border:1px solid rgba(207,243,239,.95);border-radius:16px;padding:18px 20px;box-shadow:var(--sh)}
.contact-strip span{display:block;font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--navy);margin-bottom:5px}
.contact-strip a{color:var(--teal);text-decoration:none;font-weight:800;word-break:break-word}
.contact-strip a:hover{text-decoration:underline}
.contact-social .si{justify-content:flex-start;margin-top:0}
.si{display:flex;gap:16px;justify-content:center;margin-top:8px}
.si a{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;background:var(--bg);color:var(--navy);transition:all .2s;box-shadow:var(--sh)}
.si a:hover{background:var(--teal);color:var(--w);transform:scale(1.1)}
.si a svg{width:22px;height:22px}

/* FOOTER */
footer{background:linear-gradient(135deg,var(--navy) 0%,#102f52 100%);color:var(--w);padding:46px 24px 22px;position:relative;overflow:hidden}
footer::before{content:'';position:absolute;right:-100px;top:-120px;width:260px;height:260px;border-radius:50%;background:rgba(26,175,160,.12);pointer-events:none}
.fti{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:minmax(260px,1.35fr) repeat(3,minmax(150px,1fr));gap:34px;align-items:start;position:relative;z-index:1}
.ftb img{height:58px;margin-bottom:14px;border-radius:8px;background:rgba(255,255,255,.88)}
.ftb p{color:rgba(255,255,255,.74);font-size:.9rem;line-height:1.65;max-width:380px;margin-bottom:16px}
.footer-cta{display:inline-flex;align-items:center;justify-content:center;background:rgba(26,175,160,.16);color:#dffafa;text-decoration:none;border:1px solid rgba(26,175,160,.35);border-radius:999px;padding:9px 14px;font-family:'Poppins',sans-serif;font-weight:700;font-size:.82rem;transition:all .2s}
.footer-cta:hover{background:var(--teal);color:var(--w);transform:translateY(-1px)}
.ft-col h3{color:var(--w);font-size:.82rem;letter-spacing:1px;text-transform:uppercase;margin-bottom:12px;opacity:.9}
.ftl{display:flex;flex-direction:column;gap:8px}
.ftl a{color:rgba(255,255,255,.68);text-decoration:none;font-size:.88rem;transition:color .2s;cursor:pointer;line-height:1.45}
.ftl a:hover{color:var(--teal)}
.fts{display:flex;gap:10px;justify-content:flex-start;margin-top:16px}
.fts a{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.72);background:rgba(255,255,255,.07);transition:all .2s}
.fts a:hover{color:var(--w);background:var(--teal);transform:translateY(-2px)}
.fts a svg{width:18px;height:18px}
.ftc{max-width:1120px;margin:30px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:rgba(255,255,255,.45);font-size:.78rem;position:relative;z-index:1}

/* BLOG AND FREE RESOURCES */
.blog-hero,.resource-hero{padding:140px 24px 56px;background:linear-gradient(135deg,var(--bg) 0%,#effcfc 100%);position:relative;overflow:hidden}
.blog-hero::before,.resource-hero::before{content:'';position:absolute;right:-80px;top:80px;width:280px;height:280px;border-radius:50%;background:rgba(26,175,160,.12)}
.blog-post-hero{padding-top:72px;border-top:1px solid var(--bg2)}
.blog-hero-inner,.resource-hero-inner{max-width:950px;margin:0 auto;position:relative;z-index:1}
.blog-eyebrow,.resource-kicker{font-family:'Poppins',sans-serif;font-size:.78rem;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--teal);margin-bottom:10px;display:block}
.blog-hero h1,.resource-hero h1{font-size:clamp(2rem,5vw,3.25rem);max-width:900px;margin-bottom:16px}
.blog-hero p,.resource-hero p{font-size:1.06rem;line-height:1.75;color:var(--body);max-width:760px}
.blog-index-s{background:var(--w);padding:28px 24px 8px}
.blog-index-wrap{max-width:1120px;margin:0 auto;background:linear-gradient(135deg,var(--card),#fff);border:1px solid var(--bg2);border-radius:22px;padding:24px;box-shadow:var(--sh)}
.blog-index-head{display:flex;align-items:baseline;justify-content:space-between;gap:18px;margin-bottom:16px;flex-wrap:wrap}
.blog-index-head h2{font-size:1.28rem}
.blog-index-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.blog-index-card{display:block;text-decoration:none;color:inherit;background:var(--w);border:1px solid rgba(207,243,239,.9);border-radius:16px;padding:18px 18px;transition:transform .2s,box-shadow .2s,border-color .2s}
.blog-index-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(13,42,74,.09);border-color:rgba(26,175,160,.42)}
.blog-index-card span{display:block;font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:900;letter-spacing:1.2px;text-transform:uppercase;color:var(--teal);margin-bottom:6px}
.blog-index-card strong{display:block;font-family:'Poppins',sans-serif;color:var(--navy);font-size:1rem;line-height:1.35;margin-bottom:6px;overflow-wrap:break-word}
.blog-index-card small{display:block;color:var(--body);font-size:.86rem;line-height:1.5;overflow-wrap:break-word}
.article-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:22px;max-width:520px}
.article-meta span{background:rgba(255,255,255,.62);border:1px solid rgba(26,175,160,.2);border-radius:999px;padding:9px 14px;font-family:'Poppins',sans-serif;font-size:.78rem;font-weight:700;color:var(--navy);line-height:1.35;box-shadow:0 8px 20px rgba(13,42,74,.04)}
.article-meta span:last-child{white-space:nowrap;color:var(--body);background:rgba(255,255,255,.48)}
.article-s,.resource-s{background:var(--w);padding:54px 24px 70px;position:relative;overflow:hidden}
.article-layout{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:250px minmax(0,1fr);gap:34px;align-items:start}
.article-toc{position:sticky;top:112px;background:var(--card);border:1px solid var(--bg2);border-radius:18px;padding:18px;box-shadow:var(--sh)}
.article-toc strong{display:block;font-family:'Poppins',sans-serif;color:var(--navy);font-size:.9rem;margin-bottom:10px}
.article-toc a{display:block;color:var(--body);text-decoration:none;font-size:.84rem;line-height:1.45;padding:7px 0;border-top:1px solid rgba(207,243,239,.85)}
.article-toc a:hover{color:var(--teal)}
.article-body{background:#fff;border:1px solid var(--bg2);border-radius:22px;padding:38px 42px;box-shadow:0 18px 48px rgba(13,42,74,.08)}
.article-body h2{font-size:1.55rem;margin:34px 0 12px}
.article-body h2:first-child{margin-top:0}
.article-body h3{font-size:1.08rem;margin:24px 0 8px}
.article-body h4{font-family:'Poppins',sans-serif;font-size:1rem;line-height:1.35;color:var(--navy);margin:22px 0 8px}
.article-body .article-group-heading{font-size:.88rem;letter-spacing:1px;text-transform:uppercase;color:var(--teal);border-bottom:1px solid var(--bg2);padding-bottom:8px;margin:24px 0 14px}
.article-body p{font-size:1rem;line-height:1.82;margin-bottom:16px;color:var(--body)}
.article-body ul{margin:0 0 22px 22px}
.article-body li{margin-bottom:8px;line-height:1.65}
.article-body a{color:var(--teal);font-weight:700;text-decoration:underline;text-underline-offset:3px}
.article-rule{border:none;border-top:1px solid var(--bg2);margin:28px 0}
.article-callout{background:var(--tl);border-left:4px solid var(--teal);border-radius:14px;padding:18px 20px;margin:22px 0;font-family:'Poppins',sans-serif;font-weight:800;color:var(--navy);font-size:1.05rem}
.article-table-wrap{overflow-x:auto;margin:18px 0 24px;border-radius:14px;border:1px solid var(--bg2)}
.article-body table{width:100%;border-collapse:collapse;background:var(--w);min-width:0}
.article-body th,.article-body td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--bg2);font-size:.93rem}
.article-body th{background:var(--card);font-family:'Poppins',sans-serif;color:var(--navy);font-size:.82rem;text-transform:uppercase;letter-spacing:.7px}
.article-body tr:last-child td{border-bottom:none}
.admissions-summary table{table-layout:fixed}
.admissions-summary th,.admissions-summary td{padding:10px 11px;font-size:.82rem;line-height:1.45;vertical-align:top}
.admissions-summary th{font-size:.68rem;letter-spacing:.55px}
.admissions-summary td:first-child{font-family:'Poppins',sans-serif;font-weight:800;color:var(--navy)}
.article-checklist{list-style:none!important;margin-left:0!important;display:grid;gap:8px}
.article-checklist li{background:var(--card);border:1px solid var(--bg2);border-radius:12px;padding:10px 12px 10px 38px;position:relative;margin:0!important}
.article-checklist li::before{content:'';position:absolute;left:13px;top:15px;width:13px;height:13px;border-radius:4px;border:2px solid var(--teal);background:#fff}
.article-cta{margin-top:34px;background:linear-gradient(135deg,var(--navy),#17476b);color:var(--w);border-radius:18px;padding:22px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.article-cta strong{display:block;color:var(--w);font-family:'Poppins',sans-serif;font-size:1.05rem;margin-bottom:4px}
.article-cta span{display:block;color:rgba(255,255,255,.75);font-size:.9rem}
.article-nav-card{margin-top:16px;background:var(--card);border:1px solid var(--bg2);border-radius:16px;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.article-nav-card span{font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:900;letter-spacing:1.2px;text-transform:uppercase;color:var(--teal);white-space:nowrap}
.article-nav-card a{font-family:'Poppins',sans-serif;font-weight:800;color:var(--navy);text-decoration:none;line-height:1.35}
.article-nav-card a:hover{color:var(--teal);text-decoration:none}
.resource-wrap{max-width:1120px;margin:0 auto}
.resource-intro{text-align:center;margin:0 auto 28px;max-width:720px}
.resource-intro h2{font-size:1.8rem;margin-bottom:8px}
.resource-intro p{color:var(--body);font-size:.97rem}
.resource-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.resource-card{background:var(--card);border:1px solid var(--bg2);border-radius:18px;padding:24px 22px;text-decoration:none;color:inherit;box-shadow:var(--sh);min-height:250px;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s}
.resource-card:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(13,42,74,.11);border-color:rgba(26,175,160,.45)}
.resource-card h3{font-size:1.08rem;margin-bottom:10px}
.resource-card p{font-size:.92rem;line-height:1.65;color:var(--body);margin-bottom:18px}
.resource-link{margin-top:auto;color:var(--teal);font-family:'Poppins',sans-serif;font-weight:800;font-size:.86rem}
.resource-card-muted{background:linear-gradient(135deg,#f7fdfd,#fff);border-style:dashed;box-shadow:none}
.resource-card-muted:hover{transform:none;box-shadow:none}
@media(max-width:980px){
.article-s{padding:34px 14px 56px;overflow:hidden}
.article-layout{display:block;width:100%;max-width:100%;min-width:0}
.article-toc{display:none}
.article-body{width:100%;max-width:100%;min-width:0;padding:30px 22px;border-radius:18px}
.article-body h2{font-size:1.42rem;line-height:1.24;margin:30px 0 10px}
.article-body h3{font-size:1.05rem;line-height:1.36;margin:22px 0 8px}
.article-body h4{font-size:.98rem;line-height:1.34}
.article-body .article-group-heading{font-size:.82rem;line-height:1.35;margin-top:24px}
.article-body h2,.article-body h3,.article-body h4,.article-body p,.article-body li{max-width:100%;overflow-wrap:break-word;word-break:normal}
.article-body p{font-size:1rem;line-height:1.72}
.article-table-wrap{width:100%;max-width:100%;overflow-x:visible;margin:16px 0 22px}
.article-body table{width:100%;min-width:0;table-layout:auto}
.article-body th,.article-body td{white-space:normal;overflow-wrap:break-word}
.admissions-summary table{table-layout:fixed}
.resource-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:820px){
.blog-hero,.blog-index-s{width:100%;max-width:100%;margin-left:0;margin-right:0}
.blog-hero{padding:112px 20px 42px}
.blog-hero-inner,.blog-index-wrap{max-width:640px}
.blog-hero h1{font-size:clamp(2rem,7.5vw,2.75rem);line-height:1.12}
.blog-hero p{font-size:1rem;line-height:1.65}
.blog-index-s{padding:20px 18px 10px}
.blog-index-wrap{padding:20px;border-radius:20px}
.blog-index-head{display:block;margin-bottom:14px}
.blog-index-head h2{font-size:1.18rem;margin-top:3px}
.blog-index-grid{grid-template-columns:1fr;gap:12px}
.blog-index-card{border-radius:18px;padding:20px 18px;background:linear-gradient(135deg,#fbffff,#fff);box-shadow:0 12px 28px rgba(13,42,74,.06)}
.blog-index-card span{font-size:.68rem;letter-spacing:1px}
.blog-index-card strong{font-size:1.08rem;line-height:1.32}
.blog-index-card small{font-size:.9rem;line-height:1.55;display:block;overflow:visible}
}
@media(max-width:600px){.resource-hero{padding:118px 18px 42px}.resource-s{padding:34px 14px 48px}.resource-grid{grid-template-columns:1fr}.resource-card{min-height:0}}

@media(max-width:600px){
.blog-hero{padding:106px 16px 34px;border-bottom:1px solid rgba(207,243,239,.82)}
.blog-hero::before{right:-118px;top:72px;width:238px;height:238px;background:rgba(26,175,160,.1)}
.blog-eyebrow{font-size:.68rem;letter-spacing:1.2px;margin-bottom:8px}
.blog-hero h1{font-size:clamp(1.72rem,8.4vw,2.25rem);line-height:1.12;margin-bottom:12px}
.blog-hero p{font-size:.94rem;line-height:1.62;max-width:100%}
.article-meta{gap:8px;max-width:100%;margin-top:18px}
.article-meta span{min-height:36px;padding:9px 12px;font-size:.73rem;line-height:1.25}
.article-meta span:last-child{white-space:nowrap}
.blog-index-s{padding:16px 12px 2px}
.blog-index-wrap{padding:0;background:transparent;border:0;border-radius:0;box-shadow:none}
.blog-index-head{padding:0 2px;margin-bottom:12px}
.blog-index-head h2{font-size:1.06rem}
.blog-index-grid{gap:12px}
.blog-index-card{border-radius:18px;padding:18px 16px 20px;background:linear-gradient(135deg,#f5fdfc,#fff);box-shadow:0 12px 32px rgba(13,42,74,.08);min-height:0}
.blog-index-card span{font-size:.66rem;letter-spacing:1px}
.blog-index-card strong{font-size:1.02rem;line-height:1.3}
.blog-index-card small{font-size:.88rem;line-height:1.55}
.article-s{padding:22px 10px 44px;background:linear-gradient(180deg,#fff 0%,#f8fdfd 100%)}
.article-toc{display:none}
.article-body{padding:24px 16px;border-radius:18px;box-shadow:0 12px 32px rgba(13,42,74,.06)}
.article-body h2{font-size:1.34rem;line-height:1.24;margin:30px 0 10px}
.article-body h3{font-size:1.03rem;line-height:1.36;margin:22px 0 8px}
.article-body h4{font-size:.98rem;line-height:1.35;margin:20px 0 8px}
.article-body .article-group-heading{font-size:.78rem;line-height:1.4;margin:24px 0 12px}
.article-body h2,.article-body h3,.article-body h4,.article-body p,.article-body li{overflow-wrap:break-word}
.article-body p{font-size:1rem;line-height:1.74;margin-bottom:15px}
.article-body ul{margin:0 0 20px 18px}
.article-body li{font-size:.98rem;line-height:1.6;margin-bottom:9px}
.article-rule{margin:26px 0}
.article-callout{border-radius:14px;padding:16px;margin:20px 0;font-size:.98rem;line-height:1.45}
.article-table-wrap{margin:16px -2px 22px;-webkit-overflow-scrolling:touch}
.article-body table{min-width:0}
.article-body th,.article-body td{padding:11px 12px;font-size:.86rem}
.article-body th{font-size:.72rem;letter-spacing:.55px}
.admissions-summary{border:0;background:transparent;overflow:visible}
.admissions-summary table,.admissions-summary thead,.admissions-summary tbody,.admissions-summary tr,.admissions-summary td{display:block;width:100%}
.admissions-summary thead{display:none}
.admissions-summary tr{background:var(--w);border:1px solid var(--bg2);border-radius:14px;margin-bottom:10px;box-shadow:0 8px 20px rgba(13,42,74,.05);overflow:hidden}
.admissions-summary td{padding:10px 12px;font-size:.8rem;line-height:1.45;border-bottom:1px solid var(--bg2)}
.admissions-summary td::before{content:attr(data-label);display:block;font-family:'Poppins',sans-serif;font-size:.62rem;font-weight:900;letter-spacing:.65px;text-transform:uppercase;color:var(--teal);margin-bottom:3px}
.admissions-summary td:first-child{font-size:.9rem;background:var(--card)}
.admissions-summary td:first-child::before{display:none}
.admissions-summary td:last-child{border-bottom:0}
.article-checklist{gap:10px}
.article-checklist li{border-radius:14px;padding:12px 12px 12px 40px}
.article-checklist li::before{top:16px}
.article-cta{display:block;margin-top:30px;border-radius:18px;padding:18px}
.article-cta strong{font-size:1rem;line-height:1.35}
.article-cta span{font-size:.88rem;line-height:1.5;margin-bottom:14px}
.article-cta .cb{display:block;width:100%;padding:13px 16px;text-align:center}
.article-nav-card{display:block;border-radius:16px;padding:15px;background:linear-gradient(135deg,var(--card),#fff)}
.article-nav-card span{display:block;margin-bottom:7px}
.article-nav-card a{font-size:.95rem;line-height:1.4}
}

@media(max-width:380px){
.blog-hero{padding-left:14px;padding-right:14px}
.blog-hero h1{font-size:1.58rem}
.blog-hero p{font-size:.9rem}
.article-meta span{font-size:.7rem}
.article-body{padding:22px 14px}
.article-body table{min-width:0}
}

.fi-a,.scroll-animate{opacity:0;transform:translateY(12px);transition:opacity .42s ease,transform .42s ease,box-shadow .25s ease,border-color .25s ease}
.fi-a.vis,.scroll-animate.vis{opacity:1;transform:translateY(0)}
.scroll-animate.from-left{transform:translateX(-12px)}
.scroll-animate.from-right{transform:translateX(12px)}
.scroll-animate.scale-in{transform:translateY(10px) scale(.99)}
.scroll-animate.from-left.vis,.scroll-animate.from-right.vis,.scroll-animate.scale-in.vis{transform:translate(0,0) scale(1)}
@media(max-width:768px){
.fi-a,.scroll-animate{opacity:1!important;transform:none!important;transition:none!important}
}
@media(prefers-reduced-motion:reduce){
*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}
.fi-a,.scroll-animate{opacity:1!important;transform:none!important}
}

/* UCAT SCORE CALCULATOR */
.cal-s{padding:60px 24px;background:var(--w);position:relative;overflow:hidden}
.cal-s::before{content:'';position:absolute;top:-100px;right:-100px;width:300px;height:300px;border-radius:50%;background:var(--tl);pointer-events:none}
.cal-s::after{content:'';position:absolute;bottom:-80px;left:-80px;width:200px;height:200px;border-radius:50%;background:rgba(26,175,160,.04);pointer-events:none}
.cal-wrap{max-width:880px;margin:0 auto;position:relative;z-index:1}
.cal-intro{text-align:center;max-width:720px;margin:0 auto 32px}
.cal-intro p{font-size:.97rem;line-height:1.75;margin-bottom:10px}
.cal-intro .cal-note{font-size:.85rem;color:var(--body);opacity:.75;font-style:italic}
.cal-total{background:linear-gradient(135deg,var(--navy) 0%,#1a4a6a 100%);color:var(--w);border-radius:20px;padding:28px 28px;text-align:center;box-shadow:0 10px 30px rgba(13,42,74,.18);margin-bottom:28px;position:relative;overflow:hidden}
.cal-total::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:rgba(26,175,160,.18);pointer-events:none}
.cal-total::after{content:'';position:absolute;bottom:-40px;left:-40px;width:120px;height:120px;border-radius:50%;background:rgba(26,175,160,.08);pointer-events:none}
.cal-total-label{font-family:'Poppins',sans-serif;font-weight:600;font-size:.85rem;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:8px;position:relative;z-index:1}
.cal-total-score{font-family:'Poppins',sans-serif;font-weight:800;font-size:clamp(2.4rem,6vw,3.4rem);line-height:1;color:var(--w);position:relative;z-index:1;display:flex;align-items:baseline;gap:10px;justify-content:center;flex-wrap:wrap}
.cal-total-score #cogTotal{color:var(--w)}
.cal-total-score.flash #cogTotal{animation:calFlash .6s ease}
.cal-total-max{font-size:1rem;font-weight:600;color:rgba(255,255,255,.65);letter-spacing:.5px}
.cal-total-sub{font-family:'Poppins',sans-serif;font-size:.78rem;color:rgba(255,255,255,.55);margin-top:8px;letter-spacing:1px;text-transform:uppercase;position:relative;z-index:1}
@keyframes calFlash{0%{transform:scale(1)}40%{transform:scale(1.08);color:var(--teal)}100%{transform:scale(1)}}
.cal-card{background:var(--card);border-radius:18px;padding:26px 26px;box-shadow:var(--sh);border-left:4px solid var(--teal);margin-bottom:20px;transition:transform .2s,box-shadow .2s}
.cal-card:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(13,42,74,.08)}
.cal-card-sjt{border-left-color:#5a7fa6;background:#f0f6fa}
.cal-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap;margin-bottom:18px}
.cal-card-eyebrow{font-family:'Poppins',sans-serif;font-size:.7rem;font-weight:700;color:var(--teal);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px}
.cal-card-sjt .cal-card-eyebrow{color:#5a7fa6}
.cal-card-head h3{font-size:1.15rem;margin-bottom:4px}
.cal-card-desc{font-size:.85rem;color:var(--body);opacity:.85;line-height:1.5;max-width:440px}
.cal-card-score{font-family:'Poppins',sans-serif;font-weight:800;font-size:clamp(1.6rem,4vw,2rem);color:var(--teal);line-height:1;display:flex;align-items:baseline;gap:6px;flex-shrink:0;text-align:right}
.cal-card-sjt .cal-card-score{color:#5a7fa6}
.cal-card-score.flash > span:first-child{animation:calFlash .5s ease}
.cal-card-max{font-size:.78rem;font-weight:600;color:var(--body);opacity:.55;letter-spacing:.5px}
.cal-toggle{display:inline-flex;background:var(--bg2);padding:4px;border-radius:50px;margin-bottom:18px}
.cal-toggle-btn{background:transparent;border:none;font-family:'Poppins',sans-serif;font-weight:600;font-size:.85rem;color:var(--body);padding:8px 22px;border-radius:50px;cursor:pointer;transition:all .2s}
.cal-toggle-btn.act{background:var(--teal);color:var(--w);box-shadow:0 2px 10px rgba(26,175,160,.3)}
.cal-toggle-btn:hover:not(.act){color:var(--teal)}
.cal-inputs{display:block}
.cal-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cal-fg{margin-bottom:0}
.cal-fg label{display:block;font-size:.85rem;font-weight:600;color:var(--navy);margin-bottom:6px;font-family:'Poppins',sans-serif}
.cal-fg .cal-max{font-weight:500;color:var(--body);opacity:.65;font-size:.78rem;margin-left:4px}
.cal-fg input{width:100%;padding:12px 16px;border:2px solid var(--bg2);border-radius:10px;font-size:1rem;font-family:'Poppins',sans-serif;font-weight:600;color:var(--navy);background:var(--w);transition:border-color .2s,box-shadow .2s;-moz-appearance:textfield}
.cal-fg input::-webkit-outer-spin-button,.cal-fg input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.cal-fg input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(26,175,160,.12)}
.cal-fg input.err{border-color:#e74c3c;box-shadow:0 0 0 4px rgba(231,76,60,.1)}
.cal-error{color:#e74c3c;font-size:.82rem;font-weight:600;margin-top:10px;min-height:1.2em;font-family:'Poppins',sans-serif}
.cal-divider{display:flex;align-items:center;gap:14px;margin:34px 0 24px;color:var(--body);opacity:.55}
.cal-divider::before,.cal-divider::after{content:'';flex:1;height:1px;background:var(--bg2)}
.cal-divider span{font-family:'Poppins',sans-serif;font-size:.78rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase}
.cal-actions{text-align:center;margin-top:28px}
.cal-actions .db{background:var(--w);color:var(--teal);border:2px solid var(--teal)}
.cal-actions .db:hover{background:var(--teal);color:var(--w)}
.cal-disclaimer{margin-top:32px;padding:18px 22px;background:var(--bg2);border-radius:12px;font-size:.82rem;line-height:1.6;color:var(--body)}
.cal-disclaimer p{margin:0}
.cal-percentile{margin-top:32px;background:var(--card);border:2px solid var(--teal);border-radius:18px;padding:26px 28px;display:flex;align-items:flex-start;gap:20px;box-shadow:var(--sh)}
.cal-percentile-icon{width:54px;height:54px;border-radius:50%;background:var(--tl);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--teal)}
.cal-percentile-icon svg{width:26px;height:26px}
.cal-percentile-text{flex:1}
.cal-percentile-text h3{font-size:1.05rem;margin-bottom:6px}
.cal-percentile-text p{font-size:.92rem;line-height:1.65;margin-bottom:14px;color:var(--body)}
.cal-percentile-text .cb{display:inline-block}
@media(max-width:600px){
.cal-percentile{flex-direction:column;align-items:flex-start;padding:22px 20px}
}

@media(max-width:600px){
.cal-card{padding:22px 20px}
.cal-card-head{flex-direction:column;gap:6px}
.cal-card-score{align-self:flex-start;font-size:1.6rem}
.cal-grid-2{grid-template-columns:1fr;gap:14px}
.cal-toggle-btn{padding:7px 18px;font-size:.82rem}
.cal-total{padding:24px 20px}
}

/* UCAT MENTAL MATHS TRAINER */
.mm-s{padding:60px 24px;background:var(--w);position:relative;overflow:hidden}
.mm-s::before{content:'';position:absolute;top:-100px;right:-100px;width:300px;height:300px;border-radius:50%;background:var(--tl);pointer-events:none}
.mm-s::after{content:'';position:absolute;bottom:-80px;left:-80px;width:200px;height:200px;border-radius:50%;background:rgba(26,175,160,.04);pointer-events:none}
.mm-wrap{max-width:1080px;margin:0 auto;position:relative;z-index:1}

/* Setup screen */
.mm-setup{background:var(--card);border-radius:20px;padding:36px 32px;box-shadow:var(--sh);border-left:4px solid var(--teal)}
.mm-setup h2{font-size:1.35rem;margin-bottom:6px}
.mm-setup-sub{color:var(--body);font-size:.92rem;margin-bottom:24px;line-height:1.6}
.mm-mode-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--w);border:1px solid var(--bg2);border-radius:14px;padding:5px;gap:5px;margin-bottom:22px}
.mm-mode-tab{border:none;background:transparent;color:var(--body);border-radius:10px;padding:12px 14px;font-family:'Poppins',sans-serif;font-weight:800;font-size:.88rem;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}
.mm-mode-tab.act{background:var(--navy);color:var(--w);box-shadow:0 8px 18px rgba(13,42,74,.16)}
.mm-ranked-note{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,300px);gap:14px;align-items:center;background:var(--w);border:1px solid var(--bg2);border-radius:16px;padding:14px;margin-bottom:22px}
.mm-ranked-rules strong{display:block;font-family:'Poppins',sans-serif;color:var(--navy);font-size:.95rem;margin-bottom:2px}
.mm-ranked-rules span{display:block;color:var(--body);font-size:.82rem;line-height:1.45}
.mm-name-field{display:grid;gap:6px;font-family:'Poppins',sans-serif;font-size:.74rem;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:var(--navy)}
.mm-name-field input,.mm-ranked-submit-row input{width:100%;border:2px solid var(--bg2);border-radius:12px;padding:12px 14px;font-family:'Poppins',sans-serif;font-weight:700;font-size:.95rem;color:var(--navy);background:var(--w);text-transform:none;letter-spacing:0}
.mm-name-field input:focus,.mm-ranked-submit-row input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(26,175,160,.12)}
.mm-fld{margin-bottom:22px}
.mm-fld-label{display:block;font-family:'Poppins',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:1.2px;text-transform:uppercase;color:var(--navy);margin-bottom:10px}
.mm-pill-row{display:flex;flex-wrap:wrap;gap:8px}
.mm-pill{background:var(--w);border:2px solid var(--bg2);color:var(--navy);font-family:'Poppins',sans-serif;font-weight:600;font-size:.85rem;padding:8px 18px;border-radius:50px;cursor:pointer;transition:all .15s}
.mm-pill:hover{border-color:var(--teal);color:var(--teal)}
.mm-pill.act{background:var(--teal);border-color:var(--teal);color:var(--w);box-shadow:0 2px 10px rgba(26,175,160,.3)}
.mm-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}
.mm-cat-pill{background:var(--w);border:2px solid var(--bg2);color:var(--navy);font-family:'Poppins',sans-serif;font-weight:600;font-size:.82rem;padding:9px 14px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:all .15s;text-align:left}
.mm-cat-pill:hover{border-color:var(--teal)}
.mm-cat-pill.act{background:var(--tl);border-color:var(--teal);color:var(--teal)}
.mm-cat-pill .mm-tick{width:16px;height:16px;border-radius:4px;border:2px solid var(--bg2);flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--w);transition:all .15s}
.mm-cat-pill.act .mm-tick{background:var(--teal);border-color:var(--teal)}
.mm-cat-pill .mm-tick svg{width:10px;height:10px;color:var(--w);opacity:0;transition:opacity .15s}
.mm-cat-pill.act .mm-tick svg{opacity:1}
.mm-cat-helpers{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.mm-cat-helpers button{background:transparent;border:none;color:var(--teal);font-family:'Poppins',sans-serif;font-weight:600;font-size:.78rem;cursor:pointer;text-decoration:underline;padding:2px 4px}
.mm-cat-helpers button:hover{color:var(--teal-h)}
.mm-start-row{display:flex;justify-content:center;margin-top:8px}
.mm-start-row .cb{font-size:1rem;padding:14px 38px}

/* Trainer screen */
.mm-grid{display:grid;grid-template-columns:1fr;gap:20px;align-items:flex-start}
.mm-main{display:grid;gap:14px}
.mm-bar{display:flex;justify-content:space-between;align-items:center;gap:14px;background:var(--card);border:1px solid var(--bg2);border-radius:16px;padding:12px 14px;box-shadow:0 8px 24px rgba(13,42,74,.06)}
.mm-bar-left{display:flex;align-items:center;gap:12px;flex-wrap:nowrap;min-width:0;flex:1}
.mm-pill-mini{background:var(--tl);color:var(--teal);font-family:'Poppins',sans-serif;font-weight:700;font-size:.74rem;letter-spacing:.5px;text-transform:uppercase;padding:5px 12px;border-radius:50px}
.mm-pill-mini.diff-easy{background:rgba(46,160,67,.12);color:#2ea043}
.mm-pill-mini.diff-medium{background:rgba(232,143,38,.14);color:#cc7a1a}
.mm-pill-mini.diff-hard{background:rgba(231,76,60,.12);color:#c0392b}
.mm-progress{flex:1;height:8px;background:var(--bg2);border-radius:50px;overflow:hidden;min-width:90px}
.mm-progress-fill{height:100%;background:var(--navy);transition:width .3s;border-radius:50px}
.mm-timer{font-family:'Poppins',sans-serif;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:5px;font-size:.95rem;flex-shrink:0}
.mm-timer svg{width:16px;height:16px;color:var(--body);opacity:.7}
.mm-timer.warn{color:#e89020}
.mm-timer.crit{color:#e74c3c}
.mm-q-card{background:linear-gradient(135deg,#ffffff 0%,#f4fbfa 100%);border-radius:26px 10px 26px 10px;padding:42px 46px 36px;box-shadow:0 18px 44px rgba(13,42,74,.08);border:1px solid var(--bg2);border-left:5px solid var(--teal);text-align:left;position:relative;overflow:hidden}
.mm-q-card::before{content:'';position:absolute;right:-90px;top:-100px;width:220px;height:220px;border-radius:50%;background:rgba(26,175,160,.08);pointer-events:none}
.mm-q-cat{font-family:'Poppins',sans-serif;font-weight:800;font-size:.76rem;letter-spacing:1.8px;text-transform:uppercase;color:var(--teal);margin-bottom:14px;position:relative;z-index:1}
.mm-q-text{font-family:'Poppins',sans-serif;font-weight:800;color:var(--navy);font-size:clamp(1.9rem,4.2vw,2.8rem);line-height:1.18;margin-bottom:14px;min-height:78px;display:flex;align-items:center;justify-content:flex-start;flex-wrap:wrap;gap:6px;position:relative;z-index:1;max-width:850px}
.mm-q-hint{font-size:.86rem;color:var(--body);opacity:.75;margin-bottom:24px;line-height:1.5;min-height:18px;position:relative;z-index:1}
.mm-form{display:flex;gap:12px;justify-content:flex-start;align-items:stretch;max-width:560px;margin:0;position:relative;z-index:1}
.mm-input{flex:1;padding:14px 18px;border:2px solid var(--bg2);border-radius:12px;font-family:'Poppins',sans-serif;font-weight:600;font-size:1.1rem;color:var(--navy);background:var(--w);text-align:center;transition:all .15s;-moz-appearance:textfield}
.mm-input::-webkit-outer-spin-button,.mm-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.mm-input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(26,175,160,.12)}
.mm-input.shake{animation:mmShake .4s}
@keyframes mmShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
.mm-submit{background:var(--teal);color:var(--w);border:none;border-radius:12px;padding:0 22px;cursor:pointer;font-size:.95rem;font-family:'Poppins',sans-serif;font-weight:800;display:flex;align-items:center;justify-content:center;transition:all .15s;min-width:108px;letter-spacing:.2px}
.mm-submit:hover{background:var(--teal-h);transform:translateX(2px)}
.mm-submit:disabled{background:var(--bg2);color:var(--body);cursor:not-allowed;transform:none}
.mm-fb{margin-top:18px;padding:14px 18px;border-radius:12px;font-size:.92rem;line-height:1.55;display:none;text-align:left;position:relative;z-index:1}
.mm-fb.show{display:block;animation:mmSlide .25s ease}
@keyframes mmSlide{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.mm-fb.correct{background:rgba(46,160,67,.1);border-left:4px solid #2ea043;color:#1a4a23}
.mm-fb.wrong{background:rgba(231,76,60,.08);border-left:4px solid #e74c3c;color:#5a1c14}
.mm-fb.skipped{background:rgba(13,42,74,.06);border-left:4px solid var(--navy);color:var(--navy)}
.mm-fb-head{font-family:'Poppins',sans-serif;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.mm-fb-tip{font-size:.88rem;color:var(--body);margin-top:4px}
.mm-fb-tip strong{color:var(--navy)}
.mm-controls{display:flex;justify-content:flex-start;gap:10px;margin-top:0;background:var(--card);border:1px solid var(--bg2);border-radius:18px;padding:10px;box-shadow:0 8px 24px rgba(13,42,74,.05)}
.mm-controls .db{flex:0 1 auto;min-width:180px;background:var(--w);color:var(--teal);border:2px solid var(--teal);font-weight:600;font-family:'Poppins',sans-serif;padding:10px 18px;border-radius:12px;cursor:pointer;font-size:.88rem;transition:all .15s}
.mm-controls .db:hover{background:var(--tl)}
.mm-controls .db.danger{color:#c0392b;border-color:#c0392b}
.mm-controls .db.danger:hover{background:rgba(231,76,60,.08)}

/* Sidebar */
.mm-side{display:grid;grid-template-columns:minmax(250px,.72fr) minmax(300px,1fr) minmax(360px,1.2fr);gap:14px;position:static;align-items:stretch;order:-1}
.mm-card{background:rgba(244,251,250,.88);border:1px solid var(--bg2);border-radius:20px;padding:20px 22px;box-shadow:0 12px 34px rgba(13,42,74,.06)}
.mm-card h3{font-family:'Poppins',sans-serif;font-size:1rem;margin-bottom:14px;display:flex;align-items:center;gap:8px;color:var(--navy)}
.mm-card h3 svg{width:18px;height:18px;color:var(--teal)}
.mm-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mm-stat{background:var(--w);border-radius:14px;padding:14px 12px;text-align:center;border:1px solid rgba(207,243,239,.7)}
.mm-stat-val{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.45rem;color:var(--navy);line-height:1;display:block;margin-bottom:4px}
.mm-stat-val.ok{color:var(--teal)}
.mm-stat-val.warn{color:#cc7a1a}
.mm-stat-val.bad{color:#c0392b}
.mm-stat-val .mm-stat-emoji{font-size:1rem;margin-left:3px}
.mm-stat-label{font-size:.74rem;color:var(--body);opacity:.75;font-weight:600;letter-spacing:.4px}
.mm-cats-list{display:grid;grid-template-columns:1fr 1fr;column-gap:16px;row-gap:10px}
.mm-cat-row{display:flex;flex-direction:column;gap:4px}
.mm-cat-row-head{display:flex;justify-content:space-between;align-items:center;font-family:'Poppins',sans-serif;font-size:.85rem;color:var(--navy);font-weight:500}
.mm-cat-row-head .mm-cat-acc{font-weight:700;font-size:.78rem;color:var(--body);opacity:.7}
.mm-cat-row-head .mm-cat-acc.has{opacity:1}
.mm-cat-row-head .mm-cat-acc.has.ok{color:var(--teal)}
.mm-cat-row-head .mm-cat-acc.has.warn{color:#cc7a1a}
.mm-cat-row-head .mm-cat-acc.has.bad{color:#c0392b}
.mm-cat-bar{height:3px;background:var(--bg2);border-radius:50px;overflow:hidden}
.mm-cat-bar-fill{height:100%;background:var(--navy);width:0;transition:width .4s,background .2s;border-radius:50px}
.mm-cat-bar-fill.ok{background:var(--teal)}
.mm-cat-bar-fill.warn{background:#cc7a1a}
.mm-cat-bar-fill.bad{background:#c0392b}

/* Results screen */
.mm-results{background:linear-gradient(135deg,var(--navy) 0%,#1a4a6a 100%);color:var(--w);border-radius:20px;padding:38px 32px;text-align:center;box-shadow:0 10px 30px rgba(13,42,74,.18);position:relative;overflow:hidden}
.mm-results::before{content:'';position:absolute;top:-30px;right:-30px;width:140px;height:140px;border-radius:50%;background:rgba(26,175,160,.18);pointer-events:none}
.mm-results-eyebrow{font-family:'Poppins',sans-serif;font-weight:600;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:8px;position:relative;z-index:1}
.mm-results-score{font-family:'Poppins',sans-serif;font-weight:800;font-size:clamp(2.4rem,6vw,3.4rem);line-height:1;margin-bottom:6px;position:relative;z-index:1}
.mm-results-sub{font-size:.95rem;color:rgba(255,255,255,.78);margin-bottom:24px;position:relative;z-index:1}
.mm-results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:22px;position:relative;z-index:1}
.mm-results-grid > div{background:rgba(255,255,255,.08);border-radius:12px;padding:14px 10px}
.mm-results-grid > div strong{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.4rem;color:var(--w);display:block;margin-bottom:3px}
.mm-results-grid > div span{font-size:.74rem;color:rgba(255,255,255,.65);font-weight:600;letter-spacing:.4px}
.mm-results-actions{display:flex;justify-content:center;gap:10px;position:relative;z-index:1;flex-wrap:wrap}
.mm-results-actions .cb{background:var(--teal)}
.mm-results-actions .db{background:transparent;color:var(--w);border:2px solid rgba(255,255,255,.4);font-family:'Poppins',sans-serif;font-weight:600;padding:10px 22px;border-radius:50px;cursor:pointer;font-size:.92rem;transition:all .15s}
.mm-results-actions .db:hover{background:rgba(255,255,255,.1);border-color:var(--w)}

/* Best record banner (persistent) */
.mm-best-banner{margin-top:18px;background:var(--card);border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:14px;box-shadow:var(--sh);border-left:4px solid var(--teal);font-size:.88rem;color:var(--body)}
.mm-best-banner strong{color:var(--navy)}
.mm-leaderboard{margin-top:18px;background:var(--w);border:1px solid var(--bg2);border-radius:18px;padding:18px;box-shadow:0 12px 30px rgba(13,42,74,.07)}
.mm-lb-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.mm-lb-head span{display:block;font-size:.72rem;font-family:'Poppins',sans-serif;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--teal)}
.mm-lb-head strong{display:block;font-family:'Poppins',sans-serif;color:var(--navy);font-size:1rem}
.mm-lb-head button{border:1px solid var(--bg2);background:var(--card);color:var(--navy);border-radius:10px;padding:8px 12px;font-family:'Poppins',sans-serif;font-weight:700;font-size:.78rem;cursor:pointer}
.mm-lb-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.mm-lb-list li{display:grid;grid-template-columns:48px minmax(0,1fr) auto;align-items:center;gap:10px;background:var(--card);border:1px solid rgba(207,243,239,.75);border-radius:12px;padding:10px 12px}
.mm-lb-rank{font-family:'Poppins',sans-serif;font-weight:900;color:var(--teal)}
.mm-lb-person{min-width:0}
.mm-lb-person strong{display:block;color:var(--navy);font-family:'Poppins',sans-serif;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mm-lb-person small{display:block;color:var(--body);font-size:.76rem;line-height:1.35}
.mm-lb-score{font-family:'Poppins',sans-serif;font-weight:900;color:var(--navy)}
.mm-lb-empty{display:block!important;color:var(--body);font-size:.86rem;text-align:center}
.mm-lb-status,.mm-submit-status{font-size:.78rem;color:var(--body);margin-top:10px;line-height:1.45}
.mm-lb-status.ok,.mm-submit-status.ok{color:var(--teal)}
.mm-lb-status.warn,.mm-submit-status.warn{color:#c0392b}

/* Points card (sidebar hero) */
.mm-points-card{background:linear-gradient(135deg,var(--navy) 0%,#1a4a6a 100%);color:var(--w);padding:22px 22px;position:relative;overflow:hidden;border-radius:20px 20px 8px 20px}
.mm-points-card::before{content:'';position:absolute;top:-30px;right:-30px;width:110px;height:110px;border-radius:50%;background:rgba(26,175,160,.18);pointer-events:none}
.mm-points-card::after{content:'';position:absolute;bottom:-40px;left:-40px;width:110px;height:110px;border-radius:50%;background:rgba(26,175,160,.08);pointer-events:none}
.mm-points-label{font-family:'Poppins',sans-serif;font-weight:600;font-size:.74rem;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.75);position:relative;z-index:1}
.mm-points-val{font-family:'Poppins',sans-serif;font-weight:800;font-size:2.4rem;color:var(--w);line-height:1;margin:6px 0 4px;position:relative;z-index:1}
.mm-points-val.flash{animation:calFlash .6s ease}
.mm-points-sub{font-size:.8rem;color:rgba(255,255,255,.7);position:relative;z-index:1;line-height:1.5}
.mm-points-sub strong{color:var(--w)}

/* Calculator trigger (in controls) */
.mm-controls .db.mm-calc-trigger{color:var(--navy);border-color:var(--bg2);display:flex;align-items:center;justify-content:center;gap:6px}
.mm-controls .db.mm-calc-trigger:hover{background:var(--bg2);border-color:var(--navy)}
.mm-controls .db.mm-calc-trigger .mm-calc-pen{background:rgba(231,76,60,.12);color:#c0392b;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:50px;letter-spacing:.3px}
.mm-controls .db.mm-calc-trigger.used{background:rgba(231,76,60,.06);border-color:#e89020;color:#cc7a1a}

/* Calc-used badge in feedback */
.mm-fb-calc{display:inline-block;background:rgba(231,76,60,.12);color:#c0392b;font-family:'Poppins',sans-serif;font-size:.74rem;font-weight:700;padding:2px 8px;border-radius:50px;margin-left:6px;letter-spacing:.3px;vertical-align:middle}
.mm-fb-strike{display:inline-block;background:rgba(231,76,60,.14);color:#c0392b;font-family:'Poppins',sans-serif;font-size:.74rem;font-weight:800;padding:2px 8px;border-radius:50px;margin-left:6px;letter-spacing:.3px;vertical-align:middle}

/* Question hint (e.g. unit conversion factor) */
.mm-q-hint.has{background:var(--bg2);border-radius:10px;padding:8px 14px;display:inline-block;font-size:.84rem;color:var(--navy);font-weight:500;margin-bottom:18px;font-family:'Poppins',sans-serif;border-left:3px solid var(--teal)}
.mm-q-hint.has strong{color:var(--teal)}

/* Points awarded chip in feedback */
.mm-fb-pts{display:inline-flex;align-items:center;gap:4px;background:rgba(46,160,67,.18);color:#1a4a23;font-family:'Poppins',sans-serif;font-weight:800;font-size:.78rem;padding:3px 10px;border-radius:50px;margin-left:8px;letter-spacing:.3px;vertical-align:middle}
.mm-fb-pts.zero{background:rgba(13,42,74,.08);color:var(--navy)}

@media(max-width:980px){
.cg{max-width:820px}
.contact-strip{grid-template-columns:1fr 1fr}
.contact-social{grid-column:1/-1}
}

@media(max-width:640px){
.co-s{padding:112px 12px 54px}
.cf{padding:24px 16px;border-radius:18px}
.form-head h1{font-size:1.65rem}
.form-head p{font-size:.92rem}
.form-grid{grid-template-columns:1fr;gap:16px}
.subject-options{grid-template-columns:1fr}
.contact-strip{grid-template-columns:1fr}
.contact-social{grid-column:auto}
.contact-strip > div{border-radius:16px}
.contact-social .si{gap:12px}
.contact-social .si a{width:42px;height:42px}
.choice-row{grid-template-columns:1fr 1fr}
}

/* Calculator modal */
.mm-calc-overlay{position:fixed;inset:0;background:rgba(13,42,74,.35);z-index:2000;display:none;align-items:center;justify-content:center;padding:16px}
.mm-calc-overlay.show{display:flex}
.mm-calc-window{background:#fff;border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.35);width:380px;max-width:100%;height:540px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;position:relative}
.mm-calc-head{background:var(--navy);color:#fff;padding:11px 14px;display:flex;justify-content:space-between;align-items:center;cursor:move;font-family:'Poppins',sans-serif;font-weight:600;font-size:.88rem;user-select:none;touch-action:none;flex-shrink:0}
.mm-calc-head-l{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.mm-calc-head svg{width:16px;height:16px}
.mm-calc-pen{background:rgba(231,76,60,.25);color:#ffc4c4;padding:2px 8px;border-radius:50px;font-size:.7rem;letter-spacing:.3px;font-weight:700}
.mm-calc-close{background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;padding:0;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s;line-height:1}
.mm-calc-close:hover{background:rgba(255,255,255,.18)}
.mm-calc-window iframe{flex:1;border:none;width:100%;background:#fff}
.mm-calc-window.dragging{transition:none;box-shadow:0 28px 70px rgba(0,0,0,.42)}
.mm-calc-window.dragging .mm-calc-head{cursor:grabbing}
.mm-calc-window.dragging iframe{pointer-events:none}
.mm-calc-fallback{padding:9px 14px;font-size:.78rem;color:var(--body);background:var(--bg2);text-align:center;line-height:1.5}
.mm-calc-fallback a{color:var(--teal);font-weight:600;text-decoration:underline}
.mm-bar-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.mm-strikes{display:inline-flex;align-items:center;gap:5px;background:rgba(231,76,60,.09);color:#c0392b;border:1px solid rgba(231,76,60,.2);border-radius:999px;padding:6px 10px;font-family:'Poppins',sans-serif;font-size:.78rem;font-weight:700;white-space:nowrap}
.mm-strikes strong{font-weight:900}
.mm-ranked-submit{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:16px;margin:0 0 18px;position:relative;z-index:1;text-align:left}
.mm-ranked-submit-copy{display:flex;justify-content:space-between;gap:14px;align-items:baseline;margin-bottom:12px}
.mm-ranked-submit-copy strong{font-family:'Poppins',sans-serif;color:var(--w)}
.mm-ranked-submit-copy span{font-size:.8rem;color:rgba(255,255,255,.7)}
.mm-ranked-submit-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}
.mm-ranked-submit-row input{background:rgba(255,255,255,.96)}
.mm-ranked-submit-row .cb{border:none;white-space:nowrap}
.mm-results-board{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14);box-shadow:none;margin:0 0 18px;position:relative;z-index:1}
.mm-results-board .mm-lb-head strong,.mm-results-board .mm-lb-score,.mm-results-board .mm-lb-person strong{color:var(--w)}
.mm-results-board .mm-lb-head button,.mm-results-board .mm-lb-list li{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.14);color:var(--w)}
.mm-results-board .mm-lb-person small,.mm-results-board .mm-lb-status{color:rgba(255,255,255,.7)}
.mm-results-board .mm-lb-empty{color:rgba(255,255,255,.7)}
@media(min-width:901px){
.mm-calc-overlay{background:transparent;pointer-events:none;align-items:flex-start;justify-content:flex-end}
.mm-calc-overlay.show{pointer-events:none}
.mm-calc-window{pointer-events:auto;position:fixed;bottom:24px;right:24px;width:360px;height:500px}
}

@media(max-width:900px){
.mm-grid{grid-template-columns:1fr}
.mm-side{grid-template-columns:1fr 1fr;position:static}
.mm-side .mm-card{min-width:0}
.mm-side .mm-points-card{grid-column:1/-1}
.mm-side .mm-card:last-child{grid-column:1/-1}
.mm-cats-list{grid-template-columns:1fr 1fr}
.mm-ranked-note{grid-template-columns:1fr}
.mm-bar{align-items:stretch;flex-direction:column}
.mm-bar-right{justify-content:space-between;width:100%}
}
@media(max-width:600px){
.mm-s{padding:34px 12px}
.mm-setup{padding:22px 16px;border-radius:16px;border-left:none;border-top:4px solid var(--teal)}
.mm-setup h2{font-size:1.18rem}
.mm-setup-sub{font-size:.86rem;margin-bottom:18px}
.mm-mode-tabs{border-radius:12px}
.mm-mode-tab{min-height:46px;padding:10px 8px}
.mm-pill-row{display:grid;grid-template-columns:1fr 1fr}
.mm-pill{min-height:44px;padding:9px 10px;border-radius:12px;font-size:.82rem}
.mm-ranked-note{padding:12px}
.mm-name-field input,.mm-ranked-submit-row input{min-height:46px}
.mm-q-card{padding:24px 16px 20px;border-radius:18px 8px 18px 8px;border-left:none;border-top:5px solid var(--teal)}
.mm-q-card::before{width:150px;height:150px;right:-58px;top:-56px}
.mm-q-text{font-size:1.55rem;min-height:42px;line-height:1.22}
.mm-q-hint.has{font-size:.78rem;padding:8px 10px}
.mm-form{display:block;width:100%;max-width:100%;position:relative}
.mm-input{width:100%;min-height:64px;font-size:1.16rem;padding-right:88px;box-sizing:border-box}
.mm-submit{position:absolute;right:7px;top:7px;bottom:7px;z-index:2;min-width:72px;min-height:0;height:auto;padding:0 10px;border-radius:10px;font-size:.82rem;box-shadow:0 8px 18px rgba(26,175,160,.22)}
.mm-submit:hover{transform:none}
.mm-fb{margin-top:14px;padding:14px;border-radius:16px;border-left:none;box-shadow:0 10px 22px rgba(13,42,74,.06)}
.mm-fb.correct{border-top:4px solid #2ea043}
.mm-fb.wrong{border-top:4px solid #e74c3c}
.mm-fb.skipped{border-top:4px solid var(--navy)}
.mm-fb-head{font-size:.96rem;line-height:1.35;text-transform:none;letter-spacing:0;gap:7px 8px;flex-wrap:wrap;margin-bottom:10px}
.mm-fb-head svg{width:15px;height:15px;flex:0 0 auto}
.mm-fb-pts,.mm-fb-strike,.mm-fb-calc{margin-left:0;padding:5px 9px;border-radius:999px;font-size:.7rem;line-height:1;white-space:nowrap;flex:0 0 auto}
.mm-fb-tip{font-size:.92rem;line-height:1.55;margin-top:0;padding-top:10px;border-top:1px solid rgba(13,42,74,.08)}
.mm-cat-grid{grid-template-columns:1fr 1fr}
.mm-side{grid-template-columns:1fr}
.mm-side .mm-card,.mm-side .mm-card:last-child,.mm-side .mm-points-card{grid-column:auto}
.mm-side .mm-cat-tracker{display:none}
.mm-card{border-radius:14px;padding:15px}
.mm-points-card{padding:16px;border-radius:16px}
.mm-points-val{font-size:2rem}
.mm-cats-list{grid-template-columns:1fr}
.mm-stats-grid{grid-template-columns:1fr 1fr}
.mm-controls{flex-direction:column;border-radius:14px;padding:8px}
.mm-controls .db{width:100%;min-width:0;min-height:46px;border-radius:10px}
.mm-results{border-radius:16px;padding:28px 16px}
.mm-results-grid{grid-template-columns:1fr 1fr}
.mm-ranked-submit-copy{display:block}
.mm-ranked-submit-copy span{display:block;margin-top:4px}
.mm-ranked-submit-row{grid-template-columns:1fr}
.mm-lb-list li{grid-template-columns:38px minmax(0,1fr) auto;padding:9px}
.mm-lb-person small{font-size:.7rem}
.mm-best-banner{align-items:flex-start;padding:12px;font-size:.82rem}
}

/* RESPONSIVE */
@media(max-width:768px){
.nk{display:none}.hb{display:flex}
.nl img{height:55px;width:auto}.hero-logo{width:210px}
.uw canvas{display:none!important}
.uw-ex{position:relative;text-decoration:none;padding-bottom:5px;display:inline-block}
.uw-ex::after{content:'';position:absolute;left:0;bottom:0;height:3px;background:var(--teal);border-radius:2px;width:0;animation:uwExMobile 3.4s ease-in-out infinite}
.fl{grid-template-columns:1fr;text-align:center}
.fpw{max-width:320px;margin:0 auto}
.fi{margin:0 auto;max-width:220px}
.ab{flex-direction:row;flex-wrap:wrap}
.ai{flex:1 1 45%;min-width:0}
footer{width:100%;max-width:100%;margin-left:0;margin-right:0;padding:36px 18px 24px}
.fti{max-width:640px;grid-template-columns:repeat(2,minmax(0,1fr));gap:26px 18px;text-align:left}
.ftb{grid-column:1/-1;text-align:center}
.ftb img{height:54px;margin-bottom:12px}
.ftb p{max-width:520px;margin-left:auto;margin-right:auto;font-size:.86rem;line-height:1.55}
.footer-cta{padding:10px 16px}
.ft-col h3{font-size:.78rem;margin-bottom:9px}
.ftl{gap:7px}
.ftl a{font-size:.86rem}
.fti .ft-col:last-child{grid-column:1/-1;text-align:center}
.fti .ft-col:last-child .ftl{align-items:center}
.fts{justify-content:center;margin-top:14px}
.ftc{max-width:640px;justify-content:center;text-align:center;flex-direction:column;align-items:center;gap:6px;margin-top:24px;padding-top:16px}
.hero{padding:120px 24px 50px}
.sh-in{grid-template-columns:1fr 120px}
.sh-icon svg{max-width:100px}
.sb-inner{grid-template-columns:1fr}
.sb-side{flex-direction:row;flex-wrap:wrap;justify-content:center}
.sb-card{flex:1 1 140px;max-width:180px}
.cn{width:32px;height:32px;font-size:.9rem}
.cp{left:0}.cx{right:0}
.pg{grid-template-columns:1fr}
.cg{grid-template-columns:1fr}
.mocks-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}
}
@media(min-width:769px){.mn{display:none!important}}
