/* ════════════════════════════════════════
   STYLE.CSS — All Lotus styles
   Edit this file to change the visual design
════════════════════════════════════════ */

/* ═══════════════════════════════════════ RESET & TOKENS */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
:root{
  --ink:#060f08;--ink2:#0d1f11;--ink3:#142a18;
  --g1:#1b4332;--g2:#2d6a4f;--g3:#40916c;--g4:#52b788;
  --leaf:#b7e4c7;--pale:#e8f5ee;
  --gold:#f5c842;--amber:#d97706;
  --sky:#60a5fa;--rose:#f472b6;--violet:#a78bfa;
  --err:#f87171;
  --wh:#fff;
  --glass:rgba(255,255,255,.055);
  --glass2:rgba(255,255,255,.04);
  --border:rgba(183,228,199,.1);
  --border2:rgba(183,228,199,.06);
  --txt:rgba(255,255,255,.88);
  --txt2:rgba(183,228,199,.6);
  --txt3:rgba(183,228,199,.35);
  --r:16px;--r2:12px;--r3:20px;
}
html,body{height:100%;overflow:hidden;background:var(--ink);font-family:'Georgia',Palatino,serif}
#app{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:480px;margin:0 auto;background:var(--ink);position:relative}

/* ═══════════════════════════════════════ SCREENS */
.screen-wrap{display:none;flex-direction:column;flex:1;min-height:0;
             background:linear-gradient(160deg,var(--ink) 0%,var(--ink2) 60%,var(--ink3) 100%)}
.screen-wrap.show{display:flex}

/* ═══════════════════════════════════════ SETUP */
#sc-setup{align-items:center;justify-content:center;padding:32px 24px;text-align:center;gap:16px}
.setup-lotus{font-size:60px;margin-bottom:4px;filter:drop-shadow(0 0 24px rgba(64,145,108,.5))}
.setup-title{color:var(--wh);font-size:24px;font-weight:700;letter-spacing:-.01em}
.setup-sub{color:var(--txt2);font-size:14px;font-family:sans-serif;line-height:1.7}
.setup-sub strong{color:var(--leaf)}
.setup-field{width:100%;background:rgba(27,67,50,.6);border:1.5px solid rgba(183,228,199,.2);
             border-radius:var(--r);padding:15px 16px;font-size:16px;font-family:sans-serif;
             outline:none;color:var(--wh);-webkit-user-select:text;user-select:text;-webkit-appearance:none}
.setup-field:focus{border-color:var(--g3)}
.setup-field::placeholder{color:var(--txt3)}
.btn-primary{width:100%;background:linear-gradient(135deg,var(--g1),var(--g3));color:var(--wh);
             border:none;border-radius:var(--r);padding:16px;font-size:16px;font-weight:700;
             cursor:pointer;font-family:sans-serif;letter-spacing:.01em}
.btn-primary:active{opacity:.85}
.setup-link{color:rgba(64,145,108,.75);font-size:13px;font-family:sans-serif;text-decoration:none}

/* ═══════════════════════════════════════ PROFILE SELECT */
#sc-profiles{align-items:center;justify-content:flex-start;padding:28px 20px 20px;gap:14px;overflow-y:auto}
.profile-header{text-align:center;width:100%}
.profile-header h1{color:var(--wh);font-size:21px;font-weight:700;margin-bottom:4px}
.profile-header p{color:var(--txt3);font-size:13px;font-family:sans-serif}
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}
.pc{background:var(--glass);border:1.5px solid var(--border);border-radius:var(--r3);
    padding:18px 14px;cursor:pointer;text-align:center;transition:transform .15s,background .15s;
    position:relative;overflow:hidden}
.pc:active{transform:scale(.96);background:rgba(255,255,255,.08)}
.pc.diogo{border-color:rgba(64,145,108,.4);background:rgba(64,145,108,.07)}
.pc.codar{border-color:rgba(167,139,250,.35);background:rgba(167,139,250,.07)}
.pc.pai{border-color:rgba(96,165,250,.3);background:rgba(96,165,250,.06)}
.pc.mae{border-color:rgba(244,114,182,.3);background:rgba(244,114,182,.06)}
.pc.irmao{border-color:rgba(245,200,66,.3);background:rgba(245,200,66,.06)}
.pc-badge{position:absolute;top:8px;right:8px;background:rgba(64,145,108,.3);border-radius:6px;
          padding:2px 7px;font-size:9px;color:var(--leaf);font-family:sans-serif;font-weight:700;letter-spacing:.04em}
