:root{
  --cream:#F7FAFE; --card:#fff; --ink:#2F343B; --muted:#6B7280; --line:#E3EAF4;
  --green:#2F80EC; --green2:#2570D8; --green-d:#1E66C9;
  --gtint:#E8F1FE; --gtint-bd:#D4E6FE;
  --lilac:#FFF3D6; --lilac-bd:#FFE0A6; --lilac-tx:#8A6400;
  --amarelo:#FFC53D; --verde:#27AE60;
}
*{box-sizing:border-box}
body{margin:0;background:var(--cream);color:var(--ink);font-family:'Nunito',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;font-size:16px;line-height:1.45}
.wrap{max-width:460px;margin:0 auto;padding:18px 18px 40px}
.appbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:6px 2px 18px}
.brand{display:flex;align-items:center;gap:8px;font-family:'Baloo 2';font-weight:600;font-size:20px}
.brand .dot{font-size:22px}
.brand small{display:block;font-family:'Nunito';font-weight:700;font-size:11.5px;color:var(--muted)}

.h1{font-family:'Baloo 2';font-weight:600;font-size:26px;margin:8px 2px 2px;line-height:1.15}
.psub{color:var(--muted);font-weight:600;margin:0 2px 18px;font-size:14.5px}
.label{display:flex;align-items:center;gap:7px;font-weight:800;font-size:15px;margin:0 2px 8px}
.label .opt{color:var(--muted);font-weight:600;font-size:13px}
.block{margin-bottom:16px}
.input{width:100%;border:2px solid var(--line);border-radius:16px;background:#fff;padding:14px 16px;
  font-family:'Nunito';font-weight:600;font-size:16px;color:var(--ink);outline:0;transition:border-color .15s}
.input::placeholder{color:#9FB0C6;font-weight:600}
.input:focus{border-color:var(--green)}
.selectwrap{position:relative}
.selectwrap .caret{position:absolute;right:16px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--muted)}
select.input{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:40px}

.cta{width:100%;border:0;border-radius:18px;padding:17px;cursor:pointer;font-family:'Baloo 2';font-weight:600;font-size:18px;
  color:#fff;background:linear-gradient(180deg,#3D8BF0,#1E66C9);box-shadow:0 10px 22px -8px rgba(47,128,236,.65);
  display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}
.cta:active{transform:translateY(1px)}
.ghostbtn{width:100%;border:2px solid var(--line);border-radius:18px;padding:15px;cursor:pointer;background:#fff;
  font-family:'Baloo 2';font-weight:500;font-size:16px;color:#6B7280;margin-top:10px;
  display:flex;align-items:center;justify-content:center;gap:8px}
.fotlink{display:block;text-align:center;margin-top:26px;color:var(--muted);font-weight:700;font-size:13px;text-decoration:none}

.hero{text-align:center;padding:26px 8px 8px}
.hero .big{font-size:64px;line-height:1}
.hero h1{font-family:'Baloo 2';font-weight:600;font-size:32px;margin:14px 0 6px}
.hero p{color:var(--muted);font-weight:700;font-size:15.5px;margin:0 auto 22px;max-width:300px}

.headline{display:flex;align-items:center;gap:10px;margin:2px 2px 14px}
.back{width:42px;height:42px;border-radius:14px;border:2px solid var(--line);background:#fff;font-size:18px;cursor:pointer;flex:none;color:var(--ink)}
.headline .tt{font-family:'Baloo 2';font-weight:600;font-size:20px;line-height:1.1}
.headline .tt small{display:block;font-family:'Nunito';font-weight:700;font-size:12.5px;color:var(--muted);margin-top:2px}

.chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:2px solid var(--line);border-radius:999px;
  padding:7px 14px;font-weight:800;font-size:13.5px;margin:0 0 14px}
.note{background:var(--gtint);border:2px solid var(--gtint-bd);border-radius:16px;padding:12px 14px;
  font-weight:700;font-size:13.5px;color:var(--green-d);margin:0 0 14px}
