/* ДУЭТ — стиль v2.1 (уголь + аметист), перенесён из утверждённого прототипа */
:root{
  --bg:#0c0c0d; --ink:#f4f2ef; --mut:#b0ada8; --mut2:#7a7872;
  --panel:#16161a; --panel2:#1f1f25; --line:#2a2a31;
  --accent:#a98fe0; --accent-dim:#8f74d4; --accent-soft:rgba(169,143,224,.16);
  --pos:#86b08c; --neg:#c08f8d;
  --serif:'Hoefler Text',Georgia,'Times New Roman',serif;
  --mono:'SF Mono',ui-monospace,Menlo,Consolas,monospace;
  --sans:'Helvetica Neue',system-ui,-apple-system,'Segoe UI',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);
  -webkit-font-smoothing:antialiased;overflow:hidden}
#app{display:flex;flex-direction:column;height:100vh;max-width:480px;margin:0 auto;position:relative}

/* topbar */
#topbar{padding:max(16px,env(safe-area-inset-top)) 18px 12px;display:flex;align-items:center;gap:11px;
  border-bottom:1px solid var(--line);flex:none}
#topbar .av{width:30px;height:30px;border-radius:50%;flex:none;border:1px solid var(--accent);
  background:var(--accent-soft);display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:13px;color:var(--accent)}
#topbar .tt{font-family:var(--serif);font-size:15px;letter-spacing:1px}
#topbar .ss{font-size:10px;color:var(--mut);font-family:var(--mono);margin-top:1px}
#topbar .ss b{color:var(--accent);font-weight:400}

/* view */
#view{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:14px;
  -webkit-overflow-scrolling:touch}
#view::-webkit-scrollbar{width:0}

.eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:2px;color:var(--accent);text-transform:uppercase}
h3.st{font-family:var(--serif);font-size:18px;font-weight:500;letter-spacing:.3px}
.small{font-size:11px;color:var(--mut);font-weight:300}
.mono{font-family:var(--mono)}
.center{text-align:center}
.muted{color:var(--mut)}
.empty{color:var(--mut2);font-size:13px;text-align:center;padding:40px 10px;font-weight:300}

/* idea card */
.idea{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px}
.idea .meta{display:flex;gap:14px;margin-bottom:10px;align-items:center;flex-wrap:wrap}
.idea .meta .c{font-family:var(--mono);font-size:10px;color:var(--mut);letter-spacing:.5px}
.idea .meta .c.acc{color:var(--accent)}
.idea .t{font-size:15px;font-weight:400;line-height:1.4;letter-spacing:.2px}
.idea .by{font-size:10px;color:var(--mut);font-family:var(--mono);margin-top:10px;
  display:flex;justify-content:space-between;align-items:center;gap:8px}
.energy{letter-spacing:2px;color:var(--mut2)}
.energy b{color:var(--accent);font-weight:400}
.actions{display:flex;gap:8px;margin-top:14px}
.btn{border:1px solid var(--line);border-radius:9px;padding:9px 0;font-size:12px;font-family:var(--sans);
  cursor:pointer;background:transparent;color:var(--mut);letter-spacing:.5px;flex:1;transition:.15s}
.btn:active{transform:scale(.97)}
.btn.yes{color:var(--pos);border-color:rgba(134,176,140,.45)}
.btn.no{color:var(--neg);border-color:rgba(192,143,141,.45)}
.btn.later{flex:0 0 42px;color:var(--mut2)}
.btn.done{color:var(--accent);border-color:var(--accent)}
.btn.full{flex:1}

/* fab */
.fab{position:absolute;bottom:84px;right:18px;width:46px;height:46px;border-radius:50%;
  background:var(--bg);color:var(--accent);font-size:22px;font-weight:300;border:1px solid var(--accent);
  cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;
  box-shadow:0 6px 18px rgba(0,0,0,.5)}
.fab:active{transform:scale(.94)}

/* navbar */
#navbar{display:flex;border-top:1px solid var(--line);padding:12px 0 max(14px,env(safe-area-inset-bottom));flex:none}
#navbar div{flex:1;text-align:center;font-family:var(--mono);font-size:9px;color:var(--mut2);
  letter-spacing:1px;cursor:pointer}
#navbar div.on{color:var(--accent)}
#navbar div .dot{display:block;width:3px;height:3px;border-radius:50%;background:var(--accent);
  margin:0 auto 6px;opacity:0}
#navbar div.on .dot{opacity:1}

/* stats */
.statline{display:flex;justify-content:space-between;align-items:baseline;padding:13px 0;border-bottom:1px solid var(--line)}
.statline .k{font-family:var(--mono);font-size:10px;color:var(--mut);letter-spacing:1px;text-transform:uppercase}
.statline .v{font-family:var(--serif);font-size:22px}
.statline .v.acc{color:var(--accent)}
.bar{height:2px;background:var(--panel2);border-radius:2px;overflow:hidden;margin-top:14px}
.bar>i{display:block;height:100%;background:var(--accent)}
.note{font-size:11px;color:var(--mut);font-weight:300;margin-top:10px;line-height:1.5}
.tabs{display:flex;gap:8px;margin-bottom:4px}
.tab{font-family:var(--mono);font-size:10px;letter-spacing:1px;color:var(--mut2);
  border:1px solid var(--line);border-radius:7px;padding:6px 12px;cursor:pointer;text-transform:uppercase}
.tab.on{color:var(--accent);border-color:var(--accent)}

/* achievements */
.ach{display:flex;gap:14px;align-items:center;padding:13px 0;border-bottom:1px solid var(--line)}
.ach .ic{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);display:flex;
  align-items:center;justify-content:center;font-size:15px;flex:none;color:var(--mut)}
