/* ============ JOC — Teme & componente (ADN „Cursa Cifrelor") ============ */
:root{
  --ink:#11203b; --asphalt:#1f2a44;
  --sky1:#ffd166; --sky2:#ff8c42; --sky3:#ff5d73;
  --correct:#2ecc71; --correct-d:#22a35a; --wrong:#ff6b6b; --wrong-d:#d94c4c;
  --gold:#ffd93d; --card:#ffffff; --muted:#56627d; --line:#e1e6ef;
  --radius:26px; --radius-sm:16px;
  --shadow:0 14px 34px rgba(17,32,59,.22); --shadow-sm:0 6px 16px rgba(17,32,59,.14);
  --head:'Baloo 2',system-ui,sans-serif; --body:'Fredoka',system-ui,sans-serif;
  --tap:54px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{height:100%;scrollbar-gutter:stable;overflow-y:scroll;}
html,body{margin:0;}
body{min-height:100%;overflow-x:hidden;}
body{
  font-family:var(--body); color:var(--ink); font-size:17px;
  background:linear-gradient(160deg,var(--sky1) 0%,var(--sky2) 48%,var(--sky3) 100%);
  background-attachment:fixed; -webkit-user-select:none; user-select:none;
}
h1,h2,h3,.head{font-family:var(--head);}
#app{min-height:100%;display:flex;flex-direction:column;max-width:820px;margin:0 auto;
  padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);}
.hidden{display:none!important;}
button{font-family:inherit;}
a{color:inherit;}

