:root{
  --cream:#F4F1EA; --card:#fff; --ink:#2C2C2E; --muted:#928E87; --line:#E7E2D8;
  --green:#1FA058; --green2:#178A47; --green-d:#147a3f;
  --gtint:#EAF6EF; --gtint-bd:#C4E5D1;
  --lilac:#F4EFFB; --lilac-bd:#CDB8F2; --lilac-tx:#7C4DC4;
}
*{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:'Fredoka';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:'Fredoka';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:#B6B1A8;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:'Fredoka';font-weight:600;font-size:18px;
  color:#fff;background:linear-gradient(180deg,#26A75D,#1A8C49);box-shadow:0 10px 22px -8px rgba(31,160,88,.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:'Fredoka';font-weight:500;font-size:16px;color:#6E6A63;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:'Fredoka';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:'Fredoka';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:#2C2C2E;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:'Fredoka';font-weight:600;font-size:19px;color:var(--ink)}
.paybtn{border:0;background:linear-gradient(180deg,#26A75D,#1A8C49);color:#fff;font-family:'Fredoka';font-weight:600;font-size:15px;
  padding:13px 18px;border-radius:15px;cursor:pointer;box-shadow:0 8px 16px -6px rgba(31,160,88,.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 #E4E0D7;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:'Fredoka';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:'Fredoka';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:'Fredoka';font-weight:600;font-size:17px;padding:10px 10px 6px;display:flex;align-items:center;gap:8px}
.turmarow{border:0;background:#FAF8F3;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:'Fredoka';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:'Fredoka';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:#F3EFE7;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:#E2604B;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,#E2604B,#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:#178A47}.toast.err{background:#C0392B}

.modal{position:fixed;inset:0;background:rgba(25,22,18,.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:'Fredoka';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(22,20,16,.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:'Fredoka';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,#26A75D,#1A8C49);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:'Fredoka';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} }