.pc-icon{font-size:34px;margin-bottom:8px;display:block}
.pc-name{color:var(--wh);font-size:15px;font-weight:700;font-family:sans-serif;margin-bottom:3px}
.pc-sub{color:var(--txt3);font-size:11px;font-family:sans-serif;line-height:1.4}
.pc-hint{color:var(--txt3);font-size:11px;font-family:sans-serif;text-align:center;width:100%}

/* ═══════════════════════════════════════ MAIN LAYOUT */
#sc-main{flex:1;min-height:0}
#hdr{flex-shrink:0;padding:10px 12px;display:flex;align-items:center;gap:10px;
     border-bottom:1px solid var(--border2);background:rgba(6,15,8,.9)}
.lav{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--g1),var(--g3));
     display:flex;align-items:center;justify-content:center;font-size:20px;
     border:2px solid rgba(183,228,199,.2);position:relative;flex-shrink:0;transition:border-color .3s,box-shadow .3s}
.lav.pulse{border-color:var(--g3);box-shadow:0 0 0 4px rgba(64,145,108,.18)}
.lav.think{border-color:var(--sky);box-shadow:0 0 0 4px rgba(96,165,250,.15)}
.sdot{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;
      background:var(--g3);border:2px solid var(--ink)}
.sdot.busy{background:var(--gold);animation:blink .7s ease-in-out infinite}
.sdot.tk{background:var(--sky);animation:blink .9s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.hi{flex:1;min-width:0}
.hn{color:var(--wh);font-size:17px;font-weight:700;letter-spacing:.02em}
.hs{color:var(--txt3);font-size:11px;font-family:sans-serif;margin-top:1px;transition:color .3s}
.hm{font-size:10px;color:rgba(245,200,66,.65);font-family:sans-serif;margin-top:1px}
.hbtns{display:flex;gap:5px}
.hb{background:var(--glass);border:1px solid var(--border);border-radius:10px;
    color:var(--txt2);cursor:pointer;padding:6px 9px;font-size:13px;transition:all .15s}
.hb:active{background:rgba(64,145,108,.2);color:var(--leaf)}
#prof-pill{display:inline-flex;align-items:center;gap:5px;background:var(--glass);
           border:1px solid var(--border);border-radius:10px;padding:5px 9px;
           cursor:pointer;font-size:11px;font-family:sans-serif;color:var(--txt2)}
#prof-pill:active{background:rgba(64,145,108,.18)}
#fam-bar{display:none;flex-shrink:0;padding:7px 12px;gap:7px;
         overflow-x:auto;border-bottom:1px solid var(--border2)}
#fam-bar.show{display:flex}
#fam-bar::-webkit-scrollbar{display:none}
.fam-btn{background:var(--glass2);border:1px solid var(--border);border-radius:20px;
         padding:6px 14px;font-size:12px;font-family:sans-serif;color:var(--txt3);
         cursor:pointer;white-space:nowrap;flex-shrink:0}
.fam-btn.active{background:rgba(64,145,108,.18);border-color:rgba(64,145,108,.35);color:var(--leaf);font-weight:700}
#statbar{display:none;padding:5px 14px;align-items:center;gap:8px;flex-shrink:0;background:rgba(6,15,8,.6)}
#statbar.on{display:flex}
.spin{width:11px;height:11px;border:2px solid rgba(96,165,250,.2);border-top-color:var(--sky);
      border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#statmsg{color:rgba(96,165,250,.75);font-size:11px;font-family:sans-serif}

/* ═══════════════════════════════════════ TAB SCREENS */
.tab{display:none;flex:1;flex-direction:column;min-height:0}
.tab.active{display:flex}

/* ═══════════════════════════════════════ CHAT */
#chat{flex:1;overflow-y:auto;padding:14px 12px 6px;display:flex;flex-direction:column;gap:13px;
      -webkit-overflow-scrolling:touch}
#chat::-webkit-scrollbar{width:2px}
#chat::-webkit-scrollbar-thumb{background:rgba(183,228,199,.12);border-radius:2px}
#empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;
             text-align:center;padding:20px;gap:12px;flex:1}
