*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f0f;--s1:#161616;--s2:#1e1e1e;--s3:#252525;--b1:#2c2c2c;--b2:#3a3a3a;--ac:#c9a96e;--ac2:#dfc08a;--acd:rgba(201,169,110,.13);--tx:#ede9e3;--t2:#9a9690;--t3:#5c5a57;--gn:#5fa876;--gnd:rgba(95,168,118,.13);--rd:#c26868;--rdd:rgba(194,104,104,.13);--bl:#6b8fd4;--bld:rgba(107,143,212,.13);--pu:#a47fc4;--pud:rgba(164,127,196,.13);--or:#d29555;--ord:rgba(210,149,85,.13);--sw:224px}:root[data-theme=light]{--bg:#f6f4ef;--s1:#ffffff;--s2:#f0ece4;--s3:#e6e0d2;--b1:#dcd5c4;--b2:#c5bca8;--ac:#9a7d44;--ac2:#b8975a;--acd:rgba(154,125,68,.1);--tx:#2a2620;--t2:#5a554c;--t3:#8a8478;--gn:#3e8a55;--gnd:rgba(62,138,85,.12);--rd:#b13e3e;--rdd:rgba(177,62,62,.1);--bl:#3f6db7;--bld:rgba(63,109,183,.1);--pu:#7d59a8;--pud:rgba(125,89,168,.1);--or:#b5763a;--ord:rgba(181,118,58,.12)}:root[data-theme=light] .today-circle{color:#fff}:root[data-theme=light] .btn-ac{color:#fff}html,body,#root{height:100%}body{background:var(--bg);color:var(--tx);font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-size:13px;transition:background .2s ease,color .2s ease}a{color:inherit;text-decoration:none}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sw);flex-shrink:0;background:var(--s1);border-right:1px solid var(--b1);display:flex;flex-direction:column;height:100vh;transition:transform .22s ease}.logo{padding:22px 20px 18px;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:11px}.logo-mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--ac) 0%,var(--ac2) 100%);display:flex;align-items:center;justify-content:center;color:#0f0f0f;font-weight:800;font-size:13px;letter-spacing:-.02em;box-shadow:0 4px 12px -4px #c9a96e66}.logo-name{font-size:16px;font-weight:700;color:var(--tx);letter-spacing:-.015em;line-height:1}.logo-sub{font-size:9px;color:var(--t3);letter-spacing:.14em;text-transform:uppercase;margin-top:3px}.nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-sec{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--t3);padding:14px 8px 6px;font-weight:600}.nav-item{position:relative;display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:8px;cursor:pointer;color:var(--t2);border:none;background:none;width:100%;text-align:left;transition:all .14s ease;margin-bottom:1px;font-size:12.5px;font-family:inherit}.nav-item:hover{background:var(--s2);color:var(--tx)}.nav-item.active{background:var(--acd);color:var(--ac);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-10px;top:7px;bottom:7px;width:3px;background:var(--ac);border-radius:0 3px 3px 0}.sfooter{padding:14px;border-top:1px solid var(--b1)}.role-box{background:var(--s2);border:1px solid var(--b1);border-radius:10px;padding:12px}.role-lbl{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:6px}.role-sel{width:100%;background:var(--s3);border:1px solid var(--b1);border-radius:7px;color:var(--tx);padding:7px 9px;font-size:12px;font-family:inherit;outline:none}.plan-row{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:8px}.plan-badge{font-size:10px;background:var(--acd);color:var(--ac);padding:3px 8px;border-radius:5px;font-weight:500}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:56px;background:var(--s1);border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;gap:10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.content{flex:1;overflow-y:auto;padding:22px 24px}.tb-left{display:flex;align-items:center;gap:12px;min-width:0}.tb-title{font-size:15px;font-weight:600;letter-spacing:-.005em}.tb-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.tb-date{font-size:11px;color:var(--t3);font-weight:500}.av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;border:1px solid rgba(255,255,255,.06)}.hbg{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--t2)}.hbg svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}.overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:299}.overlay.open{display:block}.card{background:var(--s1);border:1px solid var(--b1);border-radius:14px;padding:18px;transition:border-color .18s,box-shadow .18s}.card:hover{border-color:var(--b2)}.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat{position:relative;background:var(--s1);border:1px solid var(--b1);border-radius:14px;padding:16px 18px;transition:transform .18s,border-color .18s,box-shadow .18s;overflow:hidden}.stat:hover{transform:translateY(-2px);border-color:var(--b2);box-shadow:0 6px 18px -10px #0000008c}.stat:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ac);opacity:.35;border-radius:3px 0 0 3px}.stat-l{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:6px;font-weight:600}.stat-v{font-size:24px;font-weight:600;line-height:1;letter-spacing:-.01em}.stat-ac{color:var(--ac)}.stat-gn{color:var(--gn)}.stat-rd{color:var(--rd)}.stat-t{display:inline-flex;align-items:center;font-size:10px;padding:2px 7px;border-radius:4px;margin-top:5px}.stat-sub{font-size:10px;color:var(--t3);margin-top:4px}.up{background:var(--gnd);color:var(--gn)}.dn{background:var(--rdd);color:var(--rd)}.eq{background:var(--s3);color:var(--t2)}.badge{display:inline-flex;align-items:center;font-size:10px;padding:3px 9px;border-radius:20px;font-weight:600;white-space:nowrap;letter-spacing:.01em}.b-gn{background:var(--gnd);color:var(--gn)}.b-bl{background:var(--bld);color:var(--bl)}.b-ac{background:var(--acd);color:var(--ac)}.b-rd{background:var(--rdd);color:var(--rd)}.b-pu{background:var(--pud);color:var(--pu)}.b-or{background:var(--ord);color:var(--or)}.b-mut{background:var(--s3);color:var(--t2)}.tbl{width:100%;border-collapse:collapse;font-size:12px}.tbl th{text-align:left;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);padding:7px 10px;border-bottom:1px solid var(--b1);font-weight:500}.tbl td{padding:10px;border-bottom:1px solid rgba(44,44,44,.5)}.tbl tr:hover td{background:#ffffff04}.tbl tr:last-child td{border-bottom:none}.tbl-wrap{overflow-x:auto}input,select,textarea{background:var(--s2);border:1px solid var(--b1);border-radius:8px;color:var(--tx);padding:8px 11px;font-size:12px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}input:hover:not(:disabled),select:hover:not(:disabled),textarea:hover:not(:disabled){border-color:var(--b2)}input:focus,select:focus,textarea:focus{border-color:var(--ac);box-shadow:0 0 0 3px #c9a96e1a}select option,optgroup{background:var(--s2)}optgroup{color:var(--ac)}input[type=checkbox]{width:15px;height:15px;accent-color:var(--ac);cursor:pointer}input[disabled],select[disabled]{opacity:.6;cursor:not-allowed}.lbl{font-size:10px;color:var(--t3);margin-bottom:4px;display:block;letter-spacing:.04em}.field{display:flex;flex-direction:column;gap:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:8px 15px;border-radius:8px;font-size:12px;font-family:inherit;font-weight:500;cursor:pointer;border:none;transition:all .15s ease;text-decoration:none;letter-spacing:.005em}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-ac{background:linear-gradient(135deg,var(--ac) 0%,var(--ac2) 100%);color:#0f0f0f;box-shadow:0 1px #ffffff1f inset,0 4px 12px -6px #c9a96e66}.btn-ac:hover:not(:disabled){box-shadow:0 1px #ffffff2e inset,0 6px 16px -6px #c9a96e80;transform:translateY(-1px)}.btn-gh{background:transparent;border:1px solid var(--b2);color:var(--t2)}.btn-gh:hover:not(:disabled){color:var(--tx);border-color:var(--ac);background:#c9a96e0d}.btn-gn{background:var(--gnd);color:var(--gn);border:1px solid rgba(95,168,118,.25)}.btn-gn:hover:not(:disabled){background:#5fa8762e;border-color:#5fa87666}.btn-rd{background:var(--rdd);color:var(--rd);border:1px solid rgba(194,104,104,.25)}.btn-rd:hover:not(:disabled){background:#c268682e;border-color:#c2686866}.btn-bl{background:var(--bld);color:var(--bl);border:1px solid rgba(107,143,212,.25)}.btn-bl:hover:not(:disabled){background:#6b8fd42e;border-color:#6b8fd466}.btn-lg{padding:11px 20px;font-size:13px;border-radius:10px}.btn-sm{padding:5px 11px;font-size:11px}.btn-xs{padding:3px 9px;font-size:10px;border-radius:6px;font-weight:600}.sh{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;flex-wrap:wrap;gap:8px}.sh-t{font-size:20px;font-weight:700;letter-spacing:-.015em}.sh-s{font-size:11.5px;color:var(--t3);margin-top:4px;line-height:1.4}.sh-a{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:7px}.bar-n{width:130px;color:var(--t2);flex-shrink:0;font-size:11px;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-tr{flex:1;height:6px;background:var(--s3);border-radius:3px;overflow:hidden;position:relative}.bar-fi{height:100%;border-radius:3px;background:var(--ac);transition:width .3s ease}.bar-v{width:88px;color:var(--tx);font-size:11px;font-weight:500;text-align:right}.caja-sec{background:var(--s1);border:1px solid var(--b1);border-radius:12px;margin-bottom:12px;overflow:hidden}.caja-hdr{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--b1);background:var(--s2)}.caja-wrap{overflow-x:auto}.ctbl{width:100%;border-collapse:collapse;font-size:12px;min-width:660px}.ctbl th{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);padding:8px 7px;border-bottom:1px solid var(--b1);font-weight:500;text-align:left;white-space:nowrap}.ctbl td{padding:5px 6px;border-bottom:1px solid rgba(44,44,44,.4);vertical-align:middle}.ctbl tr:last-child td{border-bottom:none}.ctbl input,.ctbl select{padding:6px 8px;font-size:11px;min-width:0}.ctbl select{min-width:145px}.caja-ftr{background:var(--s2);border-top:1px solid var(--b1);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.caja-tot-g{display:flex;gap:14px;flex-wrap:wrap}.ctot-l{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3)}.ctot-v{font-size:15px;font-weight:600;color:var(--ac)}.ts-txt{font-size:9px;color:var(--t3);font-style:italic;margin-top:2px}.tip{font-size:10px;color:var(--t3);background:var(--s2);border:1px solid var(--b1);border-radius:7px;padding:8px 10px;margin-bottom:12px;line-height:1.6}.tot-box{background:#c9a96e12;border:1px solid rgba(201,169,110,.18);border-radius:9px;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;margin-top:12px;flex-wrap:wrap;gap:8px}.pay-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(44,44,44,.4)}.pay-row:last-child{border-bottom:none}.pay-time{font-size:11px;font-weight:700;color:var(--ac);width:48px;flex-shrink:0}.pay-info{flex:1;min-width:0}.pay-client{font-size:12px;font-weight:500}.pay-detail{font-size:10px;color:var(--t3);margin-top:1px}.pay-amt{font-size:13px;font-weight:600;color:var(--gn);flex-shrink:0}.search-wrap{position:relative;margin-bottom:14px}.search-wrap input{padding-left:34px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--t3);font-size:14px;pointer-events:none}.client-card{background:var(--s2);border:1px solid var(--b1);border-radius:10px;margin-bottom:8px;overflow:hidden;cursor:pointer;transition:border-color .15s}.client-card:hover{border-color:var(--b2)}.client-card.open{border-color:#c9a96e4d}.client-header{display:flex;align-items:center;gap:12px;padding:13px 16px}.client-body{padding:0 16px 14px}.visit-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(44,44,44,.35);font-size:12px}.visit-row:last-child{border-bottom:none}.visit-date{font-weight:600;color:var(--ac);width:70px;flex-shrink:0;font-size:11px}.visit-info{flex:1;min-width:0}.visit-svc{font-weight:500}.visit-emp{font-size:10px;color:var(--t3);margin-top:1px}.cal-page{display:flex;gap:0;height:100%}.cal-filter{width:200px;flex-shrink:0;padding-right:16px;border-right:1px solid var(--b1)}.cfs-title{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--t3);padding:4px 0 10px;font-weight:500}.cfs-all{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:8px;cursor:pointer;margin-bottom:4px;border:none;background:none;width:100%;font-family:inherit}.cfs-all:hover{background:var(--s2)}.cfs-all-dot{width:14px;height:14px;border-radius:4px;background:linear-gradient(135deg,#c9a96e,#5fa876,#6b8fd4);flex-shrink:0}.cfs-all-label{font-size:12px;color:var(--tx);font-weight:500}.cfs-divider{height:1px;background:var(--b1);margin:8px 0}.cfs-subtitle{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);padding:4px 8px 6px;font-weight:500}.cfs-item{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.cfs-item:hover{background:var(--s2)}.cfs-checkbox{width:15px;height:15px;border-radius:4px;border:2px solid;flex-shrink:0;display:flex;align-items:center;justify-content:center}.cfs-checkbox.checked:after{content:"✓";font-size:9px;font-weight:700;color:#0f0f0f}.cfs-name{font-size:12px;color:var(--t2)}.cfs-item.checked .cfs-name{color:var(--tx)}.cal-main-area{flex:1;padding-left:16px;min-width:0;display:flex;flex-direction:column}.cal-nav{display:flex;align-items:center;gap:8px;margin-bottom:12px}.cal-month-lbl{font-size:16px;font-weight:600;min-width:160px}.cal-dn{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:2px}.cal-dn span{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--t3);text-align:center;padding:5px 2px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--b1);border:1px solid var(--b1);border-radius:10px;overflow:hidden;flex:1}.cal-cell{background:var(--s2);padding:5px 6px;min-height:90px;cursor:pointer;transition:background .1s}.cal-cell:hover{background:var(--s3)}.cal-cell.today{background:#c9a96e12}.cal-cell.sel{background:#c9a96e24!important;outline:1px solid rgba(201,169,110,.4);outline-offset:-1px}.cal-cell.other{background:#161616b3}.cal-num{font-size:11px;color:var(--t2);text-align:right;margin-bottom:3px}.cal-num.other{color:var(--t3)}.today-circle{background:var(--ac);color:#0f0f0f;width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;float:right}.cal-pill{font-size:10px;padding:3px 6px;border-radius:5px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.45;font-weight:500;transition:transform .12s}.cal-pill:hover{transform:translate(1px)}.cal-more{font-size:9px;color:var(--t3);padding:1px 3px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;animation:fade .18s ease}.modal-box{background:var(--s1);border:1px solid var(--b1);border-radius:16px;width:440px;max-width:100%;max-height:88vh;overflow-y:auto;display:flex;flex-direction:column;animation:pop .2s cubic-bezier(.2,.9,.3,1.2);box-shadow:0 24px 60px -20px #000000b3}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 0}.modal-title{font-size:15px;font-weight:700;color:var(--ac);letter-spacing:-.01em}.modal-close{background:none;border:none;color:var(--t3);cursor:pointer;font-size:22px;padding:0 4px;line-height:1;border-radius:6px;transition:all .15s}.modal-close:hover{color:var(--tx);background:var(--s2)}.modal-body{padding:14px 18px 18px;flex:1}.modal-empty{font-size:11px;color:var(--t3);text-align:center;padding:24px 0}.modal-item{padding:12px 14px;background:var(--s2);border-radius:10px;margin-bottom:8px;border-left:3px solid;position:relative;transition:transform .15s,box-shadow .15s}.modal-item:hover{transform:translate(2px);box-shadow:0 4px 12px -8px #00000080}.modal-time{font-size:12px;font-weight:700}.modal-client{font-size:13px;font-weight:500;margin-top:2px}.modal-svc{font-size:11px;color:var(--t3);margin-top:1px}.modal-emp{font-size:11px;font-weight:500;margin-top:2px}.modal-reg{font-size:9px;color:var(--t3);font-style:italic;margin-top:3px}.modal-st{position:absolute;top:10px;right:10px}.sched-form{display:flex;flex-direction:column;gap:9px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at 20% 15%,rgba(201,169,110,.1) 0%,transparent 45%),radial-gradient(circle at 80% 80%,rgba(95,168,118,.06) 0%,transparent 50%),var(--bg)}.login-shell{width:100%;max-width:980px;display:grid;grid-template-columns:1.05fr 1fr;gap:24px;align-items:stretch}.login-pitch{background:linear-gradient(160deg,var(--s1) 0%,var(--s2) 100%);border:1px solid var(--b1);border-radius:18px;padding:32px 30px;display:flex;flex-direction:column;gap:22px;position:relative;overflow:hidden}.login-pitch:after{content:"";position:absolute;top:-40%;right:-30%;width:60%;height:60%;background:radial-gradient(circle,rgba(201,169,110,.1),transparent 60%);pointer-events:none}.login-brand{display:flex;align-items:center;gap:12px;position:relative;z-index:1}.login-brand-mark{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--ac) 0%,var(--ac2) 100%);display:flex;align-items:center;justify-content:center;color:#0f0f0f;font-weight:800;font-size:15px;letter-spacing:-.02em;box-shadow:0 6px 18px -6px #c9a96e80}.login-brand-name{font-size:17px;font-weight:700;color:var(--tx);letter-spacing:-.015em;line-height:1}.login-brand-sub{font-size:10px;color:var(--t3);letter-spacing:.1em;text-transform:uppercase;margin-top:3px}.login-headline{font-size:24px;font-weight:600;line-height:1.25;color:var(--tx);letter-spacing:-.015em;position:relative;z-index:1}.login-headline-ac{color:var(--ac);font-weight:700}.login-features{display:flex;flex-direction:column;gap:14px;margin-top:4px;position:relative;z-index:1}.login-feature{display:flex;gap:12px;align-items:flex-start}.login-feature-i{width:32px;height:32px;border-radius:9px;background:var(--s3);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;border:1px solid var(--b1)}.login-feature-t{font-size:13px;font-weight:600;color:var(--tx);line-height:1.2}.login-feature-d{font-size:11px;color:var(--t2);margin-top:2px;line-height:1.4}.login-trust{margin-top:auto;font-size:10px;color:var(--t3);letter-spacing:.06em;text-transform:uppercase;position:relative;z-index:1}.login-card{width:100%;max-width:420px;background:var(--s1);border:1px solid var(--b1);border-radius:18px;padding:32px;margin:0 auto;box-shadow:0 24px 48px -24px #0000008c}.login-logo{text-align:center;margin-bottom:22px}.login-logo .logo-name{font-size:20px;color:var(--ac)}.login-logo .logo-sub{margin-top:5px}.login-form{display:flex;flex-direction:column;gap:13px}.login-tabs{display:flex;gap:4px;background:var(--s2);border:1px solid var(--b1);padding:3px;border-radius:10px;margin-bottom:18px}.login-tab{flex:1;padding:8px;border:none;background:none;color:var(--t2);font-size:12px;border-radius:7px;cursor:pointer;font-family:inherit;font-weight:500;transition:all .15s}.login-tab:hover{color:var(--tx)}.login-tab.active{background:var(--acd);color:var(--ac);font-weight:600}.login-err{background:var(--rdd);color:var(--rd);font-size:11px;padding:9px 13px;border-radius:8px;border:1px solid rgba(194,104,104,.25);animation:shake .35s}.login-foot{text-align:center;font-size:11px;color:var(--t3);margin-top:4px}.link{background:none;border:none;color:var(--ac);font-size:11px;cursor:pointer;font-family:inherit;font-weight:600;text-decoration:underline;padding:0}.link:hover{color:var(--ac2)}.spin{display:inline-block;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}@media (max-width:780px){.login-shell{grid-template-columns:1fr;max-width:440px}.login-pitch{display:none}}.ficha-card{background:var(--s2);border:1px solid var(--b1);border-radius:10px;padding:14px;margin-bottom:8px}.empty{text-align:center;padding:44px 24px;color:var(--t3);font-size:12.5px;line-height:1.6;background:var(--s1);border:1px dashed var(--b1);border-radius:14px}.legend{display:flex;flex-direction:column;gap:6px;margin-top:8px}.legend-row{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--t2)}.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.legend-val{margin-left:auto;color:var(--tx);font-weight:500}.heat-row{display:flex;align-items:center;gap:6px;margin-bottom:4px}.heat-lbl{width:36px;font-size:11px;color:var(--t2);text-align:right}.heat-cells{display:grid;grid-template-columns:repeat(24,1fr);gap:2px;flex:1}.heat-cell{height:14px;border-radius:2px;background:var(--s3);transition:background .15s}@media (max-width:900px){.g4,.g3{grid-template-columns:1fr 1fr}.cal-filter{width:170px}}@media (max-width:700px){.sidebar{position:fixed;left:0;top:0;z-index:300;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px #00000080}.hbg{display:flex}.g2,.g3{grid-template-columns:1fr}.g4{grid-template-columns:1fr 1fr}.cal-page{flex-direction:column}.cal-filter{width:100%;border-right:none;border-bottom:1px solid var(--b1);padding-right:0;padding-bottom:12px;margin-bottom:12px}.cfs-item,.cfs-all{display:inline-flex;width:auto;margin-right:6px}.cal-main-area{padding-left:0}.cal-cell{min-height:56px}.content{padding:14px}}@media (max-width:420px){.g4{grid-template-columns:1fr}.cal-cell{min-height:44px;padding:3px}.cal-pill{display:none}}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes fd{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page{animation:fd .18s ease}.emp-acc{background:var(--s2);border:1px solid var(--b1);border-radius:10px;margin-bottom:8px;overflow:hidden;transition:border-color .15s}.emp-acc:hover{border-color:var(--b2)}.emp-acc.open{border-color:#c9a96e59}.emp-acc-hdr{display:flex;align-items:center;gap:12px;padding:11px 14px;background:none;border:none;width:100%;cursor:pointer;color:var(--tx);font-family:inherit;text-align:left}.emp-acc-hdr:hover{background:#ffffff05}.emp-acc-body{padding:0 14px 12px 56px;border-top:1px solid var(--b1);background:#0000000f}:root[data-theme=light] .emp-acc-body{background:#00000005}.caja-hist-tgl{display:flex;align-items:center;gap:10px;width:100%;padding:9px 16px;background:var(--gnd);border:none;border-bottom:1px solid var(--b1);font-size:11px;color:var(--t2);font-family:inherit;cursor:pointer;transition:background .12s}.caja-hist-tgl:hover{background:#5fa8761a}.caja-hist{background:#0000001a;border-bottom:1px solid var(--b1);padding:4px 16px}:root[data-theme=light] .caja-hist{background:#00000005}.caja-hist-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid rgba(128,128,128,.1)}.caja-hist-row:last-child{border-bottom:none}.tabs{display:flex;gap:4px;background:var(--s2);border:1px solid var(--b1);padding:3px;border-radius:9px;margin-bottom:14px}.tab{flex:0 1 auto;padding:7px 16px;border:none;background:none;color:var(--t2);font-size:12px;border-radius:6px;cursor:pointer;font-family:inherit;font-weight:500;transition:all .12s}.tab:hover{color:var(--tx)}.tab.active{background:var(--acd);color:var(--ac)}.visit-card{background:var(--s3);border:1px solid var(--b1);border-radius:8px;padding:11px 13px;margin-bottom:8px}.visit-card-hdr{display:flex;justify-content:space-between;align-items:center;gap:8px}.visit-card .visit-date{color:var(--ac)}.visit-meta{color:var(--t2);margin-top:6px;font-size:11px}.visit-notes{background:var(--s2);border:1px solid var(--b1);border-left:3px solid var(--t3);border-radius:6px;padding:7px 10px;margin-top:8px}.visit-notes-lbl{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--t3);margin-bottom:3px;font-weight:500}.visit-notes-txt{font-size:11.5px;color:var(--tx);line-height:1.45;white-space:pre-wrap}.theme-tgl{background:var(--s2);border:1px solid var(--b1);color:var(--t2);width:34px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .15s}.theme-tgl:hover{color:var(--ac);border-color:var(--ac)}