.tiny{color:var(--muted);font-weight:700;font-size:12.5px;margin:6px 2px 0;line-height:1.4}

.photogrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.ptile{position:relative;border:0;background:transparent;padding:0;cursor:pointer}
.pimg{aspect-ratio:1/1;border-radius:16px;overflow:hidden;position:relative;border:3px solid transparent}
.ptile.sel .pimg{border-color:var(--green)}
.pcheck{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;background:var(--green);color:#fff;
  font-weight:800;display:grid;place-items:center;box-shadow:0 2px 6px rgba(0,0,0,.2);font-size:14px}
.wm{position:absolute;inset:-30%;transform:rotate(-26deg);opacity:.2;display:flex;flex-wrap:wrap;align-content:center;pointer-events:none}
.wm span{font-size:7px;font-weight:800;color:#2F343B;white-space:nowrap;width:100%;text-align:center}

.cartdock{position:sticky;bottom:14px;margin-top:16px;background:#fff;border:2px solid var(--line);border-radius:20px;
  padding:12px 12px 12px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;
  box-shadow:0 14px 30px -12px rgba(0,0,0,.25)}
.cartdock .lt{font-weight:800;font-size:13px;color:var(--muted)}
.cartdock .lt b{display:block;font-family:'Baloo 2';font-weight:600;font-size:19px;color:var(--ink)}
.paybtn{border:0;background:linear-gradient(180deg,#3D8BF0,#1E66C9);color:#fff;font-family:'Baloo 2';font-weight:600;font-size:15px;
  padding:13px 18px;border-radius:15px;cursor:pointer;box-shadow:0 8px 16px -6px rgba(47,128,236,.6);white-space:nowrap}

.qrcard{background:#fff;border:2px solid var(--line);border-radius:22px;padding:18px;display:inline-flex;flex-direction:column;align-items:center;gap:14px;margin:6px auto 4px}
.qr{width:160px;height:160px;display:grid;grid-template-columns:repeat(21,1fr)}
.qr i{display:block}
.copybtn{border:2px solid var(--line);background:#fff;border-radius:14px;padding:11px 16px;font-family:'Nunito';font-weight:800;font-size:14px;cursor:pointer;color:var(--ink)}
.center{text-align:center}
.spin{width:22px;height:22px;border:3px solid #DCE6F4;border-top-color:var(--green);border-radius:50%;animation:sp .8s linear infinite;display:inline-block;vertical-align:middle;margin-right:8px}
@keyframes sp{to{transform:rotate(360deg)}}
.okhero{text-align:center;padding:14px 6px}
.okhero .big{font-size:64px}
.okhero h1{font-family:'Baloo 2';font-weight:600;font-size:30px;margin:8px 0 6px}
.okhero p{color:var(--muted);font-weight:700;margin:0 auto 18px;max-width:300px}

.stats{display:flex;gap:10px;margin-bottom:16px}
.stats > div{flex:1;background:#fff;border:2px solid var(--line);border-radius:18px;padding:14px 8px;text-align:center}
.stats .em{font-size:22px}
.stats b{display:block;font-family:'Baloo 2';font-weight:600;font-size:17px;margin-top:2px}
.stats span{font-size:11.5px;color:var(--muted);font-weight:700}
.schoolcard{background:#fff;border:2px solid var(--line);border-radius:20px;padding:8px;margin-bottom:14px}
.schoolcard .sh{font-family:'Baloo 2';font-weight:600;font-size:17px;padding:10px 10px 6px;display:flex;align-items:center;gap:8px}
.turmarow{border:0;background:#F2F6FC;border-radius:14px;padding:13px;margin:6px 4px;width:calc(100% - 8px);
  display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-family:'Nunito';text-align:left}
.turmarow b{display:block;font-weight:800;font-size:14.5px}
.turmarow span{font-size:12px;color:var(--muted);font-weight:700}
.bigdash{width:100%;border:2px dashed var(--gtint-bd);background:var(--gtint);color:var(--green-d);border-radius:18px;
  padding:16px;font-family:'Baloo 2';font-weight:600;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:10px}
.uploadcard{width:100%;border:2px dashed var(--gtint-bd);background:var(--gtint);color:var(--green-d);border-radius:18px;
  padding:20px;font-family:'Baloo 2';font-weight:600;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:10px}
.trow{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.iconbtn{width:48px;height:48px;border:2px solid var(--line);background:#fff;border-radius:14px;font-size:18px;cursor:pointer;flex:none}
.addbtn{width:100%;border:2px dashed var(--line);background:transparent;color:var(--muted);border-radius:14px;padding:13px;
  font-family:'Nunito';font-weight:800;font-size:14px;cursor:pointer;margin:2px 0 18px;display:flex;align-items:center;justify-content:center;gap:6px}
.linkbox{display:flex;gap:8px;align-items:center;background:#fff;border:2px solid var(--line);border-radius:18px;padding:8px 8px 8px 14px;margin-top:14px}
.linkbox .lk{flex:1;font-weight:800;font-size:12.5px;color:var(--green-d);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.selfiecard{width:100%;display:flex;align-items:center;gap:14px;border:2px solid var(--line);background:#fff;border-radius:18px;padding:14px;cursor:pointer;text-align:left}
.selfiecard.done{border-color:var(--gtint-bd);background:var(--gtint)}
.selfiecard .sq{width:48px;height:48px;border-radius:14px;background:#EDF2FA;display:grid;place-items:center;font-size:24px;flex:none}
.selfiecard.done .sq{background:var(--green);color:#fff}
.selfiecard b{display:block;font-weight:800;font-size:14.5px}
.selfiecard span{font-size:12px;color:var(--muted);font-weight:700}
@media (prefers-reduced-motion:no-preference){.fade{animation:fd .25s ease both}}
@keyframes fd{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ============ Polimento de experiência ============ */
.ptile{position:relative}
.pimg{width:100%;aspect-ratio:1/1;border:3px solid transparent;border-radius:16px;overflow:hidden;position:relative;cursor:pointer;padding:0;display:block;background:#eee}
.ptile.sel .pimg{border-color:var(--green)}
.pcircle{position:absolute;top:6px;left:6px;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.94);
  border:2px solid #fff;display:grid;place-items:center;font-weight:800;color:var(--green);cursor:pointer;font-size:15px;box-shadow:0 1px 4px rgba(0,0,0,.22)}
.pcircle.on{background:var(--green);color:#fff;border-color:var(--green)}

.gtools{display:flex;gap:8px;margin:0 0 12px}
.gtool{flex:1;border:2px solid var(--line);background:#fff;border-radius:14px;padding:11px;font-family:'Nunito';font-weight:800;font-size:13px;cursor:pointer;color:var(--ink)}
.gtool:active{background:var(--gtint)}

.input.bad{border-color:#E5533D;background:#FFF5F3}
.errmsg{color:#C0392B;font-weight:800;font-size:12.5px;margin:6px 2px 0;display:flex;align-items:center;gap:5px}

.cta.danger{background:linear-gradient(180deg,#E5533D,#C0392B);box-shadow:0 10px 22px -8px rgba(192,57,43,.5)}

.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;
  font-family:'Nunito';font-weight:800;font-size:14px;padding:13px 20px;border-radius:14px;opacity:0;pointer-events:none;
  transition:opacity .2s,transform .2s;z-index:90;max-width:90%;text-align:center;box-shadow:0 10px 28px -8px rgba(0,0,0,.4)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{background:#27AE60}.toast.err{background:#C0392B}

.modal{position:fixed;inset:0;background:rgba(20,28,40,.45);display:flex;align-items:center;justify-content:center;padding:24px;z-index:95}
.modal-box{background:#fff;border-radius:22px;padding:24px;max-width:360px;width:100%;text-align:center;box-shadow:0 20px 50px -16px rgba(0,0,0,.4)}
.modal-t{font-family:'Baloo 2';font-weight:600;font-size:20px;margin-bottom:6px}
.modal-m{color:var(--muted);font-weight:700;font-size:14px;margin-bottom:18px;line-height:1.45}

.lb{position:fixed;inset:0;background:rgba(18,26,38,.9);display:none;align-items:center;justify-content:center;padding:18px;z-index:100}
.lb.show{display:flex}
.lb-box{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:16px;position:relative}
.lb-img{width:100%;aspect-ratio:3/4;border-radius:20px;position:relative;overflow:hidden}
.lb-x{position:absolute;top:-6px;right:0;width:44px;height:44px;border-radius:50%;border:0;background:rgba(255,255,255,.92);font-size:24px;cursor:pointer;color:var(--ink);z-index:2}
.lb-nav{display:flex;align-items:center;gap:18px;color:#fff;font-weight:800}
.lb-arrow{width:52px;height:52px;border-radius:50%;border:0;background:rgba(255,255,255,.18);color:#fff;font-size:26px;cursor:pointer}
.lb-arrow:active{background:rgba(255,255,255,.32)}
.lb-count{font-size:14px;min-width:60px;text-align:center}
.lb-pick{border:0;border-radius:16px;padding:15px 22px;font-family:'Baloo 2';font-weight:600;font-size:17px;cursor:pointer;background:#fff;color:var(--green-d);width:100%;max-width:300px}
.lb-pick.on{background:linear-gradient(180deg,#3D8BF0,#1E66C9);color:#fff}

.empty{text-align:center;background:#fff;border:2px dashed var(--line);border-radius:20px;padding:32px 20px;margin-bottom:14px}
.empty .big{font-size:46px}
.empty b{display:block;font-family:'Baloo 2';font-weight:600;font-size:18px;margin:10px 0 4px}
.empty span{color:var(--muted);font-weight:700;font-size:13.5px}

:focus-visible{outline:3px solid var(--green);outline-offset:2px;border-radius:8px}
@media (max-width:380px){ .wrap{padding:14px 13px 36px} .photogrid{gap:8px} .stats{gap:7px} }

/* ============ Fluxo: progresso, autorização e espera ============ */
.stepbar{margin:0 2px 16px}
.segs{display:flex;gap:6px;margin-bottom:7px}
.seg{flex:1;height:6px;border-radius:3px;background:var(--line)}
.seg.done{background:var(--green)}
.steplabel{font-weight:800;font-size:12.5px;color:var(--muted)}

.doccard{background:#fff;border:2px solid var(--line);border-radius:16px;padding:16px;font-size:13px;color:#4A5260;
  line-height:1.55;font-weight:600;max-height:230px;overflow:auto;margin-bottom:14px}
.doccard h4{font-family:'Baloo 2';font-weight:600;font-size:15px;margin:0 0 8px;color:var(--ink)}
.doccard p{margin:0 0 9px}

.checkrow{display:flex;gap:12px;align-items:flex-start;background:#fff;border:2px solid var(--line);border-radius:16px;padding:14px;cursor:pointer;margin-bottom:10px}
.checkrow.on{border-color:var(--gtint-bd);background:var(--gtint)}
.checkbox{width:26px;height:26px;border-radius:8px;border:2px solid var(--line);flex:none;display:grid;place-items:center;
  font-weight:800;color:#fff;background:#fff;font-size:15px}
.checkrow.on .checkbox{background:var(--green);border-color:var(--green)}
.checkrow .ctxt{font-weight:700;font-size:13.5px;line-height:1.4;color:var(--ink)}

.donechip{display:inline-flex;align-items:center;gap:6px;background:var(--gtint);border:2px solid var(--gtint-bd);
  color:var(--green-d);font-weight:800;font-size:13px;padding:7px 14px;border-radius:999px;margin-bottom:12px}
.waitcard{background:#FFF8E8;border:2px solid #FFE0A6;border-radius:18px;padding:16px;text-align:center;margin:0 auto 16px;max-width:320px}
.waitcard b{display:block;font-family:'Baloo 2';font-weight:600;font-size:15px;color:#8A6400;margin-bottom:3px}
.waitcard span{font-size:13px;color:#8A6400;font-weight:700}

/* ============ Fluxo em 2 momentos + autorização ============ */
.phases{display:flex;align-items:center;justify-content:center;gap:8px;margin:2px 0 20px;flex-wrap:wrap}
.ph{background:#fff;border:2px solid var(--line);border-radius:999px;padding:7px 13px;font-weight:800;font-size:12.5px;color:var(--muted)}
.ph.on{background:var(--gtint);border-color:var(--gtint-bd);color:var(--green-d)}
.ph.done{background:var(--green);border-color:var(--green);color:#fff}
.phsep{color:var(--muted);font-weight:800}
.steptag{display:inline-block;background:#fff;border:2px solid var(--line);border-radius:999px;padding:6px 13px;font-weight:800;font-size:12px;color:var(--muted);margin:0 0 12px}
.termo{background:#fff;border:2px solid var(--line);border-radius:18px;padding:16px;font-weight:700;font-size:13.5px;color:#4A5260;line-height:1.5;margin-bottom:14px}
.termo b{color:var(--ink)}
.assina{color:var(--muted);font-weight:700;font-size:12px;margin:10px 2px 16px}
.waitbell{font-size:60px;text-align:center}

/* ============ Caminho único: cadastro, linha do tempo, login, reconhecimento, download ============ */
.sect{font-family:'Baloo 2';font-weight:600;font-size:16px;margin:20px 2px 12px;display:flex;align-items:center;gap:7px}
.sect.first{margin-top:2px}
.divline{height:2px;background:var(--line);border-radius:2px;margin:4px 0}

.timeline{margin:10px 0 16px;position:relative}
.tl-item{display:flex;gap:14px;position:relative;padding-bottom:20px}
.tl-item:last-child{padding-bottom:0}
.tl-dot{width:40px;height:40px;border-radius:50%;background:var(--gtint);border:2px solid var(--gtint-bd);display:grid;place-items:center;font-size:18px;flex:none;position:relative;z-index:1}
.tl-item.done .tl-dot{background:var(--green);border-color:var(--green);color:#fff}
.tl-item.next .tl-dot{background:#FFF3D6;border-color:#FFE0A6}
.tl-line{position:absolute;left:19px;top:40px;height:calc(100% - 40px);width:2px;background:var(--line)}
.tl-item:last-child .tl-line{display:none}
.tl-c{padding-top:2px}
.tl-c .date{display:block;font-family:'Baloo 2';font-weight:600;font-size:16px;color:var(--ink)}
.tl-c b{display:block;font-weight:800;font-size:14.5px;margin-top:1px}
.tl-c span{color:var(--muted);font-weight:700;font-size:13px;display:block;margin-top:2px;line-height:1.4}

.scan{display:flex;flex-direction:column;align-items:center;gap:14px;padding:36px 10px 20px;text-align:center}
.scan-face{width:104px;height:104px;border-radius:28px;background:var(--gtint);border:2px solid var(--gtint-bd);display:grid;place-items:center;font-size:48px;position:relative;overflow:hidden}
.scan-line{position:absolute;left:6px;right:6px;height:3px;background:var(--green);box-shadow:0 0 12px var(--green);border-radius:3px;animation:scanmove 1.5s ease-in-out infinite}
@keyframes scanmove{0%{top:10%}50%{top:84%}100%{top:10%}}
.scan b{font-family:'Baloo 2';font-weight:600;font-size:19px}
.scan span{color:var(--muted);font-weight:700;font-size:13.5px;max-width:260px}

.secure{display:flex;align-items:center;justify-content:center;gap:6px;color:var(--muted);font-weight:800;font-size:12px;margin-top:12px}

.dllist{display:flex;flex-direction:column;gap:10px;margin:6px 0 18px}
.dlrow{display:flex;align-items:center;gap:12px;background:#fff;border:2px solid var(--line);border-radius:16px;padding:10px}
.dlrow .thumb{width:52px;height:52px;border-radius:12px;flex:none}
.dlrow b{font-weight:800;font-size:14px;flex:1}
.dlbtn{border:2px solid var(--green);background:#fff;color:var(--green-d);border-radius:12px;padding:10px 15px;font-family:'Nunito';font-weight:800;font-size:13px;cursor:pointer;white-space:nowrap}
.orsep{display:flex;align-items:center;gap:10px;color:var(--muted);font-weight:800;font-size:13px;margin:16px 0}
.orsep::before,.orsep::after{content:"";flex:1;height:2px;background:var(--line);border-radius:2px}

/* ============ Linha do tempo (END do passo 1) ============ */
.timeline{margin:8px 0 16px;text-align:left}
.tl-item{display:flex;gap:14px}
.tl-rail{display:flex;flex-direction:column;align-items:center}
.tl-dot{width:44px;height:44px;border-radius:14px;background:#fff;border:2px solid var(--line);display:grid;place-items:center;font-size:21px;flex:none;z-index:1}
.tl-item.done .tl-dot{background:var(--green);border-color:var(--green)}
.tl-item.now .tl-dot{background:var(--gtint);border-color:var(--gtint-bd)}
.tl-line{flex:1;width:3px;background:var(--line);min-height:22px}
.tl-item:last-child .tl-line{display:none}
.tl-body{padding:9px 0 18px}
.tl-item:last-child .tl-body{padding-bottom:0}
.tl-when{font-weight:800;font-size:12px;color:var(--green-d);text-transform:uppercase;letter-spacing:.02em}
.tl-item:not(.done):not(.now) .tl-when{color:var(--muted)}
.tl-what{font-weight:700;font-size:14px;color:var(--ink);margin-top:2px;line-height:1.35}

/* ============ Login e download (passo 2) ============ */
.loginhero{text-align:center;padding:24px 6px 6px}
.loginhero .big{font-size:58px}
.loginhero h1{font-family:'Baloo 2';font-weight:600;font-size:27px;margin:10px 0 6px}
.loginhero p{color:var(--muted);font-weight:700;font-size:14.5px;margin:0 auto 18px;max-width:300px}
.searching{text-align:center;padding:60px 10px}
.searching .ring{width:54px;height:54px;border:5px solid #DCE6F4;border-top-color:var(--green);border-radius:50%;animation:sp .9s linear infinite;margin:0 auto 18px}
.searching b{font-family:'Baloo 2';font-weight:600;font-size:19px}
.searching span{display:block;color:var(--muted);font-weight:700;font-size:13.5px;margin-top:4px}
.dlrow{display:flex;align-items:center;gap:12px;background:#fff;border:2px solid var(--line);border-radius:16px;padding:10px;margin-bottom:8px}
.dlthumb{width:50px;height:50px;border-radius:12px;flex:none}
.dlname{flex:1;font-weight:800;font-size:13.5px}
.dlbtn{border:2px solid var(--green);background:#fff;color:var(--green-d);border-radius:12px;padding:9px 13px;font-family:'Nunito';font-weight:800;font-size:13px;cursor:pointer}
.dlbtn:active{background:var(--gtint)}
.orline{display:flex;align-items:center;gap:10px;color:var(--muted);font-weight:800;font-size:12.5px;margin:16px 0}
.orline::before,.orline::after{content:"";flex:1;height:2px;background:var(--line)}

/* ============ Marca Retratto ============ */
.bm .frame{stroke:var(--green);fill:none;stroke-width:10;stroke-linejoin:round}
.bm .person{fill:var(--amarelo)}
.brand .bm{width:28px;height:28px;flex:none}
.hero .bm{width:66px;height:66px;margin:0 auto;display:block}