.empty-lotus{font-size:56px;filter:drop-shadow(0 0 20px rgba(64,145,108,.4));animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.empty-title{color:var(--wh);font-size:22px;font-weight:700}
.empty-sub{color:var(--txt3);font-size:13px;font-family:sans-serif;line-height:1.65}
.chips{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-top:4px}
.chip{background:var(--glass);border:1px solid var(--border);border-radius:18px;
      padding:7px 14px;font-size:12px;color:var(--leaf);cursor:pointer;font-family:sans-serif}
.chip:active{background:rgba(64,145,108,.2)}

/* ── Message rows ── */
.row{display:flex;gap:8px;align-items:flex-end;animation:slideup .25s ease}
@keyframes slideup{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.row.u{flex-direction:row-reverse}
.mav{width:28px;height:28px;border-radius:50%;flex-shrink:0;
     display:flex;align-items:center;justify-content:center;font-size:14px}
.mav.bot{background:linear-gradient(135deg,var(--g1),var(--g3))}
.mav.usr{background:linear-gradient(135deg,var(--g4),var(--g1))}
.mwrap{max-width:83%}
.bbl{padding:11px 14px;font-size:15px;line-height:1.72;border-radius:18px;word-break:break-word}
.bbl.bot{background:var(--glass);color:var(--txt);border:1px solid var(--border);border-bottom-left-radius:4px}
.bbl.usr{background:linear-gradient(135deg,rgba(27,67,50,.92),rgba(64,145,108,.72));
         color:var(--pale);border-bottom-right-radius:4px;font-family:sans-serif;font-size:14px}
.bbl strong{font-weight:700;color:var(--leaf)}.bbl.usr strong{color:#fef3c7}
.bbl em{font-style:italic;opacity:.82}
.bbl code{background:rgba(64,145,108,.2);padding:1px 5px;border-radius:4px;
          font-size:.84em;font-family:monospace;color:var(--leaf)}
.bbl li{margin:3px 0 3px 16px}
.bbl-img{max-width:100%;border-radius:12px;margin-bottom:8px;display:block;
         border:1px solid var(--border)}
.bbl-code{background:rgba(6,15,8,.8);border:1px solid rgba(64,145,108,.2);border-radius:10px;
          padding:10px 12px;margin:6px 0;font-family:monospace;font-size:13px;
          color:var(--leaf);overflow-x:auto;white-space:pre-wrap;line-height:1.5}
.ts{font-size:10px;color:var(--txt3);font-family:sans-serif;margin-top:2px;text-align:right}
.badge{display:inline-flex;align-items:center;gap:4px;border-radius:8px;
       padding:3px 8px;font-size:11px;font-family:sans-serif;margin-bottom:4px}
.badge.tool{background:rgba(96,165,250,.08);border:1px solid rgba(96,165,250,.2);color:rgba(96,165,250,.78)}
.badge.search{background:rgba(167,139,250,.08);border:1px solid rgba(167,139,250,.2);color:rgba(167,139,250,.78)}
.badge.think{background:rgba(96,165,250,.06);border:1px solid rgba(96,165,250,.15);color:rgba(96,165,250,.6)}
.badge.live{background:rgba(64,145,108,.08);border:1px solid rgba(64,145,108,.22);color:rgba(183,228,199,.7)}
.stream-cur{display:inline-block;width:2px;height:16px;background:var(--g3);
            margin-left:2px;vertical-align:middle;animation:cur .8s steps(1) infinite}
@keyframes cur{0%,100%{opacity:1}50%{opacity:0}}
/* Typing indicator */
#typing{display:none;align-items:center;gap:8px}
#typing.on{display:flex;animation:slideup .25s ease}
.tbbl{background:var(--glass);border:1px solid var(--border);
      border-radius:18px 18px 18px 4px;padding:12px 16px;display:flex;gap:5px;align-items:center}
.dot{width:7px;height:7px;border-radius:50%;background:var(--g3);animation:dot 1.2s ease-in-out infinite}
.dot:nth-child(2){animation-delay:.22s}.dot:nth-child(3){animation-delay:.44s}
@keyframes dot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}
#typing.tk .dot{background:var(--sky)}
/* Image / file previews */
#img-prev{display:none;padding:0 12px;margin-bottom:6px;position:relative;height:86px}
#img-prev.on{display:block}
#img-prev img{width:76px;height:76px;object-fit:cover;border-radius:11px;border:2px solid var(--g3)}
#img-prev button{position:absolute;top:0;left:66px;background:#b91c1c;border:none;
                 color:#fff;border-radius:50%;width:22px;height:22px;font-size:11px;cursor:pointer}
#file-prev{display:none;padding:0 12px;margin-bottom:6px;align-items:center;gap:8px}
#file-prev.on{display:flex}
.file-pill{background:rgba(96,165,250,.08);border:1px solid rgba(96,165,250,.22);border-radius:10px;
           padding:6px 12px;font-size:12px;font-family:sans-serif;color:var(--sky);flex:1;
           white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#file-prev button{background:#b91c1c;border:none;color:#fff;border-radius:50%;
                  width:22px;height:22px;font-size:11px;cursor:pointer;flex-shrink:0}

/* ═══════════════════════════════════════ FOOTER */
#ftr{flex-shrink:0;padding:7px 12px 16px;background:rgba(6,15,8,.92);
     border-top:1px solid var(--border2)}
#errbar{display:none;background:rgba(185,28,28,.12);border:1px solid rgba(248,113,113,.2);
        border-radius:10px;padding:8px 12px;color:#fca5a5;font-size:12px;font-family:sans-serif;margin-bottom:7px}
#errbar.on{display:block}
.tbtns{display:flex;gap:5px;margin-bottom:7px;overflow-x:auto;padding-bottom:1px}
.tbtns::-webkit-scrollbar{display:none}
.tb{background:var(--glass);border:1px solid var(--border);border-radius:10px;
    color:var(--txt2);cursor:pointer;padding:6px 11px;font-size:12px;font-family:sans-serif;
    display:flex;align-items:center;gap:4px;white-space:nowrap;flex-shrink:0;transition:all .15s}
.tb:active,.tb.on{background:rgba(64,145,108,.2);color:var(--leaf);border-color:rgba(64,145,108,.3)}
.tb.rec{background:rgba(185,28,28,.2);color:#fca5a5;border-color:var(--err);
        animation:recpulse .9s ease-in-out infinite}
@keyframes recpulse{0%,100%{opacity:1}50%{opacity:.5}}
#vwave{display:none;align-items:center;justify-content:center;gap:3px;height:22px;margin-bottom:5px}
#vwave.on{display:flex}
.wb{width:4px;border-radius:4px;background:var(--g3);animation:wavebar 1s ease-in-out infinite}
.wb:nth-child(1){height:8px}.wb:nth-child(2){height:14px;animation-delay:.1s}
.wb:nth-child(3){height:20px;animation-delay:.2s}.wb:nth-child(4){height:14px;animation-delay:.3s}
.wb:nth-child(5){height:8px;animation-delay:.4s}
@keyframes wavebar{0%,100%{transform:scaleY(1);opacity:.5}50%{transform:scaleY(1.6);opacity:1}}
.inrow{display:flex;gap:8px;align-items:flex-end}
#inp{flex:1;background:rgba(27,67,50,.4);border:1.5px solid rgba(183,228,199,.15);border-radius:var(--r);
     padding:12px 13px;font-size:15px;font-family:sans-serif;resize:none;outline:none;
     color:var(--wh);line-height:1.5;max-height:110px;overflow-y:auto;caret-color:var(--g3);
     -webkit-user-select:text;user-select:text;-webkit-appearance:none}
