/* =========================
   CanadaPass UI — Ultra Sky Theme
   design.css
========================= */

/* Font stack */
:root{
  --bg0:#f5fcff; --bg1:#ecfbff; --ink:#071a2d; --muted:rgba(7,26,45,.72);
  --sky:#19b9ff; --sky2:#7ce7ff; --blue:#2d7bff; --deep:#0b2a4a;
  --glass:rgba(255,255,255,.68); --glass2:rgba(255,255,255,.52); --stroke:rgba(25,185,255,.20);
  --shadow:0 24px 70px rgba(3,28,60,.18); --shadow2:0 10px 40px rgba(3,28,60,.12); --glow:0 0 22px rgba(25,185,255,.42);
  --r-lg:26px; --r-md:20px; --r-sm:16px;
  --ease:cubic-bezier(.2,.8,.2,1);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;
  color:var(--ink);
  background:linear-gradient(180deg,#fff 0%,var(--bg0) 45%,var(--bg1) 100%);
  overflow-x:hidden;
}

/* Background ambient */
.bg{ position:fixed; inset:0; z-index:-1; }
.orb{
  position:absolute; width:560px; height:560px; filter:blur(60px); opacity:.55;
  transform:translate3d(0,0,0);
  animation:float 10s var(--ease) infinite;
}
.orb-a{ left:-180px; top:120px; background:radial-gradient(circle,rgba(25,185,255,.85),transparent 60%); }
.orb-b{ right:-220px; top:-60px; background:radial-gradient(circle,rgba(124,231,255,.85),transparent 60%); animation-delay:-3s; }
.orb-c{ right:12%; bottom:-260px; background:radial-gradient(circle,rgba(45,123,255,.75),transparent 60%); animation-delay:-6s; }
.grid{
  position:absolute; inset:0;
  background-image:linear-gradient(to right,rgba(25,185,255,.05) 1px,transparent 1px),
                   linear-gradient(to bottom,rgba(25,185,255,.05) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(circle at 40% 20%,rgba(0,0,0,.7),transparent 60%);
  opacity:.6;
}
@keyframes float{
  0%,100%{ transform:translateY(0) translateX(0) scale(1); }
  50%{ transform:translateY(-18px) translateX(14px) scale(1.02); }
}

/* Top progress */
.top-progress{ position:fixed; top:0; left:0; right:0; height:4px; background:rgba(25,185,255,.08); z-index:50; }
.top-progress__bar{
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--sky),var(--blue),var(--sky2));
  box-shadow:var(--glow);
  transition:width .25s var(--ease);
}

/* Shell layout */
.shell{ max-width:1200px; margin:0 auto; padding:14px 14px 40px; }

/* Glass utilities */
.glass{
  background:var(--glass);
  border:1px solid var(--stroke);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow);
  backdrop-filter:blur(14px);
}
.glass2{
  background:var(--glass2);
  border:1px solid rgba(25,185,255,.16);
  border-radius:var(--r-md);
  box-shadow:var(--shadow2);
  backdrop-filter:blur(12px);
}
.hidden{ display:none !important; }

