#app{display:none;flex-direction:column;min-height:100vh}
header{background:var(--card);border-bottom:1px solid var(--border);padding:0 24px;height:62px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.hlogo{font-size:1.35rem;font-weight:800}
.hlogo span{color:var(--accent)}
.hright{display:flex;align-items:center;gap:10px}
.nbtn{position:relative;background:var(--bg3);border:1px solid var(--border);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem}
.nbtn:hover{border-color:var(--accent)}
.nbadge{position:absolute;top:-3px;right:-3px;background:var(--red);color:#fff;border-radius:50%;width:15px;height:15px;font-size:.58rem;font-weight:800;display:flex;align-items:center;justify-content:center}
.upill{display:flex;align-items:center;gap:7px;background:var(--bg3);border-radius:100px;padding:5px 12px 5px 7px;font-size:.82rem;font-weight:600;cursor:pointer;border:1px solid var(--border)}
.uav{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:800}
/* LAYOUT */
.mlayout{display:flex;flex:1}
nav{width:215px;background:var(--card);border-right:1px solid var(--border);padding:18px 10px;display:flex;flex-direction:column;gap:3px;flex-shrink:0}
.ni{display:flex;align-items:center;gap:9px;padding:9px 13px;border-radius:10px;cursor:pointer;font-size:.88rem;font-weight:500;color:var(--text2);transition:all .2s;user-select:none}
.ni:hover{background:var(--bg3);color:var(--text)}
.ni.on{color:var(--accent);background:rgba(59,130,246,.12)}
.nico{font-size:1.05rem;width:20px;text-align:center;flex-shrink:0}
.nsep{height:1px;background:var(--border);margin:7px 4px}
.nlbl{font-size:.68rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:7px 13px 2px}
.cont{flex:1;overflow-y:auto;padding:26px;min-width:0}
/* STATS */
.sgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:13px;margin-bottom:24px}
.sc{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;position:relative;overflow:hidden}
.sc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.sc.bl::before{background:var(--accent)}.sc.gr::before{background:var(--green)}
.sc.ye::before{background:var(--yellow)}.sc.pu::before{background:var(--purple)}
.sc.pk::before{background:var(--pink)}.sc.te::before{background:var(--teal)}.sc.rd::before{background:var(--red)}
.slbl{font-size:.72rem;color:var(--text2);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}
.sval{font-size:1.9rem;font-weight:800}
.sc.bl .sval{color:var(--accent)}.sc.gr .sval{color:var(--green)}
.sc.ye .sval{color:var(--yellow)}.sc.pu .sval{color:var(--purple)}
.sc.pk .sval{color:var(--pink)}.sc.te .sval{color:var(--teal)}.sc.rd .sval{color:var(--red)}
.sico{font-size:1.8rem;position:absolute;right:13px;top:13px;opacity:.13}
/* SECTION HEADER */
.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.st{font-size:1.08rem;font-weight:800}
.bnn{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:9px;padding:8px 16px;font-size:.83rem;font-weight:700;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:5px;transition:opacity .2s;text-decoration:none;white-space:nowrap}
.bnn:hover{opacity:.88}
/* FILTER */
.fbar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.fb{padding:5px 13px;border-radius:100px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}
.fb:hover,.fb.fa{background:var(--accent);border-color:var(--accent);color:#fff}
.fb.fg{background:var(--green);border-color:var(--green);color:#fff}
.fb.fy{background:var(--yellow);border-color:var(--yellow);color:#000}
.fb.fp{background:var(--purple);border-color:var(--purple);color:#fff}
.fb.fr{background:var(--red);border-color:var(--red);color:#fff}
.fb.fbk{background:var(--pink);border-color:var(--pink);color:#fff}
/* TABLE */
.tw{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:540px}
th{font-size:.7rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:10px 13px;background:var(--bg3);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:10px 13px;font-size:.84rem;border-bottom:1px solid rgba(42,51,71,.4);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(59,130,246,.04)}
tr.bdr td{background:rgba(236,72,153,.05)}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:100px;font-size:.71rem;font-weight:700;white-space:nowrap}
.bag{background:rgba(59,130,246,.18);color:#93c5fd}
.bok{background:rgba(34,197,94,.18);color:#86efac}
.brt{background:rgba(168,85,247,.18);color:#d8b4fe}
.bhj{background:rgba(245,158,11,.18);color:#fcd34d}
.bca{background:rgba(239,68,68,.18);color:#fca5a5}
.bbk{background:rgba(236,72,153,.2);color:#f9a8d4}
.chip{font-family:monospace;font-size:.76rem;background:var(--bg3);color:var(--teal);padding:2px 7px;border-radius:5px;white-space:nowrap}
.ar{display:flex;gap:4px;align-items:center}
.ab{background:var(--bg3);border:1px solid var(--border);border-radius:6px;width:27px;height:27px;cursor:pointer;font-size:.8rem;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;text-decoration:none;flex-shrink:0}
.ab:hover{border-color:var(--accent);background:rgba(59,130,246,.15)}
.ab.wa:hover{border-color:var(--wa);background:rgba(37,211,102,.15)}
.ab.dl:hover{border-color:var(--red);background:rgba(239,68,68,.15)}
.ab.vw:hover{border-color:var(--teal);background:rgba(20,184,166,.15)}
.ab.bk:hover{border-color:var(--pink);background:rgba(236,72,153,.15)}
/* MODAL */
.mo{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:300;display:none;align-items:center;justify-content:center;backdrop-filter:blur(5px);padding:14px}
.mo.op{display:flex}
.md{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:28px;width:660px;max-width:100%;max-height:92vh;overflow-y:auto;box-shadow:0 4px 40px rgba(0,0,0,.5)}
.mdsm{width:460px}
.mh{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.mt{font-size:1.1rem;font-weight:800}
.mcl{background:var(--bg3);border:1px solid var(--border);border-radius:7px;width:30px;height:30px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:all .2s}
.mcl:hover{border-color:var(--red);color:var(--red)}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.fg2 .fw{grid-column:1/-1}
.ig{display:flex;flex-direction:column;gap:5px}
.ig label{font-size:.73rem;color:var(--text2);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.ig input,.ig select,.ig textarea{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:9px 12px;color:var(--text);font-family:inherit;font-size:.86rem;outline:none;transition:border-color .2s}
.ig input:focus,.ig select:focus,.ig textarea:focus{border-color:var(--accent)}
.ig select option{background:var(--bg3)}
.ig textarea{resize:vertical;min-height:65px}
.opt{font-size:.65rem;color:var(--text3);margin-left:3px;font-weight:400;text-transform:none;letter-spacing:0}
.cdsp{background:var(--bg);border:1px solid var(--teal);border-radius:9px;padding:9px 12px;font-family:monospace;font-size:.92rem;color:var(--teal);letter-spacing:.08em;font-weight:700}
.mf{display:flex;gap:9px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}
.bsc{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:9px 16px;color:var(--text2);font-family:inherit;font-size:.86rem;font-weight:600;cursor:pointer;transition:all .2s}
.bsc:hover{border-color:var(--red);color:var(--red)}
.fdv{grid-column:1/-1;display:flex;align-items:center;gap:9px;color:var(--text3);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin:2px 0}
.fdv::before,.fdv::after{content:'';flex:1;height:1px;background:var(--border)}
/* DETAIL */
.dgrid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:18px}
.dgrid .dfw{grid-column:1/-1}
.di{background:var(--bg3);border-radius:9px;padding:11px 14px}
.dlbl{font-size:.7rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.dval{font-size:.88rem;font-weight:600}
.dval.co{font-family:monospace;color:var(--teal)}
.sbar{display:flex;align-items:center;gap:9px;background:var(--bg3);border-radius:11px;padding:13px 16px;margin-bottom:18px;flex-wrap:wrap}
.pbdg{display:inline-flex;align-items:center;gap:5px;background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.3);border-radius:9px;padding:7px 12px;font-size:.86rem;font-weight:700;color:#93c5fd}
.dacts{display:flex;gap:9px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
/* BIRTHDAY */
.bkc{background:linear-gradient(135deg,rgba(236,72,153,.15),rgba(168,85,247,.15));border:1px solid rgba(236,72,153,.3);border-radius:14px;padding:22px;text-align:center;margin-bottom:18px}
.bkemi{font-size:3.2rem;margin-bottom:7px}
.bknam{font-size:1.3rem;font-weight:800;margin-bottom:3px}
.bkage{font-size:.96rem;color:var(--pink);font-weight:700}
.bktabs{display:flex;gap:7px;margin-bottom:11px;flex-wrap:wrap}
.bktab{padding:5px 12px;border-radius:7px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}
.bktab.on{background:var(--pink);border-color:var(--pink);color:#fff}
.bkmb{background:var(--bg3);border:1px solid var(--border);border-radius:11px;padding:14px;margin-bottom:12px}
.bkml{font-size:.7rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px}
.bkmt{font-size:.87rem;line-height:1.6;white-space:pre-wrap}
/* DOC CARDS */
.dgrd{display:grid;grid-template-columns:repeat(auto-fill,minmax(275px,1fr));gap:13px}
.dcard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:17px;display:flex;flex-direction:column;gap:8px}
.dcard:hover{border-color:rgba(59,130,246,.4)}
.dctp{display:flex;gap:11px;align-items:flex-start}
.dcav{width:44px;height:44px;border-radius:11px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.dcn{font-weight:700;font-size:.92rem;line-height:1.3}
.dce{font-size:.74rem;color:var(--accent);font-weight:600;margin-top:2px}
.dcr{font-size:.77rem;color:var(--text2);display:flex;align-items:center;gap:5px}
.dcpa{display:flex;flex-wrap:wrap;gap:4px}
.dcac{display:flex;gap:7px;flex-wrap:wrap;margin-top:2px}
/* PROC CARDS */
.pgrd{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:13px}
.pcard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:17px}
.pcard:hover{border-color:rgba(59,130,246,.4)}
.pico{font-size:2rem;margin-bottom:7px}
.pnm{font-weight:700;font-size:.93rem}
.pds{font-size:.77rem;color:var(--text2);margin-top:3px}
.pdr{font-size:.72rem;color:var(--text3);margin-top:4px}
/* PROC CHECKS */
.pcks{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.pck{display:inline-flex;align-items:center;gap:5px;cursor:pointer;background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:4px 9px;font-size:.78rem;font-weight:600;transition:all .2s;user-select:none}
.pck.on{border-color:var(--accent);background:rgba(59,130,246,.1);color:var(--accent)}
.pck input{display:none}
/* CALENDAR */
.calgrd{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.mcal{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:17px}
.chead{display:flex;justify-content:space-between;align-items:center;margin-bottom:13px}
.cnb{background:var(--bg3);border:1px solid var(--border);border-radius:7px;width:27px;height:27px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.88rem}
.cnb:hover{border-color:var(--accent)}
.cml{font-weight:700;font-size:.94rem}
.cwk{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;margin-bottom:3px}
.cwl{text-align:center;font-size:.66rem;color:var(--text3);font-weight:700;padding:3px 0}
.cdays{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}
.cd{text-align:center;padding:5px 2px;font-size:.78rem;border-radius:6px;cursor:pointer;color:var(--text2);transition:all .2s;position:relative}
.cd:hover{background:var(--bg3);color:var(--text)}
.cd.tod{background:var(--accent);color:#fff;font-weight:700}
.cd.hap::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:3px;height:3px;border-radius:50%;background:var(--green)}
.cd.hbk{border:1px solid rgba(236,72,153,.4);color:var(--pink)}
.cd.om{color:var(--text3);opacity:.3}
.dsched{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:17px;overflow-y:auto;max-height:430px}
.tsl{display:flex;gap:11px;padding:8px 0;border-bottom:1px solid rgba(42,51,71,.35);align-items:flex-start}
.tsl:last-child{border-bottom:none}
.tst{font-size:.74rem;font-weight:700;color:var(--text3);min-width:44px;padding-top:2px}
.tsc{flex:1;background:var(--bg3);border-radius:8px;padding:8px 11px;border-left:3px solid var(--accent);cursor:pointer}
.tsc:hover{border-left-width:4px}
.tsc.gn{border-color:var(--green)}.tsc.pu{border-color:var(--purple)}.tsc.bk{border-color:var(--pink)}.tsc.gc{border-color:#4285F4}
.tsn{font-weight:700;font-size:.86rem}
.tsi{font-size:.74rem;color:var(--text2);margin-top:2px}
/* ALERTS */
.alist{display:flex;flex-direction:column;gap:9px}
.ai{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:13px 17px;display:flex;align-items:center;gap:13px}
.aico{font-size:1.4rem;flex-shrink:0}
.abdy{flex:1;min-width:0}
.anm{font-weight:700;font-size:.9rem}
.asb{font-size:.78rem;color:var(--text2);margin-top:2px}
.art{display:flex;align-items:center;gap:7px;flex-shrink:0;flex-wrap:wrap}
.atm{font-size:.74rem;color:var(--text3)}
.ai.urg{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.04)}
.ai.bk{border-color:rgba(236,72,153,.4);background:rgba(236,72,153,.04)}
/* SEARCH */
.swp{position:relative;margin-bottom:14px}
.swp input{width:100%;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 14px 10px 38px;color:var(--text);font-family:inherit;font-size:.86rem;outline:none;transition:border-color .2s}
.swp input:focus{border-color:var(--accent)}
.sic{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}
/* PAGES */
.pg{display:none}.pg.on{display:block}
/* SETTINGS */
.scd{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:16px}
.scd h3{font-size:.93rem;font-weight:800;margin-bottom:14px;display:flex;align-items:center;gap:7px}
.srw{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(42,51,71,.3);gap:10px}
.srw:last-child{border-bottom:none}
.slb{font-size:.86rem;font-weight:500}
.ssb{font-size:.74rem;color:var(--text3);margin-top:2px}
.tgl{width:38px;height:21px;background:var(--bg3);border-radius:100px;cursor:pointer;position:relative;border:1px solid var(--border);transition:all .2s;flex-shrink:0}
.tgl.on{background:var(--accent);border-color:var(--accent)}
.tgl::after{content:'';position:absolute;width:13px;height:13px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s}
.tgl.on::after{transform:translateX(17px)}
.sin{background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:6px 11px;color:var(--text);font-family:inherit;font-size:.84rem;outline:none;transition:border-color .2s}
.sin:focus{border-color:var(--accent)}
/* WA */
.wapv{display:inline-flex;align-items:center;gap:6px;background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.3);border-radius:7px;padding:5px 11px;font-size:.78rem;font-weight:700;color:var(--wa);text-decoration:none;margin-top:5px}
.wapv:hover{background:rgba(37,211,102,.2)}
/* GCAL */
.gcbox{background:var(--bg3);border:1px solid var(--border);border-radius:11px;padding:16px;margin-top:4px}
.gcst{display:flex;align-items:center;gap:9px;margin-bottom:11px}
.gcdot{width:9px;height:9px;border-radius:50%;background:var(--text3);flex-shrink:0}
.gcdot.on{background:var(--green)}
.gcin{font-size:.8rem;color:var(--text2)}
.gcin strong{color:var(--text);display:block;font-size:.86rem}
.gcbtn{display:inline-flex;align-items:center;gap:7px;background:#fff;color:#3c4043;border:1px solid #dadce0;border-radius:7px;padding:7px 14px;font-size:.83rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}
.gcbtn:hover{background:#f8f9fa;box-shadow:0 2px 6px rgba(0,0,0,.2)}
.gcbtn.dis{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:var(--red)}
.gcevs{margin-top:10px;display:flex;flex-direction:column;gap:5px;max-height:180px;overflow-y:auto}
.gcev{background:var(--card);border-left:3px solid #4285F4;border-radius:7px;padding:7px 11px;font-size:.78rem}
.gcev .et{font-weight:700;color:var(--text)}
.gcev .ed{color:var(--text2);margin-top:1px}
.gcnote{font-size:.73rem;color:var(--text3);margin-top:7px;padding:7px 11px;background:rgba(66,133,244,.08);border-radius:7px;border:1px solid rgba(66,133,244,.15)}
/* WA CONFIG */
.wabox{background:var(--bg3);border:1px solid rgba(37,211,102,.25);border-radius:11px;padding:16px;margin-top:4px}
.strow{display:flex;gap:10px;align-items:flex-start;margin-bottom:12px}
.stnum{width:24px;height:24px;border-radius:50%;background:var(--wa);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;flex-shrink:0}
.sttl{font-size:.84rem;font-weight:700}
.stds{font-size:.76rem;color:var(--text2);margin-top:2px;line-height:1.5}
.watr{display:flex;gap:7px;margin-top:7px;align-items:center}
.watr input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:7px 11px;color:var(--text);font-family:inherit;font-size:.84rem;outline:none}
.watr input:focus{border-color:var(--wa)}
/* CONFIRM */
.cfbox{text-align:center;padding:6px 0}
.cfic{font-size:2.8rem;margin-bottom:10px}
.cfmg{font-size:.96rem;font-weight:700;margin-bottom:5px}
.cfsb{font-size:.83rem;color:var(--text2);margin-bottom:18px;line-height:1.5}
.cfac{display:flex;gap:9px;justify-content:center;flex-wrap:wrap}
.bdng{background:var(--red);color:#fff;border:none;border-radius:9px;padding:9px 20px;font-size:.88rem;font-weight:700;cursor:pointer;font-family:inherit}
.bdng:hover{opacity:.85}
/* BSMS */
.bsm{padding:5px 10px;border-radius:7px;font-size:.76rem;font-weight:700;cursor:pointer;font-family:inherit;border:1px solid var(--border);background:var(--bg3);color:var(--text2);transition:all .2s;display:inline-flex;align-items:center;gap:4px;text-decoration:none;white-space:nowrap}
.bsm:hover{border-color:var(--accent);color:var(--text)}
.bsm.dl:hover{border-color:var(--red);color:var(--red)}
.bsm.wa{border-color:rgba(37,211,102,.35);color:var(--wa)}.bsm.wa:hover{background:rgba(37,211,102,.1)}
.bsm.gc{border-color:rgba(66,133,244,.35);color:#4285F4}.bsm.gc:hover{background:rgba(66,133,244,.1)}
.bsm.bk{border-color:rgba(236,72,153,.35);color:var(--pink)}.bsm.bk:hover{background:rgba(236,72,153,.1)}
/* BDAY BNR */
.bkbnr{background:linear-gradient(135deg,rgba(236,72,153,.13),rgba(168,85,247,.1));border:1px solid rgba(236,72,153,.3);border-radius:13px;padding:14px 18px;margin-bottom:18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
/* EMPTY */
.empty{text-align:center;padding:42px 20px;color:var(--text3)}
.empty .ei{font-size:2.8rem;margin-bottom:10px}
.empty p{font-size:.86rem}
/* SUGGEST */
.sug{background:var(--bg3);border:1px solid var(--border);border-radius:8px;margin-top:3px;overflow:hidden;max-height:140px;overflow-y:auto}
.sug div{padding:7px 11px;cursor:pointer;font-size:.84rem;border-bottom:1px solid rgba(42,51,71,.3);transition:background .15s}
.sug div:hover{background:var(--bg)}
.sug div:last-child{border-bottom:none}
/* TOAST */
#toast{position:fixed;bottom:24px;right:24px;color:#fff;padding:11px 18px;border-radius:11px;font-weight:700;font-size:.86rem;z-index:9999;opacity:0;transform:translateY(10px);transition:all .3s;pointer-events:none;max-width:340px;box-shadow:0 4px 24px rgba(0,0,0,.4)}
#toast.sh{opacity:1;transform:translateY(0)}
#toast.ok{background:var(--green)}#toast.wn{background:var(--yellow);color:#000}
#toast.er{background:var(--red)}#toast.in{background:var(--accent)}
#toast.bk{background:linear-gradient(135deg,var(--pink),var(--purple))}
/* GCAL BADGE */
.gcbdg{display:flex;align-items:center;gap:5px;font-size:.74rem;font-weight:700;padding:4px 10px;border-radius:100px;border:1px solid var(--border);background:var(--bg3);color:var(--text3);cursor:pointer}
.gcbdg.on{border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.1);color:var(--green)}
@keyframes fi{from{opacity:0}to{opacity:1}}
@keyframes fu{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.pg.on{animation:fi .25s ease}
.lbox{animation:fu .45s ease}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}
@media(max-width:768px){
nav{width:50px}.ni span:not(.nico){display:none}.nlbl{display:none}
.sgrid{grid-template-columns:1fr 1fr}.calgrd{grid-template-columns:1fr}
.fg2{grid-template-columns:1fr}.fg2 .fw,.fdv{grid-column:1}
.dgrid{grid-template-columns:1fr}.dgrid .dfw{grid-column:1}
}
📅
Agende Fácil
Sistema inteligente de agendamento
🔐 Usuário e Senha
🔵 Google / Gmail
✅ Conectado ao Google
Sair
E-mail / Usuário
Entrar no Sistema
📅 Conectar com o Google Agenda
Entre com sua conta Google. O perfil será definido pelo administrador com base no seu e-mail.
Entrar com Google / Gmail
🏠 Dashboard
📋 Agendamentos
📅 Hoje
🗓️ Calendário
Gestão
🔔 Alertas
🌐 Link Público
👥 Pacientes
📋 Prontuários
💰 Financeiro
👨⚕️ Profissionais
🩺 Procedimentos
⚙️ Configurações
🚪 Sair
👋 Bom dia, Admin !
+ Novo Agendamento
📈 Consultas — Últimos 7 dias
Agendamentos por dia
🎯 Status dos Agendamentos
Distribuição geral
👨⚕️ Ocupação por Profissional
Total de consultas realizadas
💰 Receita Estimada — Este Mês
Baseada no valor dos procedimentos
Código Paciente Profissional Procedimento Data/Hora Status Ações
📋 Todos os Agendamentos
+ Novo Agendamento
🔍
Todos
🔵 Agendados
🟡 Hoje
🟢 Realizados
🟣 Retornos
🔴 Cancelados
🎂 Aniversários
Código Paciente Idade WhatsApp Profissional Procedimento Data/Hora Status Ações
Hora Código Paciente WhatsApp Profissional Procedimento Status Ações
‹ ›
🟢 Consulta 🎂 Aniversário
🔔 Alertas e Lembretes
💬 Enviar lembretes de amanhã
⚡ Lembretes Automáticos
O sistema verifica e notifica você quando é hora de enviar. Confirme com 1 clique.
💾 Salvar configuração
🔍 Verificar agora
📬 Lembretes pendentes de envio
📝 Anamnese
📈 Evolução
💊 Receitas
🔬 Exames
Alergias e reações adversas
Hábitos (tabagismo, álcool, atividade física)
🎯 Dados específicos por especialidade
🥗 Nutrição — Avaliação nutricional
🧠 Psicologia — Avaliação psicológica
🦴 Fisioterapia — Avaliação funcional
🩺 Medicina — Exame físico
💾 Salvar anamnese
➕ Nova evolução
Profissional
Selecione...
Subjetivo (queixa do paciente)
Objetivo (achados clínicos)
➕ Adicionar evolução
💊 Nova receita / prescrição
Orientações e observações
💾 Salvar receita
🔬 Solicitar / Registrar exame
Tipo
📋 Solicitado
✅ Resultado recebido
🖼️ Imagem/Laudo
💾 Salvar exame
🌐 Agendamento Online
👁️ Pré-visualizar página
🔗 Link de Agendamento
Compartilhe este link com seus pacientes
Carregando...
📱 QR Code
Imprima e cole na recepção
🖨️ Imprimir QR Code
⚙️ Configurações da página pública
Profissionais disponíveis online
💾 Salvar configurações
📬 Solicitações pendentes de confirmação
0
👨⚕️ Escolha o profissional
← Voltar
🩺 Escolha o procedimento
← Voltar
📅 Escolha a data e horário
Horário
Selecione a data primeiro
Continuar →
← Voltar
👤 Seus dados
✅ Confirmar agendamento
🎉
Solicitação enviada!
📅 Novo agendamento
💰 Gestão Financeira
📄 Exportar PDF
💳 Por Forma de Pagamento
Distribuição do mês selecionado
📊 Receita por Procedimento
Top procedimentos do mês
📋 Registros de Pagamento
Todos
✅ Pagos
⏳ Pendentes
🎫 Isentos
Paciente Procedimento Data Valor Forma Status Ações
Forma de pagamento *
📱 PIX
💳 Débito
💳 Crédito
💵 Dinheiro
🎫 Isento / Cortesia
Cancelar
💾 Registrar pagamento
👨⚕️ Profissionais
+ Novo Profissional
🩺 Procedimentos
+ Novo Procedimento
⚙️ Configurações do Sistema
🏢 Identidade da Empresa
🏥
Clínica Saúde Total
Sistema inteligente de agendamento
Pré-visualização
🏥
Logo da Empresa
PNG, JPG ou SVG. Recomendado 200×200px
📂 Escolher Logo
🗑️ Remover
📱 Contato & Redes Sociais
💾 Salvar Configurações
🛡️ Segurança e Log de Acesso
🔑 Senha Mestra
Uma senha de emergência que dá acesso total mesmo se o admin esquecer a senha normal. Guarde-a em local seguro.
⭕ Sem senha mestra
💾 Salvar senha mestra
🗑️ Remover
🔒 Proteção automática ativa
Após 5 tentativas de login com senha errada, o acesso é bloqueado por 5 minutos automaticamente. Todos os eventos são registrados no log abaixo.
📋 Log de Acesso
Total: 0 eventos · Alertas: 0
Todos
🔐 Login
👋 Logout
➕ Criações
✏️ Edições
🗑️ Exclusões
🛡️ Segurança
🚨 Alertas
📥 CSV
🗑️ Limpar
🎨 Paleta de Cores — Ultra Premium
Escolha o tema visual do sistema. Clique para aplicar instantaneamente em tempo real.
🎨 Tema Ativo
👤 Conta do Administrador
Salvar
Google Agenda
Não conectado Conecte para sincronizar agendamentos.
Conectar com Google
Clique em Conectar, faça login com Gmail e autorize acesso ao Google Agenda.
🔄 Sincronizar
📥 Importar
Desconectar
✅ Conectado — agendamentos sincronizados automaticamente.
🔔 Notificações Push
📱 Notificações no navegador
Receba alertas mesmo com o sistema em segundo plano. Funciona no Chrome, Edge e Firefox. No celular, adicione o site à tela inicial para receber notificações.
⚙️ Quando notificar
💾 Salvar configurações
📤 Testar agora
📱 Celular: abra o site no Chrome mobile → menu ⋮ → "Adicionar à tela inicial" → as notificações funcionarão em background.
👥 Equipe: cada dispositivo precisa ativar separadamente nas próprias configurações.
☁️ Google Drive — Banco de Dados
🔒 Seus dados na nuvem — com segurança
Todos os agendamentos, profissionais e pacientes são salvos automaticamente no seu Google Drive em tempo real. Qualquer pessoa da equipe com acesso ao sistema vê os mesmos dados atualizados.
☁️ Aguardando conexão Google
Conecte ao Google para ativar
🔄 Sync Automático em Tempo Real
⭕ Inativo
Aguardando...
✅ Detecta alterações feitas por outros dispositivos a cada 30 segundos
🔇 Atualiza silenciosamente — sem interromper o uso
💡 Badge 🔄 Atualizado aparece brevemente quando há novidades
☁️ Salvar agora
🔄 Verificar agora
↺ Reiniciar sync
📁 Arquivo: agendafacil-dados.json no seu Google Drive
👥 Todos os dispositivos com Google conectado sincronizam automaticamente
⚠️ Reconectar ao Google é necessário
Para ativar o Google Drive, o sistema precisa de uma nova permissão. Clique em Reconectar abaixo para autorizar o acesso ao Drive (além do Agenda já conectado).
🔄 Reconectar com Google (Drive + Agenda)
💬 WhatsApp — Lembretes
1
Funciona no navegador, sem instalação
Botão 💬 abre WhatsApp Web ou app com mensagem personalizada e formatada pronta para enviar.
2
Formato: (DDD) 9XXXX-XXXX
O código +55 é adicionado automaticamente.
📋 Pré-visualização da mensagem de lembrete
A mensagem usa os dados reais de cada agendamento (nome, data, hora, profissional, procedimento).
🔔 Notificações
Alerta 24h antes
Aparece nos alertas com link WhatsApp
🎂 Alertas de aniversário
Notifica no dia do aniversário
Sync Google Agenda
Lembretes automáticos nos eventos
Cancelar
📅 Salvar + Google
💾 Salvar
🎂 Mensagem de Aniversário
✕
⚠️
Tem certeza?
Esta ação não pode ser desfeita.
Cancelar
Confirmar
🔐 Conectar ao Google Agenda
✕
📋
Como funciona a conexão
O sistema usa OAuth 2.0 do Google — o mesmo padrão seguro usado por todos os apps. Você precisa de um Client ID próprio (gratuito) para autorizar o acesso à sua agenda.
✅ Seus dados ficam 100% no seu Google — nunca passam por servidores externos.
Conectar com Google Agenda
⚠️ Erros frequentes e soluções:
← Voltar
📖 Guia Rápido — Criar Client ID
1
Acesse o Google Cloud Console
Abra:
console.cloud.google.com
Faça login com o Google que tem sua agenda. Clique em
"Criar Projeto" → dê um nome qualquer (ex:
Meu Agendamento ) → clique
Criar .
2
Ativar Google Calendar API
Menu lateral → APIs e Serviços → Biblioteca
Pesquise "Google Calendar API" → clique → Ativar .
3
Criar Tela de Consentimento OAuth
APIs e Serviços → Tela de consentimento OAuth
Tipo: Externo → Preencha apenas o Nome do app e E-mail de suporte → Salvar.
Em Escopos : adicione .../auth/calendar
Em Usuários de teste : adicione seu e-mail → Salvar.
4
Criar Credencial OAuth 2.0
APIs e Serviços → Credenciais → + Criar Credenciais → ID do cliente OAuth
Tipo:
Aplicativo Web
Em
"Origens JavaScript autorizadas" , clique
+ Adicionar URI e cole o endereço da sua página atual:
Clique
Criar → copie o
ID do cliente que aparece.
5
Cole o Client ID e conecte!
Volte aqui, cole o ID do cliente no campo e clique "Conectar com Google Agenda" . Uma janela do Google abrirá para você autorizar o acesso.
💡 Usando como arquivo local (file://)?
Se abrir o sistema pelo arquivo HTML direto do computador, adicione também http://localhost nas origens autorizadas no Google Cloud. Para melhor resultado, sirva o arquivo via servidor local ou hospede numa plataforma como GitHub Pages, Netlify ou Vercel (gratuito).
← Voltar e colar o Client ID
Fechar
Perfil de acesso *
👑 Administrador — acesso total
📋 Recepcionista — agendar e editar
👨⚕️ Médico — ver próprios pacientes
💰 Financeiro — relatórios e dashboard
Cancelar
💾 Salvar usuário