#inp::placeholder{color:var(--txt3)}
#inp:focus{border-color:rgba(64,145,108,.45)}
#sbtn{background:linear-gradient(135deg,var(--g1),var(--g3));border:none;border-radius:13px;
      width:48px;height:48px;min-width:48px;display:flex;align-items:center;justify-content:center;
      cursor:pointer;color:var(--wh);box-shadow:0 2px 12px rgba(64,145,108,.25);transition:all .2s}
#sbtn:disabled{background:rgba(183,228,199,.08);box-shadow:none;cursor:default}
#sbtn:active:not(:disabled){transform:scale(.91)}
.ft-cap{text-align:center;font-size:10px;color:rgba(183,228,199,.15);font-family:sans-serif;margin-top:7px;letter-spacing:.02em}

/* ═══════════════════════════════════════ BOTTOM NAV */
#botnav{flex-shrink:0;display:flex;background:rgba(6,15,8,.95);
        border-top:1px solid var(--border2);padding-bottom:env(safe-area-inset-bottom)}
.nbtn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
      padding:8px 2px 6px;cursor:pointer;border:none;background:none;
      color:var(--txt3);font-family:sans-serif;gap:2px;transition:color .2s}
.nbtn .ni{font-size:20px;line-height:1}
.nbtn .nl{font-size:9px;letter-spacing:.02em}
.nbtn.active{color:var(--g3)}
.nbtn.active .ni{filter:drop-shadow(0 0 6px rgba(64,145,108,.5))}

/* ═══════════════════════════════════════ PANELS SHARED */
.panel-scroll{flex:1;overflow-y:auto;padding:16px 14px;-webkit-overflow-scrolling:touch}
.panel-scroll::-webkit-scrollbar{width:2px}
.panel-scroll::-webkit-scrollbar-thumb{background:rgba(183,228,199,.1);border-radius:2px}
.sec-title{color:rgba(245,200,66,.65);font-size:10px;font-family:sans-serif;font-weight:700;
           letter-spacing:.08em;margin-bottom:8px;margin-top:16px}