/* Header */
.header{ padding:16px; }
.header__row{ display:flex; align-items:center; justify-content:space-between; gap:14px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand__logoWrap{ position:relative; width:60px; height:60px; }
.brand__logo, .brand__logoPlaceholder{
  width:60px; height:60px; border-radius:18px; object-fit:cover;
  border:1px solid var(--stroke); background:#fff;
  display:grid; place-items:center;
  font-weight:1000; letter-spacing:.5px;
  box-shadow:var(--shadow2);
}
.brand__logoGlow{
  position:absolute; inset:-10px; border-radius:24px;
  background:radial-gradient(circle,rgba(25,185,255,.55),transparent 65%);
  filter:blur(12px); z-index:-1;
}
.brand__title{ display:flex; align-items:center; gap:10px; }
.brand__name{
  font-size:20px; font-weight:1000;
  background:linear-gradient(90deg,var(--deep),#0b68a9);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}
.brand__subtitle{ font-size:12.5px; color:var(--muted); margin-top:3px; }

/* Badge */
.badge{
  font-size:12px; font-weight:900; padding:7px 12px; border-radius:999px;
  border:1px solid rgba(25,185,255,.22);
  background:rgba(25,185,255,.12);
  box-shadow:var(--glow);
}
.badge--shine{ position:relative; overflow:hidden; }
.badge--shine::after{
  content:""; position:absolute; inset:-40%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);
  transform:rotate(18deg) translateX(-60%);
  animation:shine 3.2s var(--ease) infinite;
}
@keyframes shine{
  0%{ transform:rotate(18deg) translateX(-60%); opacity:0; }
  25%{ opacity:.9; }
  55%{ transform:rotate(18deg) translateX(60%); opacity:.7; }
  100%{ opacity:0; }
}

/* Actions */
.actions{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

/* Buttons */
.btn{
  border:0; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 14px; border-radius:18px;
  font-weight:950; text-decoration:none; color:var(--ink);
  transition:transform .18s var(--ease), box-shadow .18s var(--ease), filter .18s var(--ease), background .18s var(--ease);
  user-select:none;
}
.btn:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
.btn:active{ transform:translateY(0) scale(.98); }
.btn:disabled{ opacity:.55; cursor:not-allowed; transform:none; box-shadow:none; }

.btn--primary{
  color:#fff;
  background:linear-gradient(135deg,var(--sky) 0%,var(--blue) 55%,var(--sky2) 100%);
  box-shadow:var(--glow);
}
.btn--ghost{
  background:rgba(255,255,255,.55);
  border:1px solid rgba(25,185,255,.22);
  backdrop-filter:blur(12px);
}
.btn--xl{ padding:14px 16px; border-radius:20px; }
.w100{ width:100%; }

/* Icons (pure CSS) */
.icon{ width:18px; height:18px; display:inline-block; position:relative; }
.icon--phone::before{ content:""; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.85),rgba(255,255,255,.35)); mask:radial-gradient(circle at 40% 60%,#000 35%,transparent 36%), linear-gradient(#000,#000); border-radius:6px; }
.icon--whatsapp::before{ content:""; position:absolute; inset:0; border-radius:50%; background:radial-gradient(circle at 30% 30%,rgba(39,255,122,.9),rgba(39,255,122,.35)); box-shadow:0 0 0 6px rgba(39,255,122,.16); }
.icon--bolt::before{ content:""; position:absolute; inset:2px 6px 2px 6px; background:linear-gradient(180deg,#fff,rgba(255,255,255,.6)); clip-path:polygon(45% 0,70% 0,52% 45%,78% 45%,35% 100%,50% 55%,25% 55%); }
.icon--info::before{ content:"i"; position:absolute; inset:0; display:grid; place-items:center; font-weight:1000; color:#fff; border-radius:50%; background:linear-gradient(135deg,rgba(25,185,255,.9),rgba(45,123,255,.6)); }
.icon--arrowLeft::before{ content:""; position:absolute; left:2px; top:50%; width:12px; height:12px; border-left:3px solid currentColor; border-bottom:3px solid currentColor; transform:translateY(-50%) rotate(45deg); }
.icon--arrowRight::before{ content:""; position:absolute; right:2px; top:50%; width:12px; height:12px; border-right:3px solid currentColor; border-top:3px solid currentColor; transform:translateY(-50%) rotate(45deg); }
.icon--play::before{ content:""; position:absolute; inset:3px 2px 3px 5px; background:currentColor; clip-path:polygon(0 0,100% 50%,0 100%); }
.icon--check::before{ content:""; position:absolute; left:3px; top:7px; width:6px; height:10px; border-right:3px solid currentColor; border-bottom:3px solid currentColor; transform:rotate(40deg); }
.icon--pause::before{ content:""; position:absolute; left:4px; top:3px; width:4px; height:12px; background:currentColor; box-shadow:7px 0 0 currentColor; border-radius:2px; }
.icon--reset::before{ content:""; position:absolute; inset:2px; border:3px solid currentColor; border-right-color:transparent; border-radius:50%; }
.icon--close::before{ content:""; position:absolute; inset:3px; background:currentColor; clip-path:polygon(45% 0,55% 0,55% 45%,100% 45%,100% 55%,55% 55%,55% 100%,45% 100%,45% 55%,0 55%,0 45%,45% 45%); transform:rotate(45deg); }
.icon--list::before{ content:""; position:absolute; left:3px; right:3px; top:4px; height:3px; background:currentColor; box-shadow:0 5px 0 currentColor, 0 10px 0 currentColor; border-radius:2px; }
.icon--copy::before{ content:""; position:absolute; left:5px; top:4px; width:10px; height:12px; border:2px solid currentColor; border-radius:4px; }
.icon--shuffle::before{ content:""; position:absolute; inset:3px; border-top:3px solid currentColor; border-bottom:3px solid currentColor; border-radius:4px; opacity:.85; }
.icon--settings::before{ content:""; position:absolute; inset:3px; border:3px solid currentColor; border-radius:50%; box-shadow:0 0 0 3px rgba(255,255,255,0); }
.icon--refresh::before{ content:""; position:absolute; inset:2px; border:3px solid currentColor; border-left-color:transparent; border-radius:50%; }

/* Device panel */
.device{ margin-top:12px; padding:12px; }
.device__grid{ display:grid; grid-template-columns:repeat(8,1fr); gap:10px; }
.chip{
  padding:10px 12px; border-radius:18px;
  border:1px solid rgba(25,185,255,.18);
  background:rgba(25,185,255,.06);
  min-width:0;
}
.chip__k{ font-size:11px; font-weight:1000; color:rgba(7,26,45,.65); }
.chip__v{
  font-size:12.5px; font-weight:950; margin-top:4px;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.mono{ font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace; }
.chip--timer{
  background:rgba(124,231,255,.14);
  border-color:rgba(25,185,255,.24);
  box-shadow:0 0 0 6px rgba(124,231,255,.10);
}
.device__hint{ margin-top:10px; font-size:12px; color:rgba(7,26,45,.70); display:flex; align-items:center; gap:10px; }
.dot{ width:10px; height:10px; border-radius:50%; display:inline-block; }
.dot--live{ background:#27ff7a; box-shadow:0 0 0 6px rgba(39,255,122,.16); }

/* Main */
.main{ margin-top:16px; display:grid; gap:16px; }

/* Cards */
.card{ padding:18px; }
.card__head{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.card__headActions{ display:flex; gap:10px; align-items:center; }
.h1{ margin:10px 0 0; font-size:clamp(28px,4vw,44px); line-height:1.05; letter-spacing:-1px; }
.h2{ margin:0; font-size:22px; letter-spacing:-.3px; }
.lead{ margin:14px 0 0; font-size:15.5px; color:var(--muted); line-height:1.6; }
.muted{ color:var(--muted); }
.mutedStrong{ color:rgba(7,26,45,.9); font-weight:950; }
.glowText{ text-shadow:0 0 18px rgba(25,185,255,.45); }

/* Hero */
.hero{
  display:grid; grid-template-columns:1.25fr .75fr;
  gap:16px; align-items:stretch; position:relative; overflow:hidden;
}
.hero::after{
  content:""; position:absolute; inset:-2px;
  background:radial-gradient(circle at 20% 10%,rgba(25,185,255,.22),transparent 60%);
  pointer-events:none;
}
.hero__left{ min-width:0; }
.hero__right{ display:grid; gap:12px; align-content:start; }

.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:950; font-size:12px;
  padding:8px 12px; border-radius:999px;
  border:1px solid rgba(25,185,255,.22);
  background:rgba(255,255,255,.55);
  box-shadow:var(--shadow2);
}
.spark{
  width:10px; height:10px; border-radius:50%;
  background:linear-gradient(135deg,var(--sky),var(--sky2));
  box-shadow:0 0 0 6px rgba(25,185,255,.14);
}
.hero__stats{ display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }
.stat{
  padding:10px 12px; border-radius:18px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(25,185,255,.18);
  min-width:120px;
}
.stat__k{ font-size:11px; font-weight:1000; color:rgba(7,26,45,.6); }
.stat__v{ margin-top:4px; font-size:18px; font-weight:1000; }

.hero__cta{ display:flex; gap:10px; margin-top:16px; flex-wrap:wrap; }

.note{
  margin-top:14px; padding:12px 14px;
  border-radius:20px; border:1px solid rgba(25,185,255,.20);
  background:rgba(25,185,255,.07);
}
.note__title{ font-weight:1000; margin-bottom:4px; }
.note__body{ color:rgba(7,26,45,.78); line-height:1.55; }
.note--warn{ background:rgba(255,206,66,.14); border-color:rgba(255,206,66,.22); }
.note--soft{ background:rgba(124,231,255,.12); border-color:rgba(124,231,255,.22); }

.preview{ position:relative; overflow:hidden; padding:14px; }
.preview__top{ display:flex; gap:8px; flex-wrap:wrap; }
.pill, .pillRow .pill{
  display:inline-flex; align-items:center; justify-content:center;
  padding:8px 12px; border-radius:999px;
  border:1px solid rgba(25,185,255,.18);
  background:rgba(255,255,255,.55);
  font-weight:950; font-size:12px;
}
.pill--shine{ position:relative; overflow:hidden; }
.pill--shine::after{
  content:""; position:absolute; inset:-40%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);
  transform:rotate(18deg) translateX(-60%);
  animation:shine 3.4s var(--ease) infinite;
}
.preview__body{ margin-top:12px; display:grid; gap:10px; }
.miniCard{
  padding:12px 14px; border-radius:20px;
  border:1px solid rgba(25,185,255,.16);
  background:rgba(25,185,255,.06);
}
.miniCard__title{ font-weight:1000; }
.miniCard__text{ margin-top:4px; color:var(--muted); line-height:1.5; }
.preview__shine{ position:absolute; inset:-40%; background:radial-gradient(circle at 30% 30%,rgba(124,231,255,.25),transparent 60%); pointer-events:none; }

.stack{ display:flex; gap:10px; }
.stack__item{ flex:1; padding:12px 14px; }
.stack__k{ font-size:11px; font-weight:1000; color:rgba(7,26,45,.6); }
.stack__v{ margin-top:6px; font-size:18px; font-weight:1000; }

/* Select view */
.select__grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:12px; }
.select__form{ padding:14px; }
.field{ display:block; margin-top:6px; }
.field__label{ display:block; font-weight:1000; margin-bottom:8px; }
.field__hint{ display:block; margin-top:6px; font-size:12px; color:rgba(7,26,45,.7); }
.field__control{ position:relative; }
.selectInput{
  width:100%;
  padding:14px 44px 14px 14px;
  border-radius:18px;
  border:1px solid rgba(25,185,255,.22);
  background:rgba(255,255,255,.70);
  font-weight:950; outline:none;
  transition:box-shadow .18s var(--ease), transform .18s var(--ease), border-color .18s var(--ease);
}
.selectInput:focus{ box-shadow:var(--glow); border-color:rgba(25,185,255,.34); }
.selectChevron{
  position:absolute; right:14px; top:50%;
  width:10px; height:10px;
  border-right:3px solid rgba(7,26,45,.65);
  border-bottom:3px solid rgba(7,26,45,.65);
  transform:translateY(-65%) rotate(45deg);
  pointer-events:none;
}
.row{ display:flex; align-items:center; }
.row--gap{ gap:10px; flex-wrap:wrap; }
.divider{ height:1px; background:rgba(25,185,255,.18); margin:14px 0; }

.meta{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.meta__item{
  padding:10px 12px; border-radius:18px;
  border:1px solid rgba(25,185,255,.16);
  background:rgba(25,185,255,.06);
}
.meta__k{ font-size:11px; font-weight:1000; color:rgba(7,26,45,.6); }
.meta__v{ margin-top:6px; font-size:16px; font-weight:1000; }

.select__info{ display:grid; gap:12px; align-content:start; }
.infoCard{ padding:14px; }
.infoCard__title{ font-weight:1000; font-size:14px; }
.infoCard__text{ margin-top:6px; color:var(--muted); line-height:1.55; }
.infoCard__bullets{ margin-top:10px; display:grid; gap:8px; }
.bullet{ display:flex; align-items:center; gap:8px; font-weight:900; color:rgba(7,26,45,.78); }
.tick{ width:16px; height:16px; border-radius:6px; background:rgba(39,255,122,.20); position:relative; }
.tick::after{
  content:""; position:absolute; left:4px; top:3px; width:6px; height:9px;
  border-right:3px solid rgba(7,26,45,.8);
  border-bottom:3px solid rgba(7,26,45,.8);
  transform:rotate(35deg);
}

.ctaStrip{ padding:14px; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.ctaStrip__t{ font-weight:1000; }
.ctaStrip__s{ margin-top:4px; color:var(--muted); font-size:12.5px; }

/* Test view */
.test__top{ display:flex; align-items:flex-start; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.test__right{ display:flex; gap:10px; flex-wrap:wrap; }
.timerCard,.progressCard{ padding:12px 14px; min-width:170px; }
.timerCard__k,.progressCard__k{ font-size:11px; font-weight:1000; color:rgba(7,26,45,.6); }
.timerCard__v{ margin-top:6px; font-size:22px; font-weight:1000; }
.progressCard__top{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.progressCard__v{ font-weight:1000; }
.bar{
  margin-top:10px; height:10px; border-radius:999px;
  border:1px solid rgba(25,185,255,.20);
  background:rgba(25,185,255,.08);
  overflow:hidden;
}
.bar__fill{
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--sky),var(--blue),var(--sky2));
  box-shadow:var(--glow);
  transition:width .22s var(--ease);
}

.test__body{ margin-top:14px; display:grid; grid-template-columns:1.2fr .8fr; gap:14px; }
.qArea{ padding:14px; }
.side{ padding:14px; display:grid; gap:12px; align-content:start; }
.side__section{ display:grid; gap:10px; }
.side__title{ font-weight:1000; }
.navBtns{ display:flex; gap:10px; flex-wrap:wrap; }
.miniHint{ font-size:12px; color:rgba(7,26,45,.7); }

.stateGrid{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.state{
  padding:10px 12px; border-radius:18px;
  border:1px solid rgba(25,185,255,.16);
  background:rgba(25,185,255,.06);
}
.state__k{ font-size:11px; font-weight:1000; color:rgba(7,26,45,.6); }
.state__v{ margin-top:6px; font-size:16px; font-weight:1000; }

.qTitle{ font-weight:1000; display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.qTitle__n{ font-size:13px; color:rgba(7,26,45,.65); }
.qTitle__q{ font-size:16px; margin-top:6px; line-height:1.5; }
.qBody{ margin-top:12px; display:grid; gap:10px; }

.choice{
  display:flex; align-items:flex-start; gap:10px;
  padding:12px 12px; border-radius:20px;
  border:1px solid rgba(25,185,255,.18);
  background:rgba(255,255,255,.55);
  cursor:pointer;
  transition:transform .16s var(--ease), box-shadow .16s var(--ease), border-color .16s var(--ease), background .16s var(--ease);
}
.choice:hover{ transform:translateY(-1px); box-shadow:var(--glow); }
.choice input{ margin-top:3px; transform:scale(1.15); accent-color:var(--sky); }
.choice__label{ font-weight:950; min-width:22px; }
.choice__text{ color:rgba(7,26,45,.86); line-height:1.5; }
.choice.is-selected{
  border-color:rgba(25,185,255,.42);
  background:rgba(25,185,255,.10);
  box-shadow:0 0 0 6px rgba(25,185,255,.10);
}

.skeleton{
  height:16px; border-radius:999px;
  background:linear-gradient(90deg,rgba(25,185,255,.08),rgba(25,185,255,.20),rgba(25,185,255,.08));
  background-size:240% 100%;
  animation:shimmer 1.1s infinite;
}
@keyframes shimmer{ 0%{background-position:0% 0} 100%{background-position:240% 0} }

/* Result view */
.result__grid{ margin-top:12px; display:grid; grid-template-columns:.65fr .45fr 1fr; gap:14px; }
.scoreCard,.levelCard,.recapCard{ padding:14px; }
.scoreCard__label,.levelCard__label{ font-weight:1000; color:rgba(7,26,45,.7); }
.scoreCard__value{ margin-top:6px; font-size:48px; font-weight:1000; letter-spacing:-1px; }
.scoreCard__max{ font-size:18px; color:rgba(7,26,45,.55); margin-left:8px; }
.scoreCard__sub{ margin-top:6px; color:var(--muted); }
.scoreCard__bar{
  margin-top:12px; height:12px; border-radius:999px;
  background:rgba(25,185,255,.08);
  border:1px solid rgba(25,185,255,.20);
  overflow:hidden;
}
.scoreCard__barFill{
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--sky),var(--blue),var(--sky2));
  box-shadow:var(--glow);
  transition:width .45s var(--ease);
}

.levelCard__value{
  margin-top:8px; font-size:44px; font-weight:1000;
  background:linear-gradient(90deg,var(--deep),#0b68a9,var(--sky));
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}
.levelCard__sub{ margin-top:6px; color:var(--muted); line-height:1.5; }
.pillRow{ margin-top:12px; display:flex; gap:8px; flex-wrap:wrap; }

.recapCard__title{ font-weight:1000; font-size:14px; }
.recapCard__sub{ margin-top:6px; }
.recapActions{ margin-top:12px; display:flex; gap:10px; flex-wrap:wrap; }

.details{
  margin-top:12px; border-radius:20px;
  border:1px solid rgba(25,185,255,.18);
  background:rgba(255,255,255,.55);
  overflow:hidden;
}
.details__head{
  display:grid; grid-template-columns:1fr 1fr 1fr;
  gap:0; padding:10px 12px; font-weight:1000;
  border-bottom:1px solid rgba(25,185,255,.18);
  background:rgba(25,185,255,.06);
}
.details__body{ max-height:320px; overflow:auto; }
.drow{
  display:grid; grid-template-columns:1fr 1fr 1fr;
  padding:10px 12px;
  border-bottom:1px solid rgba(25,185,255,.12);
}
.drow:last-child{ border-bottom:none; }
.drow .mono{ font-size:12px; }

.footer{ margin-top:16px; }
.footer__inner{
  padding:12px 14px;
  display:flex; align-items:center; justify-content:center;
  gap:10px; flex-wrap:wrap;
}
.sep{ opacity:.3; }
.link{
  border:0; background:none; cursor:pointer;
  color:rgba(7,26,45,.75);
  font-weight:950;
  text-decoration:underline;
}

/* Toast */
.toast{
  position:fixed; right:16px; bottom:16px;
  max-width:340px;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(255,255,255,.75);
  border:1px solid rgba(25,185,255,.22);
  box-shadow:var(--shadow);
  backdrop-filter:blur(12px);
  opacity:0; transform:translateY(18px);
  pointer-events:none;
  transition:opacity .22s var(--ease), transform .22s var(--ease);
  font-weight:950;
}
.toast.show{ opacity:1; transform:translateY(0); }
.toast.success{ border-color:rgba(39,255,122,.35); }
.toast.info{ border-color:rgba(25,185,255,.35); }
.toast.warn{ border-color:rgba(255,206,66,.35); }
.toast.error{ border-color:rgba(255,80,80,.35); }

/* Loader */
.loader{
  position:fixed; inset:0;
  display:grid; place-items:center;
  background:rgba(255,255,255,.55);
  backdrop-filter:blur(12px);
  z-index:99;
}
.loader__card{ padding:16px; display:flex; gap:12px; align-items:center; }
.loader__ring{
  width:56px; height:56px; border-radius:50%;
  border:6px solid rgba(25,185,255,.18);
  border-top-color:var(--sky);
  animation:spin .9s linear infinite;
  box-shadow:var(--glow);
}
@keyframes spin{ to{ transform:rotate(360deg);} }
.loader__title{ font-weight:1000; }
.loader__sub{ margin-top:2px; color:var(--muted); font-size:12.5px; }

/* Modal */
.modal{ position:fixed; inset:0; z-index:100; display:grid; place-items:center; }
.modal__backdrop{ position:absolute; inset:0; background:rgba(7,26,45,.35); backdrop-filter:blur(6px); }
.modal__panel{ position:relative; width:min(560px,calc(100vw - 24px)); padding:14px; }
.modal__head{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.modal__title{ font-weight:1000; font-size:16px; }
.modal__body{ margin-top:10px; color:rgba(7,26,45,.85); line-height:1.6; }
.modal__foot{ margin-top:12px; display:flex; justify-content:flex-end; }
.iconBtn{
  border:0; background:rgba(255,255,255,.55);
  border:1px solid rgba(25,185,255,.18);
  border-radius:14px; padding:10px; cursor:pointer;
}

/* Confetti */
.confetti{ position:fixed; inset:0; pointer-events:none; z-index:120; }
.confetti i{
  position:absolute; width:8px; height:12px; border-radius:4px;
  background:linear-gradient(135deg,var(--sky),var(--sky2));
  animation:fall 1.2s linear forwards;
  opacity:.9;
}
@keyframes fall{
  from{ transform:translateY(-30px) rotate(0deg); opacity:1; }
  to{ transform:translateY(110vh) rotate(420deg); opacity:.1; }
}

/* Responsive */
@media (max-width:1040px){
  .device__grid{ grid-template-columns:repeat(4,1fr); }
  .hero{ grid-template-columns:1fr; }
  .select__grid{ grid-template-columns:1fr; }
  .test__body{ grid-template-columns:1fr; }
  .result__grid{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .header__row{ flex-direction:column; align-items:flex-start; }
  .actions{ width:100%; }
  .btn{ width:100%; }
  .device__grid{ grid-template-columns:repeat(2,1fr); }
  .meta{ grid-template-columns:repeat(2,1fr); }
}