/* ---- Shell / header ---- */
.screen{flex:1;display:flex;flex-direction:column;min-height:0;padding:16px 16px 28px;animation:fadeIn .25s;}
.screen.center{justify-content:center;align-items:center;text-align:center;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.topbar{display:flex;align-items:center;gap:10px;padding:6px 4px 14px;}
.topbar .spacer{flex:1;}
.topbar h2{margin:0;font-size:20px;color:#fff;text-shadow:0 2px 8px rgba(17,32,59,.25);}
.btn-ghost{background:rgba(255,255,255,.4);border:none;color:var(--ink);font-weight:700;font-size:15px;
  padding:9px 14px;border-radius:14px;cursor:pointer;backdrop-filter:blur(4px);min-height:42px;}
.btn-ghost:active{transform:scale(.95);}
.stat{background:rgba(255,255,255,.92);border-radius:14px;padding:6px 12px;font-weight:700;font-size:15px;
  display:inline-flex;align-items:center;gap:5px;box-shadow:var(--shadow-sm);}

/* ---- Logo ---- */
.logo{font-family:var(--head);font-weight:800;font-size:clamp(44px,13vw,80px);line-height:.95;color:#fff;
  text-shadow:0 4px 0 rgba(17,32,59,.18),0 10px 26px rgba(17,32,59,.28);}
.logo .accent{color:var(--ink);}
.tag{font-size:clamp(15px,4vw,20px);color:rgba(17,32,59,.72);font-weight:600;margin:8px 0 26px;}

/* ---- Cards ---- */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;}
.card.tight{padding:16px;}
.cards{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;width:100%;}
.pick{flex:1 1 240px;max-width:320px;background:var(--card);border-radius:var(--radius);padding:26px 22px;
  box-shadow:var(--shadow);cursor:pointer;border:4px solid transparent;transition:transform .15s,border-color .15s;text-align:center;}
.pick:active{transform:scale(.97);}
.pick .emoji{font-size:58px;line-height:1;}
.pick h2{margin:10px 0 4px;font-size:26px;}
.pick p{margin:0;color:var(--muted);font-size:14px;}

/* ---- Buttons ---- */
.btn{min-height:var(--tap);border:none;border-radius:var(--radius-sm);font-family:var(--head);font-weight:800;
  font-size:1.05rem;padding:14px 22px;cursor:pointer;transition:transform .08s,filter .15s;touch-action:manipulation;width:100%;}
.btn:active{transform:scale(.96);}
.btn-primary{background:linear-gradient(90deg,var(--sky2),var(--sky3));color:#fff;box-shadow:0 8px 20px rgba(255,93,115,.4);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-soft{background:#eef1f7;color:var(--ink);}
.btn-correct{background:var(--correct);color:#fff;}
.btn-row{display:flex;gap:12px;}
.btn-row .btn{width:auto;flex:1;}
.btn-sm{min-height:40px;font-size:.92rem;padding:9px 14px;width:auto;}
.btn-link{background:none;border:none;color:var(--muted);font-weight:700;font-size:14px;cursor:pointer;margin-top:12px;text-decoration:underline;}
.btn:disabled{opacity:.5;pointer-events:none;}

/* ---- Forms ---- */
.field{margin-bottom:14px;text-align:left;}
.field label{display:block;font-weight:700;font-size:14px;margin-bottom:6px;color:var(--ink);}
.input,select,textarea{width:100%;border:2px solid var(--line);border-radius:14px;padding:13px 14px;font-family:var(--body);
  font-size:16px;background:#fff;color:var(--ink);outline:none;transition:border-color .15s;}
.input:focus,select:focus,textarea:focus{border-color:var(--sky2);}
textarea{resize:vertical;min-height:64px;}
.form-card{width:100%;max-width:420px;text-align:left;}

/* ---- Lists / section headings ---- */
.section-title{font-family:var(--head);font-weight:800;font-size:15px;color:#fff;text-shadow:0 2px 6px rgba(17,32,59,.25);
  margin:18px 4px 10px;display:flex;align-items:center;justify-content:space-between;letter-spacing:.5px;}
.grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));}
.empty{color:rgba(255,255,255,.9);text-align:center;padding:18px;font-weight:600;}

/* ---- Tiles (child/test/result cards) ---- */
.tile{background:#fff;border-radius:20px;padding:16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .12s;position:relative;overflow:hidden;}
.tile:active{transform:scale(.97);}
.tile .emoji{font-size:38px;line-height:1;}
.tile h3{margin:6px 0 2px;font-size:18px;}
.tile .meta{color:var(--muted);font-size:13px;}
.chip{display:inline-block;background:linear-gradient(90deg,var(--sky2),var(--sky3));color:#fff;font-weight:700;
  padding:2px 10px;border-radius:999px;font-size:11px;}
.chip.math{background:linear-gradient(90deg,#4dabf7,#3b5bdb);}
.chip.custom{background:linear-gradient(90deg,#9775fa,#7048e8);}
.badge-new{position:absolute;top:8px;right:8px;background:var(--gold);color:var(--ink);font-weight:800;font-size:11px;
  padding:3px 9px;border-radius:999px;animation:pulse 1.4s infinite;}
@keyframes pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.12);}}

/* ---- Access code display ---- */
.codebox{background:linear-gradient(135deg,#fff7e6,#ffe8cc);border:3px dashed var(--sky2);border-radius:18px;
  padding:14px;text-align:center;margin:10px 0;}
.codebox .code{font-family:var(--head);font-weight:800;font-size:clamp(22px,7vw,34px);letter-spacing:1px;color:var(--ink);word-break:break-word;}
.codebox .lbl{font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:1px;}

/* ---- Stars / points ---- */
.stars{font-size:26px;letter-spacing:3px;}
.stars .off{opacity:.25;}
.points-badge{display:inline-flex;align-items:center;gap:5px;background:var(--gold);color:var(--ink);font-weight:800;
  padding:4px 12px;border-radius:999px;font-size:15px;}

/* ---- Quiz play ---- */
.play{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;}
.progress-dots{display:flex;gap:6px;margin:8px 0 14px;flex-wrap:wrap;justify-content:center;}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.45);}
.dot.done{background:#fff;}
.dot.cur{background:var(--gold);transform:scale(1.3);}
.question{background:#fff;border-radius:28px;padding:22px;box-shadow:var(--shadow);text-align:center;width:100%;max-width:520px;}
.q-visual{font-size:28px;line-height:1.3;min-height:0;margin-bottom:8px;letter-spacing:2px;}
.q-text{font-family:var(--head);font-weight:800;font-size:clamp(22px,5.5vw,32px);line-height:1.15;}
.q-eq{font-family:var(--head);font-weight:800;font-size:clamp(40px,12vw,68px);line-height:1;color:var(--ink);}
.q-eq .qm{color:var(--sky3);}
.answers{display:grid;gap:12px;width:100%;max-width:520px;margin-top:16px;}
.answers.cols2{grid-template-columns:repeat(2,1fr);}
.answers.cols3{grid-template-columns:repeat(3,1fr);}
.ans{background:#fff;border:4px solid transparent;border-radius:18px;padding:18px 8px;font-family:var(--head);
  font-weight:800;font-size:clamp(20px,5vw,30px);color:var(--ink);cursor:pointer;box-shadow:var(--shadow);
  transition:transform .1s,background .2s,border-color .2s;min-height:64px;}
.ans:active{transform:scale(.95);}
.ans.selected{border-color:var(--sky2);background:#fff4e6;}
.ans.good{background:var(--correct);color:#fff;border-color:var(--correct-d);animation:pop .35s;}
.ans.bad{background:var(--wrong);color:#fff;border-color:var(--wrong-d);animation:shake .35s;}
.ans.reveal{border-color:var(--correct);}
.ans .ck{font-size:.7em;margin-left:6px;}
@keyframes pop{0%{transform:scale(1);}50%{transform:scale(1.12);}100%{transform:scale(1);}}
@keyframes shake{0%,100%{transform:translateX(0);}25%{transform:translateX(-7px);}75%{transform:translateX(7px);}}
.feedback{height:28px;margin-top:14px;font-weight:700;font-size:18px;opacity:0;transition:opacity .2s;}
.feedback.show{opacity:1;}.feedback.ok{color:#198a4e;}.feedback.no{color:#c0392b;}
.fillrow{display:flex;gap:10px;max-width:360px;margin:6px auto 0;}
.fillrow .input{font-size:24px;text-align:center;font-family:var(--head);font-weight:800;}

/* ---- Racing track ---- */
.track{background:var(--asphalt);border-radius:20px;padding:12px 0 10px;position:relative;overflow:hidden;
  box-shadow:inset 0 4px 14px rgba(0,0,0,.3);margin:0 0 12px;}
.lane{position:relative;height:42px;margin:4px 12px;}
.lane .line{position:absolute;top:50%;left:0;right:44px;height:4px;transform:translateY(-50%);
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.55) 0 18px,transparent 18px 34px);border-radius:2px;}
.flag{position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:24px;}
.racer{position:absolute;top:50%;left:0;transform:translate(0,-50%) scaleX(-1);font-size:32px;
  transition:left .55s cubic-bezier(.34,1.56,.64,1);will-change:left;filter:drop-shadow(0 3px 3px rgba(0,0,0,.45));}
.racer.rival{font-size:26px;opacity:.9;}

/* ---- Parent dashboard ---- */
.zone-parent .question{max-width:560px;}
.list{display:flex;flex-direction:column;gap:10px;}
.rowcard{background:#fff;border-radius:18px;padding:14px 16px;box-shadow:var(--shadow-sm);}
.rowcard .r-top{display:flex;align-items:center;gap:10px;}
.rowcard .r-top h3{margin:0;font-size:17px;flex:1;}
.kv{display:flex;justify-content:space-between;font-size:14px;padding:5px 0;border-bottom:1px dashed var(--line);}
.kv:last-child{border-bottom:none;}.kv span:first-child{color:var(--muted);}.kv span:last-child{font-weight:700;}
.builder-q{background:#f6f8fb;border-radius:16px;padding:14px;margin-bottom:12px;border:1px solid var(--line);}
.opt-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.opt-row .input{flex:1;}
.opt-mark{width:38px;height:38px;border-radius:10px;border:2px solid var(--line);background:#fff;cursor:pointer;font-size:18px;flex:none;}
.opt-mark.on{background:var(--correct);border-color:var(--correct-d);color:#fff;}
.seg{display:flex;background:#eef1f7;border-radius:14px;padding:4px;gap:4px;margin-bottom:14px;}
.seg button{flex:1;border:none;background:none;padding:10px;border-radius:11px;font-weight:700;cursor:pointer;color:var(--muted);font-family:var(--body);font-size:15px;}
.seg button.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm);}
.chips-pick{display:flex;gap:8px;flex-wrap:wrap;}
.chips-pick button{border:2px solid var(--line);background:#fff;border-radius:12px;padding:8px 14px;font-weight:700;cursor:pointer;font-family:var(--body);}
.chips-pick button.on{background:var(--sky2);border-color:var(--sky2);color:#fff;}
.stepper{display:inline-flex;align-items:center;gap:10px;}
.stepper button{width:38px;height:38px;border-radius:10px;border:none;background:#eef1f7;font-size:20px;font-weight:800;cursor:pointer;}
.assign-row{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:14px;margin-bottom:8px;box-shadow:var(--shadow-sm);cursor:pointer;}
.assign-row.on{outline:3px solid var(--correct);}
.assign-row .check{margin-left:auto;font-size:22px;}

/* ---- Bottom nav (child) ---- */
.bottomnav{position:sticky;bottom:0;display:flex;gap:6px;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);
  border-radius:18px;padding:6px;margin:10px 4px 0;box-shadow:var(--shadow);}
.bottomnav button{flex:1;border:none;background:none;padding:8px 4px;border-radius:13px;font-weight:700;font-size:12px;
  color:var(--muted);cursor:pointer;font-family:var(--body);display:flex;flex-direction:column;align-items:center;gap:2px;}
.bottomnav button .ic{font-size:22px;}
.bottomnav button.on{background:linear-gradient(90deg,var(--sky2),var(--sky3));color:#fff;}

/* ---- Progress visuals ---- */
.ring{--p:0;width:120px;height:120px;border-radius:50%;display:grid;place-items:center;margin:0 auto;
  background:conic-gradient(var(--correct) calc(var(--p)*1%),#eef1f7 0);}
.ring .inner{width:88px;height:88px;border-radius:50%;background:#fff;display:grid;place-items:center;font-family:var(--head);font-weight:800;font-size:26px;}
.collect{display:flex;flex-wrap:wrap;gap:6px;}
.collect .slot{width:30px;height:30px;display:grid;place-items:center;font-size:22px;background:#f0f0f5;border-radius:8px;}
.trophies{display:flex;gap:10px;flex-wrap:wrap;font-size:30px;}
.trophies .lock{filter:grayscale(1);opacity:.35;}
.statgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.statbox{background:#fff;border-radius:16px;padding:14px 8px;text-align:center;box-shadow:var(--shadow-sm);}
.statbox .big{font-family:var(--head);font-weight:800;font-size:24px;}
.statbox .lbl{font-size:12px;color:var(--muted);}
.chart{width:100%;height:120px;}

/* ---- Overlay / modal ---- */
.overlay{position:fixed;inset:0;background:rgba(17,32,59,.62);display:flex;align-items:center;justify-content:center;
  z-index:50;backdrop-filter:blur(3px);padding:18px;}
.panel{background:#fff;border-radius:30px;padding:26px 24px;text-align:center;max-width:420px;width:100%;box-shadow:var(--shadow);animation:rise .3s;max-height:90vh;overflow:auto;}
@keyframes rise{from{transform:translateY(26px);opacity:0;}to{transform:none;opacity:1;}}
.panel .big{font-size:58px;line-height:1;}
.panel h2{margin:8px 0 4px;font-size:26px;}
.panel p{color:var(--muted);margin:0 0 16px;font-size:15px;}

/* ---- Toast ---- */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;
  padding:12px 20px;border-radius:14px;font-weight:700;z-index:60;opacity:0;transition:.25s;box-shadow:var(--shadow);max-width:90%;text-align:center;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast.ok{background:var(--correct-d);}.toast.err{background:var(--wrong-d);}

/* ---- Confetti ---- */
#fx{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:40;}
.confetti{position:absolute;top:-30px;font-size:22px;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(110vh) rotate(560deg);opacity:.2;}}

/* ---- Spinner ---- */
.spinner{width:42px;height:42px;border:5px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin:30px auto;}
@keyframes spin{to{transform:rotate(360deg);}}
.level-flash{animation:lflash .6s;}
@keyframes lflash{0%{transform:scale(1);}50%{transform:scale(1.5);color:var(--correct);}100%{transform:scale(1);}}

@media (max-width:520px){
  .statgrid{grid-template-columns:repeat(3,1fr);}
}

/* ============ ZONA PĂRINTE — profesional ============ */
.pro{background:#eef1f7;padding:0!important;min-height:100%;}
.pro-head{background:#fff;display:flex;align-items:center;gap:10px;padding:12px 16px;
  box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:6;}
.pro-head .brand{font-family:var(--head);font-weight:800;font-size:19px;display:flex;align-items:center;gap:7px;}
.pro-head .brand .tagp{background:linear-gradient(90deg,var(--sky2),var(--sky3));color:#fff;font-size:11px;
  font-weight:700;padding:2px 9px;border-radius:999px;letter-spacing:.5px;}
.pro-head .spacer{flex:1;}
.pro-head .iconbtn{background:#f0f2f7;border:none;width:40px;height:40px;border-radius:12px;font-size:17px;cursor:pointer;color:var(--ink);}
.pro-head .iconbtn:active{transform:scale(.94);}
.pro-back{background:#f0f2f7;border:none;border-radius:12px;padding:8px 12px;font-weight:700;cursor:pointer;color:var(--ink);font-size:14px;}
.pro-tabs{display:flex;gap:2px;background:#fff;padding:0 8px;overflow-x:auto;border-bottom:1px solid var(--line);
  position:sticky;top:56px;z-index:5;-ms-overflow-style:none;scrollbar-width:none;}
.pro-tabs::-webkit-scrollbar{display:none;}
.pro-tabs button{border:none;background:none;padding:13px 14px 11px;font-family:var(--body);font-weight:700;font-size:14px;
  color:var(--muted);border-bottom:3px solid transparent;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:6px;}
.pro-tabs button.on{color:var(--ink);border-bottom-color:var(--sky2);}
.pro-content{padding:16px;}
.pro h2.page{font-family:var(--head);font-size:22px;margin:2px 0 4px;color:var(--ink);}
.pro .sub{color:var(--muted);font-size:14px;margin:0 0 14px;}
.pro .section-title{color:var(--ink);text-shadow:none;font-size:14px;text-transform:uppercase;letter-spacing:.5px;opacity:.7;}
.pro .empty{color:var(--muted);}
.pro .card,.pro .rowcard,.pro .tile{box-shadow:0 2px 10px rgba(17,32,59,.08);border:1px solid #edf0f5;}
.hint{background:#eef6ff;border:1px solid #d0e3fb;border-radius:12px;padding:10px 12px;font-size:13px;color:#345;margin:6px 0 12px;}
.hint b{color:var(--ink);}
.level-legend{background:#f6f8fb;border-radius:12px;padding:10px 12px;font-size:13px;color:var(--muted);margin-top:8px;}
.level-legend .row{display:flex;gap:8px;padding:3px 0;}
.level-legend .row b{color:var(--ink);min-width:54px;}
.level-pick{display:flex;gap:6px;flex-wrap:wrap;}
.level-pick button{border:2px solid var(--line);background:#fff;border-radius:10px;width:40px;height:40px;font-weight:800;cursor:pointer;font-family:var(--head);}
.level-pick button.on{background:var(--sky2);border-color:var(--sky2);color:#fff;}
.level-pick button.between{background:#ffe8d6;border-color:#ffd0aa;}

/* ---- Bar chart evoluție ---- */
.barchart{display:flex;align-items:flex-end;gap:8px;height:150px;padding:10px 4px 0;overflow-x:auto;}
.bar-col{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:34px;flex:1;}
.bar-col .val{font-size:11px;font-weight:700;color:var(--muted);}
.bar-col .bar{width:100%;max-width:30px;border-radius:8px 8px 4px 4px;min-height:6px;transition:height .4s;}
.bar-col .bar.s3{background:linear-gradient(180deg,#2ecc71,#27c06b);}
.bar-col .bar.s2{background:linear-gradient(180deg,#ffd93d,#ffb84d);}
.bar-col .bar.s1{background:linear-gradient(180deg,#ff8c42,#ff6b6b);}
.bar-col .lbl{font-size:10px;color:var(--muted);}

/* ---- Answer review (per întrebare) ---- */
.ans-item{background:#fff;border-radius:14px;padding:12px 14px;margin-bottom:10px;border-left:5px solid var(--correct);box-shadow:var(--shadow-sm);}
.ans-item.wrong{border-left-color:var(--wrong);}
.ans-item .qline{font-weight:700;font-size:14px;margin-bottom:6px;}
.ans-item .aline{font-size:13px;color:var(--muted);display:flex;gap:6px;padding:2px 0;}
.ans-item .aline b{color:var(--ink);}
.ans-item .given.ok{color:var(--correct-d);font-weight:700;}
.ans-item .given.no{color:var(--wrong-d);font-weight:700;}

/* ---- Child: hero + nav mai frumos ---- */
.child-hero{background:rgba(255,255,255,.96);border-radius:22px;padding:14px 16px;display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow);margin-bottom:4px;}
.child-hero .av{font-size:42px;line-height:1;background:linear-gradient(135deg,#fff2d6,#ffe0cc);border-radius:16px;padding:6px 8px;}
.child-hero .who{flex:1;}
.child-hero .who .hi{font-family:var(--head);font-weight:800;font-size:20px;line-height:1.1;}
.child-hero .who .sub{font-size:12px;color:var(--muted);}
.child-hero .mini{display:flex;gap:6px;}
.child-hero .mini .s{background:#fff;border:1px solid var(--line);border-radius:12px;padding:5px 9px;font-weight:800;font-size:14px;}
.bottomnav{padding:7px;gap:7px;}
.bottomnav button{padding:9px 4px;border-radius:15px;}
.bottomnav button .ic{font-size:24px;}
.bottomnav button.on{box-shadow:0 6px 16px rgba(255,93,115,.4);}

/* ---- Landing ---- */
.landing-hero{margin-bottom:8px;}
.landing-footer{margin-top:28px;display:flex;flex-direction:column;align-items:center;gap:6px;}
.free-badge{background:rgba(255,255,255,.92);color:var(--ink);font-weight:700;font-size:13px;
  padding:8px 16px;border-radius:999px;box-shadow:var(--shadow-sm);}
.legal{font-size:13.5px;color:#445;line-height:1.5;max-height:50vh;overflow:auto;}
.legal p{margin:0 0 10px;}
.legal b{color:var(--ink);}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px dashed var(--line);}
.toggle-row:last-child{border-bottom:none;}
.toggle-row .lbl{font-weight:600;font-size:14px;}
.switch{position:relative;width:50px;height:28px;flex:none;}
.switch input{opacity:0;width:0;height:0;}
.switch .sl{position:absolute;inset:0;background:#ccd2de;border-radius:999px;transition:.2s;cursor:pointer;}
.switch .sl:before{content:'';position:absolute;width:22px;height:22px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;}
.switch input:checked + .sl{background:var(--correct);}
.switch input:checked + .sl:before{transform:translateX(22px);}