.sec-title:first-child{margin-top:0}
.card{background:var(--glass);border:1px solid var(--border);border-radius:var(--r);
      padding:14px;margin-bottom:10px}
.card-t{color:var(--wh);font-size:14px;font-weight:700;font-family:sans-serif;margin-bottom:3px}
.card-s{color:var(--txt2);font-size:12px;font-family:sans-serif;line-height:1.5}
.add-form{background:var(--glass2);border:1px solid var(--border2);border-radius:var(--r);
          padding:14px;margin-bottom:14px}
.fi{width:100%;background:rgba(27,67,50,.5);border:1.5px solid rgba(183,228,199,.18);
    border-radius:var(--r2);padding:11px 13px;font-size:14px;font-family:sans-serif;
    outline:none;color:var(--wh);margin-bottom:8px;-webkit-appearance:none;
    -webkit-user-select:text;user-select:text}
.fi:focus{border-color:var(--g3)}
.fi::placeholder{color:var(--txt3)}
select.fi{cursor:pointer}
.btn-s{background:rgba(64,145,108,.15);border:1px solid rgba(64,145,108,.28);border-radius:10px;
       padding:8px 14px;font-size:13px;color:var(--leaf);cursor:pointer;font-family:sans-serif;flex-shrink:0}
.btn-s:active{background:rgba(64,145,108,.28)}
.btn-s.red{background:rgba(248,113,113,.1);border-color:rgba(248,113,113,.22);color:var(--err)}
.btn-s.gold{background:rgba(245,200,66,.08);border-color:rgba(245,200,66,.2);color:var(--gold)}
.empty-msg{text-align:center;padding:24px 16px;color:var(--txt3);font-family:sans-serif;font-size:13px;line-height:1.7}
.empty-msg span{font-size:32px;display:block;margin-bottom:8px}

/* ═══════════════════════════════════════ NOTES */
.note-card{background:var(--glass);border:1px solid var(--border);border-radius:var(--r);
           padding:14px;margin-bottom:9px;cursor:pointer}
.note-card:active{background:rgba(255,255,255,.07)}
.note-t{color:var(--wh);font-size:14px;font-weight:700;font-family:sans-serif;margin-bottom:4px}
.note-p{color:var(--txt3);font-size:12px;font-family:sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.note-d{color:rgba(183,228,199,.25);font-size:10px;font-family:sans-serif;margin-top:6px}
#note-editor{display:none;position:fixed;inset:0;z-index:200;flex-direction:column;
             background:linear-gradient(160deg,var(--ink),var(--ink2));padding:16px}
#note-editor.show{display:flex}
.ed-bar{display:flex;gap:8px;margin-bottom:12px;align-items:center}
.ed-back{background:var(--glass);border:1px solid var(--border);border-radius:10px;
         padding:8px 14px;font-size:13px;color:var(--leaf);cursor:pointer;font-family:sans-serif}
.ed-save{background:linear-gradient(135deg,var(--g1),var(--g3));border:none;border-radius:10px;
         padding:8px 18px;font-size:13px;color:var(--wh);cursor:pointer;font-family:sans-serif;font-weight:700;margin-left:auto}
.ed-del{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.2);border-radius:10px;
        padding:8px 12px;font-size:13px;color:var(--err);cursor:pointer;font-family:sans-serif}
#ned-title{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(183,228,199,.18);
           padding:12px 4px;font-size:18px;font-weight:700;color:var(--wh);outline:none;
           font-family:Georgia,serif;margin-bottom:8px;-webkit-user-select:text;user-select:text}
#ned-title::placeholder{color:var(--txt3)}
#ned-body{flex:1;background:transparent;border:none;padding:8px 4px;font-size:15px;
          color:rgba(183,228,199,.85);font-family:Georgia,serif;outline:none;resize:none;line-height:1.7;
          -webkit-user-select:text;user-select:text}
#ned-body::placeholder{color:var(--txt3)}

/* ═══════════════════════════════════════ TIMER */
.timer-display{text-align:center;padding:24px 0}
.timer-clock{font-size:60px;font-weight:700;color:var(--wh);font-family:sans-serif;letter-spacing:.05em}
.timer-lbl{color:var(--txt3);font-size:13px;font-family:sans-serif;margin-top:6px}
.timer-btns{display:flex;gap:10px;justify-content:center;margin-top:18px}
.tbig{background:rgba(64,145,108,.15);border:1.5px solid rgba(64,145,108,.3);border-radius:var(--r);
      padding:12px 24px;font-size:15px;color:var(--leaf);cursor:pointer;font-family:sans-serif;font-weight:700}
