:root{
  --cream:#33202C; --paper:#3E2936; --plum:#F4E8C9; --rose:#D9705C; --rose-esc:#B23A2F;
  --sage:#5E8F54; --sage-cl:#7FA36F; --amber:#E0A43C; --tan:#4E3644; --brown:#B79B7A;
  --serif:Georgia,'Times New Roman',serif; --sans:-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--cream);color:var(--plum);min-height:100vh;
  padding-bottom:calc(76px + env(safe-area-inset-bottom))}

.topo{display:flex;align-items:center;gap:10px;padding:18px 20px 8px}
.logo-flor{width:38px;height:38px}
.topo h1 .t1{font-family:var(--sans);font-weight:800;font-size:19px;letter-spacing:3px;color:var(--plum)}
.topo h1 .t2{font-family:var(--serif);font-style:italic;font-weight:500;font-size:26px;color:var(--rose)}

main{padding:8px 20px 20px;max-width:520px;margin:0 auto}
h2{margin:18px 0 10px;font-weight:400}
h2 b{font-family:var(--sans);font-weight:800;font-size:16px;letter-spacing:2px;color:var(--plum)}
h2 em{font-family:var(--serif);font-style:italic;font-weight:500;font-size:22px;color:var(--rose)}
.saudacao{font-size:15px;color:var(--brown);margin-top:4px}
.mudo{color:var(--brown);font-size:14px}

.card{background:var(--paper);border:1px solid var(--tan);border-radius:16px;padding:16px;margin-top:12px}
.card h3{font-family:var(--serif);font-style:italic;font-weight:500;font-size:17px;margin-bottom:8px}

.meta-num{font-family:var(--serif);font-size:40px;line-height:1.1}
.meta-num small{font-size:16px;color:var(--brown);font-family:var(--sans)}
.barra{background:var(--tan);border-radius:99px;height:10px;overflow:hidden;margin:10px 0 6px}
.barra > div{background:var(--sage);height:100%;border-radius:99px;transition:width .4s}
.barra.verde > div{background:var(--sage)}

.livro-linha{display:flex;gap:12px;background:var(--paper);border:1px solid var(--tan);
  border-radius:16px;padding:12px;margin-top:10px;align-items:center}