.ach.got .ic{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.ach .nm{font-size:13px;letter-spacing:.3px}
.ach.lock .nm{color:var(--mut)}
.ach .ds{font-size:10px;color:var(--mut2);font-family:var(--mono);margin-top:2px;letter-spacing:.3px}
.ach .pr{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--accent)}

/* diary */
.quote{font-family:var(--serif);font-size:15px;font-style:italic;color:var(--accent);line-height:1.5;
  padding:4px 0 8px;letter-spacing:.3px}
.diary{padding:13px 0;border-bottom:1px solid var(--line)}
.diary .dt{font-family:var(--mono);font-size:9px;color:var(--mut2);letter-spacing:1px}
.diary .ms{font-size:13px;margin-top:5px;font-weight:300}
.diary .rs{font-size:11px;color:var(--mut);margin-top:4px;font-style:italic;font-family:var(--serif)}

/* wheel */
.wheel-wrap{display:flex;flex-direction:column;align-items:center;gap:18px;padding-top:8px}
.wheel-disc{width:230px;height:230px;border-radius:50%;border:1px solid var(--line);
  position:relative;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 50%,var(--panel) 0%,var(--bg) 75%);
  transition:transform 4s cubic-bezier(.17,.67,.16,1)}
.wheel-disc .hub{width:70px;height:70px;border-radius:50%;border:1px solid var(--accent);
  background:var(--accent-soft);color:var(--accent);font-family:var(--serif);font-size:12px;
  display:flex;align-items:center;justify-content:center;text-align:center}
.wheel-pointer{color:var(--accent);font-size:18px;margin-bottom:-8px}
.wheel-result{background:var(--panel);border:1px solid var(--accent);border-radius:14px;padding:16px;
  width:100%;text-align:center;min-height:64px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px}
.wheel-result .c{font-family:var(--mono);font-size:10px;color:var(--accent);letter-spacing:1px;text-transform:uppercase}

/* bucket */
.bkt{display:flex;gap:13px;align-items:center;padding:13px 0;border-bottom:1px solid var(--line);cursor:pointer}
.bkt .box{width:20px;height:20px;border-radius:6px;border:1px solid var(--line);flex:none;
  display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--accent)}
.bkt.done .box{border-color:var(--accent);background:var(--accent-soft)}
.bkt.done .t{color:var(--mut2);text-decoration:line-through}
.bkt .t{font-size:14px;font-weight:300}
.progress-big{font-family:var(--serif);font-size:30px}
.progress-big .s{color:var(--mut2);font-size:18px}

/* season */
.season-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px}
.season-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}
.season-row:last-child{border-bottom:0}
.season-row .nm{font-family:var(--serif);font-size:16px}
.season-row .nm.lead{color:var(--accent)}
.season-row .sc{font-family:var(--mono);font-size:12px;color:var(--mut)}
.crown{color:var(--accent);margin-left:6px}

/* modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:flex-end;
  justify-content:center;z-index:20}
.modal[hidden]{display:none}
.sheet{background:var(--bg);border:1px solid var(--line);border-bottom:0;
  border-radius:18px 18px 0 0;width:100%;max-width:480px;padding:22px 18px max(22px,env(safe-area-inset-bottom));
  display:flex;flex-direction:column;gap:14px;animation:up .25s ease}
@keyframes up{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
.sheet h3{font-family:var(--serif);font-size:18px;font-weight:500}
.field label{font-family:var(--mono);font-size:10px;color:var(--mut);letter-spacing:1px;text-transform:uppercase;display:block;margin-bottom:6px}
.field input,.field textarea{width:100%;background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:11px 12px;color:var(--ink);font-family:var(--sans);font-size:14px;outline:none}
.field input:focus,.field textarea:focus{border-color:var(--accent)}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-family:var(--mono);font-size:11px;padding:7px 12px;border-radius:8px;border:1px solid var(--line);
  color:var(--mut);cursor:pointer}
.chip.on{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}
.energy-pick{display:flex;gap:8px}
.energy-pick span{flex:1;text-align:center;border:1px solid var(--line);border-radius:8px;padding:9px 0;
  color:var(--mut2);cursor:pointer;font-size:14px}
.energy-pick span.on{color:var(--accent);border-color:var(--accent)}
.sheet .row{display:flex;gap:10px}
.sheet .row .field{flex:1}
.btn-primary{background:var(--accent);color:#1a1320;border:none;border-radius:11px;padding:13px;
  font-size:14px;font-weight:600;cursor:pointer;font-family:var(--sans);letter-spacing:.3px}
.btn-primary:active{transform:scale(.98)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--mut);border-radius:11px;
  padding:13px;font-size:13px;cursor:pointer}

/* reaction input under respond */
.react-box{margin-top:10px;display:flex;gap:8px}
.react-box input{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:9px;
  padding:9px 11px;color:var(--ink);font-size:13px;outline:none}
.react-box input:focus{border-color:var(--accent)}

/* toast */
.toast{position:fixed;top:max(20px,env(safe-area-inset-top));left:50%;transform:translateX(-50%);
  background:var(--panel);border:1px solid var(--accent);border-radius:12px;padding:12px 18px;z-index:40;
  display:flex;align-items:center;gap:12px;box-shadow:0 8px 24px rgba(0,0,0,.5);animation:up .3s ease;max-width:90%}
.toast .ic{font-size:20px;color:var(--accent)}
.toast .nm{font-family:var(--serif);font-size:14px}
.toast .ds{font-size:10px;color:var(--mut);font-family:var(--mono)}

.loading{color:var(--mut2);text-align:center;padding:40px;font-family:var(--mono);font-size:11px;letter-spacing:1px}