.tbig:active{background:rgba(64,145,108,.3)}
.tbig.red{background:rgba(248,113,113,.1);border-color:rgba(248,113,113,.25);color:var(--err)}

/* ═══════════════════════════════════════ HABITS */
.habit-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border2)}
.habit-row:last-child{border-bottom:none}
.hcheck{width:28px;height:28px;border-radius:50%;border:2px solid rgba(64,145,108,.4);
        display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;flex-shrink:0;transition:all .2s}
.hcheck.done{background:var(--g3);border-color:var(--g3)}
.hname{flex:1;color:rgba(183,228,199,.85);font-size:14px;font-family:sans-serif}
.hstreak{font-size:11px;color:var(--gold);font-family:sans-serif}

/* ═══════════════════════════════════════ CALENDAR */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:12px}
.cday{aspect-ratio:1;display:flex;align-items:center;justify-content:center;
      border-radius:8px;font-size:12px;font-family:sans-serif;color:var(--txt3);cursor:pointer}
.cday.head{color:rgba(183,228,199,.28);font-size:10px;cursor:default}
.cday.today{background:var(--g3);color:var(--wh);font-weight:700}
.cday.has-evt{background:rgba(64,145,108,.18);color:var(--leaf);font-weight:600}
.cday.sel{border:1.5px solid var(--g3);color:var(--leaf)}
.cday:active:not(.head){background:rgba(64,145,108,.22)}
.evt-row{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--border2)}
.evt-row:last-child{border-bottom:none}
.evt-time{color:var(--g3);font-size:11px;font-family:sans-serif;white-space:nowrap;margin-top:2px;min-width:36px}
.evt-title{color:rgba(183,228,199,.88);font-size:14px;font-family:sans-serif}
.evt-note{color:var(--txt3);font-size:11px;font-family:sans-serif}

