#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} }
Google Agenda
🔄 Atualizado
🔔0
AD
Admin
👋 Bom dia, Admin!
📈 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
📌 Próximos Agendamentos
CódigoPacienteProfissionalProcedimentoData/HoraStatusAções
📋 Todos os Agendamentos
🔍
CódigoPacienteIdadeWhatsAppProfissionalProcedimentoData/HoraStatusAções
📅 Agenda de Hoje
HoraCódigoPacienteWhatsAppProfissionalProcedimentoStatusAções
🗓️ Calendário
🟢 Consulta🎂 Aniversário
Selecione um dia
🔔 Alertas e Lembretes
⚡ Lembretes Automáticos
O sistema verifica e notifica você quando é hora de enviar. Confirme com 1 clique.
Ativo
⏰ Lembrete 24h antes
Enviar às
⏰ Lembrete 8h antes
Janela
⏰ Lembrete 4h antes
Janela
👥 Pacientes
🔍
NomeTelefoneNascimentoIdadeAniversárioConsultasAções
📋 Prontuários
🔍
Prontuário
Queixa principal
História da doença atual
Antecedentes pessoais
Antecedentes familiares
Alergias e reações adversas
Medicamentos em uso
Hábitos (tabagismo, álcool, atividade física)
Observações gerais
🎯 Dados específicos por especialidade
🥗 Nutrição — Avaliação nutricional
🧠 Psicologia — Avaliação psicológica
🦴 Fisioterapia — Avaliação funcional
🩺 Medicina — Exame físico
🌐 Agendamento Online
🔗 Link de Agendamento
Compartilhe este link com seus pacientes
Carregando...
↗️ Abrir
📱 QR Code
Imprima e cole na recepção
⚙️ Configurações da página pública
Mensagem de boas-vindas
Horário de atendimento
Antecedência mínima (horas)
Dias disponíveis para agendar
Profissionais disponíveis online
📬 Solicitações pendentes de confirmação
💰 Gestão Financeira
💳 Por Forma de Pagamento
Distribuição do mês selecionado
📊 Receita por Procedimento
Top procedimentos do mês
📋 Registros de Pagamento
PacienteProcedimentoDataValorFormaStatusAções
💳 Registrar Pagamento
Valor cobrado *
R$
Forma de pagamento *
Observação (opcional)
👨‍⚕️ Profissionais
🩺 Procedimentos
⚙️ 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
Nome da Empresa / Clínica *
Aparece no cabeçalho e nas mensagens
Slogan / Subtítulo
Ex: Cuidando de você com excelência
CNPJ / Inscrição
📍 Endereço

📱 Contato & Redes Sociais

💬 WhatsApp da Clínica
Número principal de atendimento
📞 Telefone Fixo
✉️ E-mail da Clínica
🌐 Site / Website
Instagram
Facebook
🎵 TikTok
▶️ YouTube

🛡️ 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
Nova senha mestra
Confirmar senha
🔒 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

👥 Usuários e Permissões

Gerencie quem tem acesso ao sistema e quais permissões cada perfil possui.
👑 Administrador
Acesso total ao sistema, usuários, configurações e relatórios.
📋 Recepcionista
Agendar, editar, ver pacientes, alertas e agenda.
👨‍⚕️ Médico
Ver agendamentos, agenda, pacientes e dashboard.
💰 Financeiro
Acesso ao dashboard e relatórios financeiros.
Usuários cadastrados
🔑 Senha padrão inicial: 12345678 — peça para cada usuário alterar no primeiro acesso.
📱 Login Google: após entrar com Google, o perfil é vinculado pelo e-mail cadastrado aqui.

🎨 Paleta de Cores — Ultra Premium

Escolha o tema visual do sistema. Clique para aplicar instantaneamente em tempo real.
🎨 Tema Ativo

👤 Conta do Administrador

E-mail
Nome de exibição

Google Agenda

Não conectadoConecte para sincronizar agendamentos.
Clique em Conectar, faça login com Gmail e autorize acesso ao Google Agenda.

🔔 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.
⭕ Inativo
Notificaçõ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
📁 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).

💬 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.
3
Testar agora
📋 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
📋 Novo Agendamento
---
Preencha o nascimento
Procedimento & Profissional
Data & Horário
📋 Detalhes
🎂 Mensagem de Aniversário
👨‍⚕️ Novo Profissional
🩺 Novo Procedimento
⚠️
Tem certeza?
Esta ação não pode ser desfeita.
🔐 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.
1 Cole seu Client ID do Google Cloud
Não tem um Client ID? Ver guia rápido (2 minutos) →
👤 Usuário
Nome completo *
E-mail *
Perfil de acesso *
Nova senha (deixe em branco para manter)