.livro-linha .info{flex:1;min-width:0}
.livro-linha .titulo{font-weight:600;font-size:15px;overflow:hidden;text-overflow:ellipsis;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.livro-linha .acoes-mini{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}

.capa{background:var(--tan);border-radius:8px;overflow:hidden;flex-shrink:0;position:relative;
  display:flex;align-items:center;justify-content:center}
.capa img{width:100%;height:100%;object-fit:cover;display:block}
.capa-p{width:52px;height:78px}
.capa-m{width:64px;height:96px}
.capa-g{width:84px;height:126px}
.capa-fake{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  padding:6px;text-align:center;font-family:var(--serif);font-style:italic;font-size:11px;
  color:var(--paper);background:var(--plum)}

.abas{display:flex;gap:8px;margin:4px 0 14px}
.aba{border:1px solid var(--tan);background:var(--paper);color:var(--brown);border-radius:99px;
  padding:8px 16px;font-size:14px;font-family:var(--sans)}
.aba.ativa{background:var(--rose);border-color:var(--rose);color:#FBF5EE;font-weight:600}

.grade{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grade .item{text-align:center;border:none;background:none;padding:0;font-family:var(--sans);color:var(--plum)}
.grade .capa{width:100%;aspect-ratio:2/3;height:auto;border-radius:10px;box-shadow:0 2px 6px rgba(76,42,61,.14)}
.grade .item p{font-size:12px;margin-top:6px;overflow:hidden;text-overflow:ellipsis;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.grade .coracoes{font-size:11px;color:var(--rose)}

.vazio{text-align:center;padding:26px 10px;color:var(--brown);font-size:14px}
.vazio .flor{font-size:30px;display:block;margin-bottom:8px}

.busca-linha{display:flex;gap:8px;margin:8px 0 14px}
input,select,textarea{font-family:var(--sans);font-size:16px;color:var(--plum);background:var(--paper);
  border:1px solid var(--tan);border-radius:12px;padding:11px 12px;width:100%}
input:focus,select:focus,textarea:focus{outline:2px solid var(--rose);border-color:var(--rose)}

.btn{border:none;border-radius:12px;padding:11px 16px;font-size:15px;font-weight:600;
  font-family:var(--sans);cursor:pointer;flex-shrink:0}
.btn-rose{background:var(--rose-esc);color:#FBEED8}
.btn-sage{background:var(--sage);color:#FBF5EE}
.btn-fantasma{background:none;border:1px solid var(--tan);color:var(--brown)}
.btn-mini{padding:7px 12px;font-size:13px;border-radius:10px}
.btn:active{transform:scale(.97)}

.manual{margin-top:18px;background:var(--paper);border:1px solid var(--tan);border-radius:16px;padding:14px}
.manual summary{cursor:pointer;color:var(--brown);font-size:14px}
.manual label{display:block;font-size:13px;color:var(--brown);margin-top:10px}
.manual input,.manual select{margin-top:4px}
.manual .btn{margin-top:14px;width:100%}

.overlay{position:fixed;inset:0;background:rgba(91,58,74,.45);display:flex;align-items:flex-end;
  justify-content:center;z-index:50;padding:0}
.modal{background:var(--cream);border-radius:20px 20px 0 0;padding:20px;width:100%;max-width:520px;
  max-height:88vh;overflow-y:auto;position:relative}
.modal h3{font-family:var(--serif);font-style:italic;font-weight:500;font-size:19px;padding-right:30px}
.fechar{position:absolute;top:10px;right:14px;border:none;background:none;font-size:26px;color:var(--brown);cursor:pointer}
.det-topo{display:flex;gap:14px;margin-bottom:14px}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.chip{border:1px solid var(--tan);background:var(--paper);color:var(--brown);border-radius:99px;
  padding:7px 14px;font-size:13px;font-family:var(--sans);cursor:pointer}
.chip.ativa{background:var(--rose-esc);border-color:var(--rose-esc);color:#FBEED8}
.prog-linha{display:flex;gap:8px;align-items:center;margin-bottom:12px}
.prog-linha input{width:90px}
.prog-linha span{font-size:13px;color:var(--brown)}
.coracao-linha{display:flex;gap:6px;font-size:28px;margin-bottom:12px;user-select:none}
.coracao-linha button{border:none;background:none;font-size:28px;cursor:pointer;filter:grayscale(1);opacity:.4;padding:2px}
.coracao-linha button.on{filter:none;opacity:1}
.lbl-resenha{display:block;font-size:13px;color:var(--brown)}
.lbl-resenha textarea{margin-top:6px;resize:vertical}
.acoes{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.acoes .btn{flex:1}

.modal-story{text-align:center}
#canvas-story{width:200px;height:auto;border-radius:14px;margin:12px auto;display:block;
  box-shadow:0 4px 14px rgba(76,42,61,.25)}

.navbar{position:fixed;bottom:0;left:0;right:0;background:var(--paper);border-top:1px solid var(--tan);
  display:flex;justify-content:space-around;padding:8px 0 calc(8px + env(safe-area-inset-bottom));z-index:40}
.nav-btn{border:none;background:none;font-family:var(--sans);font-size:12px;color:var(--brown);
  display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 18px;border-radius:12px;cursor:pointer}
.nav-btn span{font-size:20px}
.nav-btn.ativa{color:var(--rose);font-weight:600}

#toast{position:fixed;bottom:calc(90px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);
  background:var(--plum);color:var(--cream);padding:11px 18px;border-radius:99px;font-size:14px;z-index:60;
  box-shadow:0 4px 12px rgba(0,0,0,.2);max-width:90vw;text-align:center}

.rodape{text-align:center;padding:20px;color:var(--brown);font-size:11px}
.resultado{cursor:default}

.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:8px}
.stats-grid b{font-family:var(--serif);font-size:30px;font-weight:500;display:block;color:var(--plum)}
.stats-grid span{font-size:12px;color:var(--brown)}
.grafico{display:flex;gap:5px;align-items:flex-end;height:130px;margin-top:12px}
.gbar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:3px}
.gbar b{font-size:11px;color:var(--amber);font-weight:600;min-height:14px}
.gcol{width:100%;background:var(--rose);border-radius:5px 5px 0 0;min-height:3px}
.gbar span{font-size:10px;color:var(--brown)}
.grade-conq{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:10px}
.conq{background:var(--paper);border:1px solid var(--tan);border-radius:14px;padding:12px;
  display:flex;gap:10px;align-items:center}
.conq.off{opacity:.45;filter:grayscale(1)}
.conq .emj{font-size:24px}
.conq b{font-size:13px;display:block;color:var(--plum)}
.conq span{font-size:11px;color:var(--brown)}
.lbl-cit{margin:14px 0 6px;font-size:13px}
.cit-item{background:var(--paper);border:1px solid var(--tan);border-radius:12px;padding:10px 12px;margin-bottom:8px}
.cit-item p{font-family:var(--serif);font-style:italic;font-size:14px;margin-bottom:6px}
.cit-add{margin:6px 0 0}

/* acabamento dark academia */
body{background:radial-gradient(120% 90% at 50% -10%, #452E3C 0%, #33202C 55%, #291823 100%);background-attachment:fixed}
.card,.livro-linha,.manual,.conq{background:linear-gradient(170deg,#422C3A,#392431);
  box-shadow:0 8px 22px rgba(0,0,0,.28);border-color:#503A48}
h2{display:flex;align-items:baseline;gap:10px}
h2::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(224,164,60,.55),transparent)}
.btn-rose{background:linear-gradient(180deg,#C24534,#A33227);box-shadow:0 5px 14px rgba(178,58,47,.35)}
.btn-sage{background:linear-gradient(180deg,#68985D,#527D48);box-shadow:0 5px 14px rgba(94,143,84,.3)}
.aba.ativa{background:linear-gradient(180deg,#C24534,#A33227);border-color:transparent;box-shadow:0 4px 12px rgba(178,58,47,.3)}
.navbar{background:rgba(41,24,35,.96);border-top:1px solid rgba(224,164,60,.18);backdrop-filter:blur(8px)}
.nav-btn.ativa{background:rgba(217,112,92,.14);color:var(--rose)}
input,select,textarea{background:#2B1A25}
.capa-fake{background:linear-gradient(155deg,#5A3E50 0%,#8A3A31 70%,#B23A2F 100%);color:#F4E8C9}
.stats-grid b{color:var(--amber)}
.meta-num{color:var(--amber)}
.conq:not(.off){border-color:rgba(224,164,60,.45)}
.grade .capa{box-shadow:0 6px 16px rgba(0,0,0,.4)}
.topo{padding-top:22px}
.meta-flex{display:flex;align-items:center;gap:18px;margin-top:6px}
.anel-wrap{position:relative;width:112px;height:112px;flex-shrink:0}
.anel{width:112px;height:112px;transform:rotate(-90deg)}
.anel circle{fill:none;stroke-width:10;stroke-linecap:round}
.anel-fundo{stroke:#4E3644}
.anel-prog{stroke:var(--sage);transition:stroke-dashoffset .6s}
.anel-centro{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.anel-centro b{font-family:var(--serif);font-size:34px;font-weight:700;color:var(--amber);line-height:1}
.anel-centro span{font-size:11px;color:var(--brown)}
.meta-info{flex:1}
.meta-info .pct{font-weight:800;font-size:15px;color:var(--plum)}
.btn-tema{margin-left:auto;border:1px solid var(--tan);background:var(--paper);border-radius:99px;
  width:42px;height:42px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0}
.btn-tema svg{width:24px;height:24px;display:block}
.saudacao-linha{display:flex;align-items:center;gap:6px}
.btn-perfil{border:none;background:none;font-size:13px;cursor:pointer;opacity:.65;padding:2px}
@keyframes rick-pula{0%,100%{transform:translateY(0)}25%{transform:translateY(-16px)}45%{transform:translateY(0)}
  62%{transform:translateY(-8px)}78%{transform:translateY(0)}}
#conq-rick svg{animation:rick-pula 1.1s ease-in-out .2s 2}

/* tema Sol forte */
body[data-tema="sol"]{
  --cream:#F4D35E; --paper:#FBF0C8; --plum:#35202C; --rose:#B23A2F; --rose-esc:#A03227;
  --sage:#4F7A46; --sage-cl:#6B9A5E; --amber:#9C6A10; --tan:#DFC155; --brown:#6E5417;
  background:radial-gradient(120% 90% at 50% -10%, #F8E27E 0%, #F4D35E 55%, #E9C33F 100%);
  background-attachment:fixed}
body[data-tema="sol"] .card,body[data-tema="sol"] .livro-linha,body[data-tema="sol"] .manual,body[data-tema="sol"] .conq{
  background:linear-gradient(170deg,#FBF1C9,#F6E5A8);box-shadow:0 8px 20px rgba(120,90,20,.22);border-color:#E2C767}
body[data-tema="sol"] .navbar{background:rgba(248,228,130,.97);border-top:1px solid rgba(53,32,44,.15)}
body[data-tema="sol"] input,body[data-tema="sol"] select,body[data-tema="sol"] textarea{background:#FDF6DA}
body[data-tema="sol"] .capa-fake{background:linear-gradient(155deg,#7A4A3A 0%,#A03227 70%,#B23A2F 100%);color:#FBEED8}
body[data-tema="sol"] .anel-fundo{stroke:#E2C767}
body[data-tema="sol"] .conq:not(.off){border-color:rgba(53,32,44,.35)}
body[data-tema="sol"] .nav-btn.ativa{background:rgba(178,58,47,.12)}
body[data-tema="sol"] .modal{background:#F6E5A8}
body[data-tema="sol"] .modal-conq{border-color:rgba(53,32,44,.35)}
body[data-tema="sol"] .grade .capa{box-shadow:0 5px 14px rgba(120,90,20,.35)}
.vazio svg{width:170px;max-width:75%;height:auto;display:block;margin:0 auto 8px}
.overlay-centro{align-items:center;padding:20px}
.modal-conq{border-radius:20px;max-width:340px;text-align:center;border:1px solid rgba(224,164,60,.4)}
.modal-conq h3{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--amber);padding:0;margin:4px 0 2px}
.conq-titulo{font-weight:800;letter-spacing:2px;font-size:12px;color:var(--plum);margin-top:8px}
#conq-rick svg{width:150px;height:auto}
