/* Sharpenly After Screens — mockup CSS, ported verbatim from
   c:/tmp/sharpenly_after_screens.html (rendered by Claude Design).

   Everything below is scoped under `.aft` so it only applies to screen
   containers that opt in by adding the .aft class. This lets the mockup's
   exact pixel placement, shadows, fonts, and spacing override the app's
   pre-existing CSS *only on the screens that have been ported*. Other app
   screens (admin, lessons, badges, etc.) keep their existing styling.

   Path 1 (wholesale CSS adoption) per the design-lock plan. */

/* --- shared design tokens (already set on :root in index.html; redeclared
   here only for the values the mockup needs that may differ) --- */

/* .aft padding wins over any other .screen rule (including
   body.has-bottom-nav .screen) by using !important. */
/* Only ACTIVE .aft screens render. The base .screen{display:none} would
   normally hide siblings, but our display:flex was overriding it for all
   .aft screens — causing the inactive screens' topbars to bleed through. */
.screen.aft:not(.on){display:none!important;}
.aft {
  width:100%!important; min-height:100%;
  color:var(--txt,#0E2418); font-size:14px;
  font-family:'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  display:flex; flex-direction:column;
  padding:68px 18px 70px!important;
  max-width:none!important;
  margin:0!important;
  background:
    radial-gradient(900px 380px at 50% -120px, rgba(0,166,118,.06), transparent 70%),
    radial-gradient(700px 360px at 50% 110%, rgba(255,184,0,.04), transparent 70%),
    var(--bg,#F4FBF7)!important;
  position:relative;
  box-sizing:border-box;
}
.aft *,.aft *::before,.aft *::after{box-sizing:border-box;}

/* topbar */
.aft .topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.aft .brand{display:flex;align-items:center;gap:9px;background:none;border:0;padding:0;}
.aft .brand .logo{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#00A676 0%,#2BC494 100%);
  color:#fff;font-weight:900;font-size:14px;display:grid;place-items:center;letter-spacing:-.02em;
  box-shadow:0 6px 14px -6px rgba(0,166,118,.5);}
.aft .brand .name{font-weight:800;font-size:16px;letter-spacing:-.02em;color:var(--txt,#0E2418);}
.aft .brand .name .ly{background:linear-gradient(135deg,#00A676 0%,#2BC494 100%);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;}
.aft .topbar .iconbtn{
  width:32px;height:32px;border-radius:10px;
  background:var(--surface,#fff);border:1px solid var(--bd,rgba(14,36,24,.08));
  display:grid;place-items:center;color:var(--txt-2,rgba(14,36,24,.72));font-size:13px;font-weight:700;
  font-family:inherit;cursor:pointer;padding:0;
}

/* greeting */
.aft .greet{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.aft .greet .av{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,#00A676,#0E2418);
  color:#fff;font-weight:800;font-size:18px;display:grid;place-items:center;
  box-shadow:0 8px 18px -8px rgba(0,166,118,.5); cursor:pointer;}
.aft .greet h2{margin:0;font-size:19px;font-weight:800;letter-spacing:-.01em;line-height:1.15;color:var(--txt,#0E2418);}
.aft .greet h2 small{display:block;font-size:11.5px;font-weight:600;letter-spacing:.04em;
  text-transform:none;color:#007A57;margin-top:3px;background:rgba(0,166,118,.10);
  padding:2px 8px;border-radius:99px;width:fit-content;}

/* mint stat strip (single pill, two halves with divider) */
.aft .stat-strip{
  display:flex;background:rgba(0,166,118,.07);border:1px solid rgba(0,166,118,.16);
  border-radius:12px;padding:9px 12px;margin-bottom:14px;gap:14px;font-size:12px;color:var(--txt,#0E2418);
}
.aft .stat-strip > div{flex:1;display:flex;align-items:center;gap:6px;}
.aft .stat-strip .sep{width:1px;background:rgba(14,36,24,.08);flex:0 0 1px;}
.aft .stat-strip b{font-weight:800;color:var(--txt,#0E2418);}
.aft .stat-strip .muted{color:var(--txt-3,rgba(14,36,24,.5));font-size:11px;}
.aft .stat-strip .flame{color:#FF4D2A;font-size:14px;}
.aft .stat-strip .zap{color:#FFB800;font-size:14px;}

/* KIT-STRICT: 96px reto banner (mockup spec) */
.aft .reto-card{
  display:block;text-decoration:none;color:#fff;position:relative;
  height:96px;border-radius:16px;overflow:hidden;margin-bottom:8px;
  box-shadow:0 1px 0 rgba(14,36,24,.04), 0 6px 18px -10px rgba(0,166,118,.18);
  border:0;padding:0;width:100%;font-family:inherit;cursor:pointer;background:#0b1d14;
}
.aft .reto-card.dc{margin-bottom:14px;}
.aft .reto-card .reto-bg{
  position:absolute;inset:0;
  background-size:cover,cover;
  background-position:center,center;
  background-repeat:no-repeat,no-repeat;
}
.aft .reto-card.wc .reto-bg{
  background:linear-gradient(110deg,rgba(11,29,20,.85) 0%,rgba(11,29,20,.55) 55%,rgba(11,29,20,.25) 100%),url('banners/wc-reto-semana.jpg') center/cover no-repeat;
}
.aft .reto-card.dc .reto-bg{
  background:linear-gradient(110deg,rgba(11,29,20,.85) 0%,rgba(11,29,20,.55) 55%,rgba(11,29,20,.25) 100%),url('banners/dc-reto-dia.jpg') center/cover no-repeat;
}
.aft .reto-card .reto-inner{
  position:relative;height:100%;display:flex;align-items:center;gap:12px;padding:0 14px;text-align:left;
}
.aft .reto-card .reto-icon{
  width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:18px;flex-shrink:0;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.aft .reto-card.wc .reto-icon{background:rgba(255,184,0,.18);border:1px solid rgba(255,184,0,.35);}
.aft .reto-card.dc .reto-icon{background:rgba(70,217,168,.22);border:1px solid rgba(70,217,168,.45);}
.aft .reto-card .reto-body{flex:1;min-width:0;}
.aft .reto-card .reto-title{font-size:14px;font-weight:800;letter-spacing:-.005em;line-height:1.15;color:#fff;}
.aft .reto-card .reto-sub{font-size:11px;color:rgba(255,255,255,.78);margin-top:3px;}
.aft .reto-card .reto-sub b{font-weight:800;}
.aft .reto-card.wc .reto-sub b{color:#FFD166;}
.aft .reto-card.dc .reto-sub b{color:#46D9A8;}
.aft .reto-card .reto-chev{color:rgba(255,255,255,.6);font-size:18px;flex-shrink:0;}
/* Bridge to legacy JS that uses .on/.off classes */
.aft .reto-card.on{display:block!important;}
.aft .resume.on{display:flex!important;}
.aft .secrow.on{display:flex!important;}

/* 3-tile quick row */
.aft .tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:16px;}
.aft .tile{
  background:var(--surface,#fff);
  border:1px solid var(--bd,rgba(14,36,24,.08));
  border-radius:16px;
  padding:12px 8px 10px;
  text-align:center;
  box-shadow:0 1px 0 rgba(14,36,24,.04), 0 6px 18px -10px rgba(0,166,118,.18);
  position:relative;cursor:pointer;font-family:inherit;color:var(--txt,#0E2418);
}
.aft .tile .ic{font-size:24px;margin-bottom:4px;line-height:1;}
.aft .tile .lab{font-size:11.5px;font-weight:700;letter-spacing:-.005em;color:var(--txt,#0E2418);}
.aft .tile .sub{font-size:9.5px;color:var(--txt-3,rgba(14,36,24,.5));margin-top:1px;font-weight:600;}
.aft .tile.featured{
  background:linear-gradient(135deg,#00A676 0%,#2BC494 100%);
  color:#fff;border-color:transparent;
  box-shadow:0 12px 28px -10px rgba(0,166,118,.55);
}
.aft .tile.featured .lab{color:#fff;}
.aft .tile.featured .sub{color:rgba(255,255,255,.8);}
.aft .tile.featured .ic{color:#fff;}

/* section header row (eyebrow + right link) */
.aft .secrow{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.aft .secrow .label{font-size:10.5px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--txt-3,rgba(14,36,24,.5));}
.aft .secrow a{color:#007A57;font-weight:700;font-size:12px;text-decoration:none;cursor:pointer;}

/* resume row */
.aft .resume{
  display:flex;gap:12px;align-items:center;padding:13px 14px;
  background:var(--surface,#fff);border:1px solid var(--bd,rgba(14,36,24,.08));border-radius:16px;
  box-shadow:0 1px 0 rgba(14,36,24,.04), 0 6px 18px -10px rgba(0,166,118,.18);
  cursor:pointer;
}
.aft .resume .badge{width:36px;height:36px;border-radius:11px;background:rgba(0,166,118,.10);
  color:#007A57;display:grid;place-items:center;font-size:18px;flex-shrink:0;}
.aft .resume .body{flex:1;min-width:0;}
.aft .resume .body .t{font-size:13.5px;font-weight:800;letter-spacing:-.01em;color:var(--txt,#0E2418);}
.aft .resume .body .m{font-size:11.5px;color:var(--txt-2,rgba(14,36,24,.72));margin-top:2px;}
.aft .resume .chev{color:var(--txt-3,rgba(14,36,24,.5));font-size:18px;font-weight:700;}

/* bottom nav */
.aft .botnav{
  position:absolute;left:0;right:0;bottom:0;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--bd,rgba(14,36,24,.08));
  display:flex;justify-content:space-around;padding:8px 4px 12px;
}
.aft .nv{display:flex;flex-direction:column;align-items:center;gap:2px;
  color:var(--txt-3,rgba(14,36,24,.5));font-size:9.5px;font-weight:700;letter-spacing:.02em;flex:1;
  background:none;border:0;cursor:pointer;font-family:inherit;}
.aft .nv .i{font-size:16px;line-height:1;}
.aft .nv.active{color:#007A57;}

/* update toast */
.aft .upchip{
  position:absolute;bottom:80px;right:14px;
  display:flex;align-items:center;gap:6px;
  padding:5px 9px 5px 7px;border-radius:99px;
  background:linear-gradient(135deg,#00A676 0%,#2BC494 100%);color:#fff;
  font-size:10.5px;font-weight:700;letter-spacing:.02em;
  box-shadow:0 8px 18px -8px rgba(0,166,118,.6);z-index:6;
}
.aft .upchip .d{width:6px;height:6px;border-radius:50%;background:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.4);}

/* ──── Estudiar */
.aft.study{padding:68px 18px 70px!important;display:flex;flex-direction:column;height:100%;background:
  radial-gradient(900px 380px at 50% -120px, rgba(0,166,118,.12), transparent 70%),
  var(--bg,#F4FBF7)!important;}
.aft.study h1{margin:14px 0 4px;font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--txt,#0E2418);}
.aft.study .lede{color:var(--txt-2,rgba(14,36,24,.72));font-size:12.5px;margin-bottom:18px;}
.aft .cardlist{display:flex;flex-direction:column;gap:10px;}
.aft.study .cardlist{gap:10px;}
.aft .escard{
  display:block;text-decoration:none;color:#fff;position:relative;height:78px;
  border-radius:16px;overflow:hidden;box-shadow:0 1px 0 rgba(14,36,24,.04), 0 6px 18px -10px rgba(0,166,118,.18);
  border:0;background:#0b1d14;padding:0;width:100%;font-family:inherit;cursor:pointer;
}
.aft .escard .es-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;}
.aft .escard .es-inner{
  position:relative;height:100%;display:flex;align-items:center;gap:12px;padding:0 14px;text-align:left;
}
.aft .escard .es-ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:15px;flex-shrink:0;}
.aft .escard.repaso .es-ic{background:rgba(255,107,74,.22);border:1px solid rgba(255,107,74,.45);}
.aft .escard.articulos .es-ic{background:rgba(45,156,219,.22);border:1px solid rgba(45,156,219,.45);}
.aft .escard.guias .es-ic{background:rgba(70,217,168,.22);border:1px solid rgba(70,217,168,.45);}
.aft .escard.infografias .es-ic{background:rgba(255,184,0,.22);border:1px solid rgba(255,184,0,.45);}
/* After Screens §2: exact Unsplash URLs from the mockup HTML so the photos match
   pixel-perfect with the reference. CDN-loaded; the first paint will hit the
   network but the browser cache holds it after. */
.aft .escard.repaso .es-bg{background:linear-gradient(110deg,rgba(11,29,20,.86) 0%,rgba(11,29,20,.55) 60%,rgba(11,29,20,.25) 100%),url('https://images.unsplash.com/photo-1486006920555-c77dcf18193c?w=640&q=70') center/cover no-repeat;}
.aft .escard.articulos .es-bg{background:linear-gradient(110deg,rgba(11,29,20,.86) 0%,rgba(11,29,20,.55) 60%,rgba(11,29,20,.25) 100%),url('https://images.unsplash.com/photo-1481627834876-b7833e8f5570?w=640&q=70') center/cover no-repeat;}
.aft .escard.guias .es-bg{background:linear-gradient(110deg,rgba(11,29,20,.86) 0%,rgba(11,29,20,.55) 60%,rgba(11,29,20,.25) 100%),url('https://images.unsplash.com/photo-1581092335397-9583eb92d232?w=640&q=70') center/cover no-repeat;}
.aft .escard.infografias .es-bg{background:linear-gradient(110deg,rgba(11,29,20,.86) 0%,rgba(11,29,20,.55) 60%,rgba(11,29,20,.25) 100%),url('https://images.unsplash.com/photo-1551288049-bebda4e38f71?w=640&q=70') center/cover no-repeat;}
.aft .escard .es-body{flex:1;min-width:0;}
.aft .escard .es-title{font-size:14px;font-weight:800;letter-spacing:-.005em;line-height:1.15;color:#fff;}
.aft .escard .es-meta{font-size:10.5px;color:rgba(255,255,255,.78);margin-top:3px;}
.aft .escard .es-meta b{font-weight:800;color:#FFD166;}
.aft .escard .es-chev{color:rgba(255,255,255,.6);font-size:18px;flex-shrink:0;}

/* ──── Guías */
.aft.guias{padding:68px 18px 70px;}
.aft.guias .ghead{margin-bottom:14px;}
.aft.guias h1{margin:8px 0 2px;font-size:21px;font-weight:800;letter-spacing:-.02em;color:var(--txt,#0E2418);}
.aft.guias .glede{font-size:12px;color:var(--txt-2,rgba(14,36,24,.72));}
.aft .gsearch{
  display:flex;align-items:center;gap:8px;
  padding:5px 12px;background:var(--surface,#fff);border:1px solid var(--bd,rgba(14,36,24,.08));
  border-radius:10px;margin-bottom:10px;box-shadow:0 1px 0 rgba(14,36,24,.04), 0 6px 18px -10px rgba(0,166,118,.18);
  color:var(--txt-3,rgba(14,36,24,.5));font-size:12px;
}
.aft .gsearch input{border:0;background:transparent;outline:none;flex:1;font-family:inherit;font-size:12.5px;color:var(--txt,#0E2418);}
.aft .gsearch .ic{color:var(--txt-2,rgba(14,36,24,.72));}
.aft .gchips{display:flex;gap:6px;margin-bottom:10px;overflow-x:auto;flex-wrap:nowrap;}
.aft .gchip{
  font-size:10.5px;font-weight:700;padding:5px 9px;border-radius:99px;
  background:var(--surface,#fff);border:1px solid var(--bd,rgba(14,36,24,.08));color:var(--txt-2,rgba(14,36,24,.72));
  white-space:nowrap;cursor:pointer;font-family:inherit;
}
.aft .gchip.on{background:linear-gradient(135deg,#00A676,#2BC494);border-color:transparent;color:#fff;
  box-shadow:0 6px 14px -6px rgba(0,166,118,.5);}
.aft .ggrid21{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.aft .gpcard{
  position:relative;height:78px;border-radius:14px;overflow:hidden;
  box-shadow:0 1px 0 rgba(14,36,24,.04), 0 6px 18px -10px rgba(0,166,118,.18);
  background:#0b1d14;cursor:pointer;
}
.aft .gpcard .gp-photo{position:absolute;inset:0;background-size:cover;background-position:center;}
.aft .gpcard .gp-veil{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,29,20,.25) 0%,rgba(11,29,20,.55) 55%,rgba(11,29,20,.92) 100%);}
.aft .gpcard .gp-chip{
  position:absolute;top:7px;right:7px;background:rgba(0,0,0,.5);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  color:#fff;font-size:9.5px;font-weight:800;padding:2px 7px;border-radius:99px;
  border:1px solid rgba(255,255,255,.15);letter-spacing:.02em;z-index:2;
}
.aft .gpcard .gp-chip.done{background:rgba(0,166,118,.85);border-color:rgba(255,255,255,.25);}
.aft .gpcard .gp-body{position:absolute;left:10px;right:10px;bottom:8px;color:#fff;z-index:1;}
.aft .gpcard .gp-t{font-size:12.5px;font-weight:800;letter-spacing:-.005em;line-height:1.15;
  text-shadow:0 1px 4px rgba(0,0,0,.4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.aft .gpcard .gp-meta{font-size:9.5px;color:rgba(255,255,255,.78);margin-top:2px;letter-spacing:.02em;font-weight:600;}
.aft .gpcard .gp-bar{position:absolute;left:0;right:0;bottom:0;height:3px;background:rgba(255,255,255,.12);z-index:1;}
.aft .gpcard .gp-bar i{display:block;height:100%;background:linear-gradient(90deg,#46D9A8,#FFB800);}
.aft .gpcard-footer{
  text-align:center;font-size:11px;color:var(--txt-3,rgba(14,36,24,.5));font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;margin-top:10px;grid-column:1/-1;
}

/* ──── Ranking */
.aft.rank{padding:68px 18px 70px;}
.aft.rank .rhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.aft.rank .rh-ttl{display:flex;align-items:center;gap:6px;font-size:16px;font-weight:800;letter-spacing:-.02em;color:var(--txt,#0E2418);}
.aft.rank .scope{margin:8px 0 10px!important;}
.aft.rank .sc{padding:6px 6px!important;font-size:11px!important;}
/* Hide the legacy 'Mi taller' card and the 'Cuentas persistentes' note below the rows */
.aft.rank #rank-taller-card{display:none!important;}
.aft.rank #lb-note{display:none!important;}
.aft.rank .filter{
  display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border-radius:99px;
  background:var(--surface,#fff);border:1px solid var(--bd,rgba(14,36,24,.08));font-size:12px;font-weight:700;
  color:var(--txt,#0E2418);box-shadow:0 1px 0 rgba(14,36,24,.04), 0 6px 18px -10px rgba(0,166,118,.18);
}
.aft.rank .filter b{color:#007A57;}
.aft.rank .scope{display:flex;gap:6px;margin:12px 0 14px;}
.aft.rank .sc{flex:1;font-size:11.5px;font-weight:700;text-align:center;padding:8px 6px;border-radius:11px;
  background:var(--surface,#fff);border:1px solid var(--bd,rgba(14,36,24,.08));color:var(--txt-2,rgba(14,36,24,.72));
  cursor:pointer;font-family:inherit;}
.aft.rank .sc.on{background:linear-gradient(135deg,#00A676,#2BC494);border-color:transparent;color:#fff;
  box-shadow:0 8px 16px -8px rgba(0,166,118,.5);}
.aft .rrow{
  display:flex;align-items:center;gap:11px;padding:11px 12px;
  background:var(--surface,#fff);border:1px solid var(--bd,rgba(14,36,24,.08));
  border-radius:14px;margin-bottom:7px;box-shadow:0 1px 0 rgba(14,36,24,.04), 0 6px 18px -10px rgba(0,166,118,.18);
}
.aft .rrow.me{background:rgba(0,166,118,.07);border-color:rgba(0,166,118,.25);}
.aft .rrow .rk{width:24px;text-align:center;font-weight:900;font-size:13px;color:var(--txt-3,rgba(14,36,24,.5));}
.aft .rrow .rk.gold{color:#fff;background:linear-gradient(135deg,#FFD166,#FFB800);
  border-radius:50%;width:24px;height:24px;display:grid;place-items:center;
  box-shadow:0 4px 10px -2px rgba(255,184,0,.6);font-size:11px;}
.aft .rrow .rk.silver{color:#fff;background:linear-gradient(135deg,#D5DAE0,#9CA3AF);border-radius:50%;
  width:24px;height:24px;display:grid;place-items:center;font-size:11px;}
.aft .rrow .rk.bronze{color:#fff;background:linear-gradient(135deg,#E2A877,#B97441);border-radius:50%;
  width:24px;height:24px;display:grid;place-items:center;font-size:11px;}
.aft .rrow .av{width:30px;height:30px;border-radius:10px;background:linear-gradient(135deg,#00A676,#0E2418);
  color:#fff;font-weight:800;font-size:12px;display:grid;place-items:center;flex-shrink:0;}
.aft .rrow .who{flex:1;min-width:0;}
.aft .rrow .who .n{font-size:13px;font-weight:800;line-height:1.2;color:var(--txt,#0E2418);}
.aft .rrow .who .r{font-size:10.5px;color:var(--txt-3,rgba(14,36,24,.5));margin-top:1px;font-weight:600;}
.aft .rrow .pts{font-size:15px;font-weight:900;color:#007A57;letter-spacing:-.01em;text-align:right;}
.aft .rrow .pts small{font-size:9.5px;color:var(--txt-3,rgba(14,36,24,.5));font-weight:700;
  display:block;line-height:1;margin-top:2px;letter-spacing:.04em;text-transform:uppercase;}