/* ═══════════════════════════════════════ FINANCE */
.fin-row{display:flex;gap:8px;margin-bottom:14px}
.fin-box{flex:1;background:var(--glass);border-radius:var(--r2);padding:12px;text-align:center;border:1px solid var(--border)}
.fin-val{font-size:17px;font-weight:700;font-family:sans-serif;color:var(--leaf)}
.fin-val.red{color:var(--err)}.fin-val.gold{color:var(--gold)}
.fin-lab{font-size:10px;color:var(--txt3);font-family:sans-serif;margin-top:2px}
.tx-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border2)}
.tx-row:last-child{border-bottom:none}
.tx-ic{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.tx-ic.inc{background:rgba(64,145,108,.18)}.tx-ic.exp{background:rgba(248,113,113,.13)}
.tx-name{color:rgba(183,228,199,.85);font-size:14px;font-family:sans-serif}
.tx-cat{color:var(--txt3);font-size:11px;font-family:sans-serif}
.tx-amt{font-size:14px;font-weight:700;font-family:sans-serif}
.tx-amt.inc{color:var(--g3)}.tx-amt.exp{color:var(--err)}

/* ═══════════════════════════════════════ MUSIC */
.music-card{background:var(--glass);border:1px solid var(--border);border-radius:var(--r);
            display:flex;align-items:center;gap:12px;padding:11px;margin-bottom:7px;cursor:pointer}
.music-card:active{background:rgba(255,255,255,.07)}
.music-art{width:46px;height:46px;border-radius:9px;object-fit:cover;flex-shrink:0;
           background:rgba(64,145,108,.18);display:flex;align-items:center;justify-content:center;font-size:20px}
.music-t{color:rgba(183,228,199,.9);font-size:14px;font-family:sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.music-a{color:var(--txt3);font-size:12px;font-family:sans-serif}
.music-play{color:var(--g3);font-size:18px}

/* ═══════════════════════════════════════ BOTTOM SHEET (panels) */
.bsheet-wrap{position:fixed;inset:0;z-index:100;display:flex;align-items:flex-end;
             pointer-events:none;opacity:0;transition:opacity .3s}
.bsheet-wrap.on{pointer-events:all;opacity:1}
.bsheet-bg{position:absolute;inset:0;background:rgba(0,0,0,.68)}
.bsheet{position:relative;border-radius:24px 24px 0 0;padding:22px 18px 36px;
        width:100%;max-width:480px;margin:0 auto;max-height:82vh;overflow-y:auto;
        transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);
        background:linear-gradient(160deg,#0a1f12,#112a1a);border:1px solid var(--border)}
.bsheet-wrap.on .bsheet{transform:translateY(0)}
.bsheet-title{color:var(--wh);font-size:17px;font-weight:700;margin-bottom:3px}
.bsheet-sub{color:var(--txt3);font-size:12px;font-family:sans-serif;margin-bottom:16px}

/* ═══════════════════════════════════════ MEMORY PANEL */
.mem-stat-row{display:flex;gap:8px;margin-bottom:12px}
.msb{background:var(--glass2);border-radius:10px;padding:8px 10px;flex:1;text-align:center}
.msv{color:var(--leaf);font-size:17px;font-weight:700;font-family:sans-serif}
.msl{color:var(--txt3);font-size:10px;font-family:sans-serif;margin-top:1px}
.mem-sec{margin-bottom:12px}
.mem-lb{color:rgba(245,200,66,.62);font-size:10px;font-family:sans-serif;font-weight:700;letter-spacing:.07em;margin-bottom:5px}
.mem-val{color:rgba(183,228,199,.82);font-size:13px;font-family:sans-serif;background:var(--glass2);border-radius:10px;padding:8px 11px;line-height:1.55}
.mem-clr{width:100%;background:rgba(185,28,28,.1);border:1px solid rgba(248,113,113,.2);border-radius:12px;
         padding:11px;color:#fca5a5;font-size:13px;font-family:sans-serif;cursor:pointer;margin-top:12px}
.mem-key{width:100%;background:rgba(64,145,108,.12);border:1px solid rgba(64,145,108,.25);border-radius:12px;
         padding:11px;color:var(--leaf);font-size:13px;font-family:sans-serif;cursor:pointer;margin-top:8px}

/* ═══════════════════════════════════════ MAP */
#map-box{position:relative;height:75vh}
#map{width:100%;height:calc(100% - 52px)}
.map-bar{height:52px;display:flex;align-items:center;padding:0 16px;gap:10px;background:rgba(13,31,18,.9)}
.map-lbl{color:var(--leaf);font-size:13px;font-family:sans-serif;flex:1}

/* ═══════════════════════════════════════ LIVE PANEL */
.live-orb{width:96px;height:96px;border-radius:50%;background:radial-gradient(circle,var(--g3),var(--g1));
          margin:0 auto 14px;display:flex;align-items:center;justify-content:center;
          font-size:38px;cursor:pointer;transition:all .3s;border:2px solid rgba(183,228,199,.15)}
.live-orb.listening{background:radial-gradient(circle,#60a5fa,#2563eb);
                    box-shadow:0 0 0 6px rgba(96,165,250,.18),0 0 24px rgba(96,165,250,.35);
                    animation:orbpulse 1s ease-in-out infinite}
.live-orb.speaking{background:radial-gradient(circle,var(--gold),var(--amber));
                   box-shadow:0 0 0 6px rgba(245,200,66,.18),0 0 24px rgba(245,200,66,.35);
                   animation:orbpulse .7s ease-in-out infinite}
.live-orb.ready{background:radial-gradient(circle,var(--g4),var(--g2));
                box-shadow:0 0 0 6px rgba(64,145,108,.18);animation:orbpulse 2s ease-in-out infinite}
@keyframes orbpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.live-bars{display:flex;gap:4px;justify-content:center;align-items:flex-end;height:28px;margin-bottom:10px}
.lbar{width:5px;border-radius:4px;background:var(--g3);animation:lbaranim 1.2s ease-in-out infinite}
.lbar:nth-child(1){animation-delay:0s}.lbar:nth-child(2){animation-delay:.15s}
.lbar:nth-child(3){animation-delay:.3s}.lbar:nth-child(4){animation-delay:.15s}
.lbar:nth-child(5){animation-delay:0s}
.live-bars.active .lbar{animation:lbaract 1s ease-in-out infinite}
@keyframes lbaranim{0%,100%{height:6px;opacity:.4}50%{height:18px;opacity:1}}
@keyframes lbaract{0%{height:4px}50%{height:26px}100%{height:4px}}
.live-status{color:var(--txt2);font-size:14px;font-family:sans-serif;margin-bottom:8px;text-align:center}
.live-tx{color:var(--txt3);font-size:13px;font-family:Georgia,serif;line-height:1.6;
         min-height:44px;padding:10px;background:var(--glass2);border-radius:10px;margin-bottom:14px}
.live-btns{display:flex;gap:10px;justify-content:center}
.live-btn{background:rgba(64,145,108,.15);border:1.5px solid rgba(64,145,108,.28);border-radius:14px;
          padding:11px 22px;font-size:14px;font-weight:700;color:var(--leaf);cursor:pointer;font-family:sans-serif}
.live-btn:active{background:rgba(64,145,108,.3)}
.live-btn.red{background:rgba(248,113,113,.1);border-color:rgba(248,113,113,.25);color:var(--err)}
.live-mode-row{display:flex;gap:8px;justify-content:center;margin-bottom:16px}
.live-mode{background:var(--glass2);border:1px solid var(--border);border-radius:10px;
           padding:7px 14px;font-size:12px;font-family:sans-serif;color:var(--txt3);cursor:pointer}
.live-mode.sel{background:rgba(64,145,108,.18);border-color:rgba(64,145,108,.38);color:var(--leaf)}

/* ═══════════════════════════════════════ IMAGE GEN */
.ig-models,.ig-styles,.ig-aspects{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}
.ig-opt{background:var(--glass2);border:1.5px solid var(--border);border-radius:10px;
        padding:7px 13px;font-size:12px;font-family:sans-serif;color:var(--txt3);cursor:pointer}
.ig-opt.sel{background:rgba(64,145,108,.18);border-color:rgba(64,145,108,.38);color:var(--leaf);font-weight:700}
.ig-opt.asp{flex:1;text-align:center;padding:7px 4px}
.ig-ta{width:100%;background:rgba(27,67,50,.5);border:1.5px solid rgba(183,228,199,.18);
       border-radius:var(--r2);padding:12px;font-size:14px;font-family:sans-serif;outline:none;
       color:var(--wh);resize:none;min-height:80px;-webkit-user-select:text;user-select:text;-webkit-appearance:none}
.ig-ta::placeholder{color:var(--txt3)}
.ig-ta:focus{border-color:var(--g3)}
.ig-result img{width:100%;border-radius:var(--r);border:1px solid var(--border);cursor:pointer;display:block;margin-top:12px}
.ig-loader{display:none;flex-direction:column;align-items:center;gap:10px;padding:28px 0}
.ig-loader.on{display:flex}
.ig-spin{width:40px;height:40px;border:3px solid rgba(64,145,108,.18);border-top-color:var(--g3);
         border-radius:50%;animation:spin .9s linear infinite}
.ig-spinner-txt{color:var(--txt2);font-size:13px;font-family:sans-serif}
.gen-img-wrap img{max-width:100%;border-radius:14px;border:1px solid var(--border);display:block;cursor:pointer}
.gen-img-cap{color:var(--txt3);font-size:11px;font-family:sans-serif;margin-top:4px;font-style:italic}

/* ═══════════════════════════════════════ CAMERA */
#cam-modal{display:none;position:fixed;inset:0;z-index:300;background:#000;flex-direction:column}
#cam-modal.on{display:flex}
#cam-vid{flex:1;object-fit:cover;width:100%}
.cambar{padding:18px;display:flex;gap:16px;justify-content:center;align-items:center;background:rgba(0,0,0,.55)}
.camb{background:rgba(255,255,255,.14);border:none;color:#fff;border-radius:50%;
      width:52px;height:52px;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.camsnap{background:var(--wh);width:62px;height:62px;border:4px solid rgba(255,255,255,.35)}

/* ═══════════════════════════════════════ TOAST */
#toast{position:fixed;bottom:-200px;left:50%;transform:translateX(-50%);z-index:400;
       width:calc(100% - 28px);max-width:460px;background:#112a1a;
       border:1px solid rgba(183,228,199,.18);border-radius:18px;padding:14px 16px;
       transition:bottom .35s cubic-bezier(.32,.72,0,1)}
#toast.on{bottom:84px}
#toast-t{color:var(--wh);font-size:14px;font-weight:700;font-family:sans-serif;margin-bottom:4px}
#toast-b{color:var(--txt2);font-size:13px;font-family:sans-serif;line-height:1.6;white-space:pre-line}
#toast-cl{display:block;width:100%;background:rgba(64,145,108,.15);border:1px solid rgba(64,145,108,.25);
          border-radius:9px;padding:9px;color:var(--leaf);font-size:13px;font-family:sans-serif;cursor:pointer;margin-top:10px;text-align:center}
/* codar mode accent */
.codar-mode .bbl.bot{border-left:3px solid rgba(167,139,250,.45)!important}
.codar-mode #hdr{background:rgba(5,3,15,.92)!important}
