@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--brand:#2563eb;--brand-600:#1d4ed8;--brand-700:#1e40af;--brand-50:#eff6ff;--ink:#0f172a;--ink-2:#334155;--muted:#64748b;--faint:#94a3b8;--bg:#f1f5f9;--surface:#fff;--surface-2:#f8fafc;--line:#e2e8f0;--line-2:#cbd5e1;--good:#16a34a;--good-bg:#dcfce7;--warn:#d97706;--warn-bg:#fef3c7;--bad:#dc2626;--bad-bg:#fee2e2;--info:#0ea5e9;--info-bg:#e0f2fe;--sb-from:#063a33;--sb-to:#04201d;--r:12px;--r-sm:8px;--r-lg:16px;--sh-sm:0 1px 2px #0f172a0f, 0 1px 3px #0f172a14;--sh:0 1px 3px #0f172a0f, 0 8px 24px -8px #0f172a1f;--sh-lg:0 20px 48px -16px #0f172a47}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,system-ui,Segoe UI,sans-serif;font-size:14px;line-height:1.5}a{color:var(--brand-600);text-decoration:none}h1,h2,h3,h4{letter-spacing:-.01em;margin:0;font-weight:700}button{cursor:pointer;font:inherit}::selection{background:var(--brand-50)}.app{height:100vh;display:flex;overflow:hidden}.sidebar{background:linear-gradient(180deg, var(--sb-from), var(--sb-to));color:#cbd5e1;flex-direction:column;width:248px;height:100vh;display:flex;position:sticky;top:0}.brand{border-bottom:1px solid #ffffff14;align-items:center;gap:9px;height:50px;padding:10px 16px;display:flex}.brand .logo{background:linear-gradient(135deg, var(--brand), #60a5fa);color:#fff;width:28px;height:28px;box-shadow:0 6px 16px -6px var(--brand);border-radius:8px;flex:none;place-items:center;display:grid}.brand b{color:#fff;letter-spacing:-.02em;font-size:14.5px;line-height:1.1}.brand small{color:#64748b;font-size:10px;font-weight:500;display:block}.nav{flex:1;padding:12px;overflow:visible}.nav .group{color:#475569;text-transform:uppercase;letter-spacing:.08em;padding:14px 12px 6px;font-size:10.5px;font-weight:700}.nav a{color:#cbd5e1;border-radius:9px;align-items:center;gap:11px;margin:2px 0;padding:9px 12px;font-weight:500;transition:background .2s,color .2s,border-radius .2s,padding .2s,margin .2s;display:flex;position:relative}.nav a svg{opacity:.8;flex:none;width:18px;height:18px}.nav a:hover{color:#fff;background:#ffffff0f}.nav a.active{background:var(--bg);color:var(--ink);border-radius:22px 0 0 22px;margin-right:-12px;padding-right:16px;font-weight:600}.nav a.active svg{opacity:1;color:var(--brand)}.nav a.active:before,.nav a.active:after{content:"";background:0 0;border-radius:50%;width:18px;height:18px;position:absolute;right:0}.nav a.active:before{box-shadow:9px 9px 0 0 var(--bg);bottom:100%}.nav a.active:after{box-shadow:9px -9px 0 0 var(--bg);top:100%}.usermenu{position:relative}.topuser{background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;gap:9px;padding:4px 6px 4px 12px;transition:background .12s,border .12s;display:flex}.topuser:hover{background:var(--surface-2);border-color:var(--line)}.topuser .av{background:linear-gradient(135deg, var(--brand), #60a5fa);color:#fff;border-radius:50%;flex:none;place-items:center;width:32px;height:32px;font-size:12.5px;font-weight:700;display:grid}.topuser .meta{text-align:right;flex-direction:column;margin-left:auto;line-height:1.1;display:flex}.topuser .nm{color:var(--ink);font-size:13px;font-weight:600}.topuser .rl{color:var(--muted);font-size:11px}.topuser .caret{color:var(--muted)}.topuser{min-width:180px}@media (width<=640px){.topuser .meta{display:none}.topuser{min-width:0}}.popmenu{background:var(--surface);border-radius:var(--r);width:240px;box-shadow:var(--sh-lg);z-index:50;padding:8px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.popmenu .pop-head{align-items:center;gap:10px;padding:8px 8px 10px;display:flex}.popmenu .pop-head .av{background:linear-gradient(135deg, var(--brand), #60a5fa);color:#fff;border-radius:50%;place-items:center;width:38px;height:38px;font-weight:700;display:grid}.popmenu .pop-head .nm{font-size:13.5px;font-weight:700}.popmenu .pop-head .rl{color:var(--muted);font-size:11.5px}.pop-sec{color:var(--muted);padding:0 8px 6px;font-size:11px}.pop-label{text-transform:uppercase;letter-spacing:.06em;color:var(--faint);border-top:1px solid var(--line);padding:8px 8px 4px;font-size:10.5px;font-weight:700}.pop-item{text-align:left;border-radius:var(--r-sm);width:100%;color:var(--ink-2);background:0 0;border:0;align-items:center;gap:8px;padding:8px 10px;font-size:13px;display:flex}.pop-item:hover{background:var(--surface-2)}.pop-item.on{color:var(--brand);font-weight:600}.pop-item.danger{color:var(--bad)}.pop-divider{background:var(--line);height:1px;margin:6px 0}.content{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex}.topbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);z-index:20;background:#ffffffe6;justify-content:space-between;align-items:center;height:50px;padding:0 26px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px -2px #0f172a1a}.topbar h2{font-size:17px}.topbar .sub{color:var(--muted);font-size:12px}.main{flex-direction:column;flex:1;width:100%;min-height:0;padding:16px 20px;display:flex;overflow-y:auto}@media (width<=640px){.main{padding:12px}.topbar{padding:0 14px}}.appfoot{border-top:1px solid var(--line);background:var(--surface);color:var(--muted);text-align:center;margin-top:auto;padding:8px 28px;font-size:11.5px}.appfoot b{color:var(--ink-2);font-weight:600}.muted{color:var(--muted)}.faint{color:var(--faint)}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.page-head h2{font-size:22px}.page-head .sub{color:var(--muted);margin-top:2px;font-size:13px}.hero{color:#fff;border-radius:var(--r);background:linear-gradient(120deg,#0b1220 0%,#1e3a8a 60%,#2563eb 100%);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:12px 18px;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 28px -16px #2563ebb3}.hero:after{content:"";background:radial-gradient(circle,#ffffff24,#0000 70%);width:180px;height:180px;position:absolute;top:-70px;right:-40px}.hero h2{color:#fff;letter-spacing:-.02em;font-size:18px}.hero .sub{color:#cbd5e1;margin-top:1px;font-size:12px}.hero .btn{color:var(--brand-700);z-index:1;background:#fff;border-color:#fff;padding:7px 13px;position:relative}.hero .btn:hover{background:#eff6ff}.row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.spread{justify-content:space-between;align-items:center;gap:12px;display:flex}.grid{gap:16px;display:grid}.kpis{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;display:grid}.card{background:var(--surface);border-radius:var(--r);border:0;padding:18px;box-shadow:0 1px 2px #0f172a0a,0 6px 20px -6px #0f172a1f}.card.pad-lg{padding:22px}.section-title{align-items:center;gap:8px;margin-bottom:14px;font-size:14px;font-weight:700;display:flex}.kpi{color:#fff;border:0;flex-direction:column;align-items:flex-start;min-height:132px;padding:18px 18px 16px;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 24px -12px #0f172a80}.kpi>*{z-index:1;position:relative}.kpi .ic{background:#ffffff38;border-radius:12px;place-items:center;width:42px;height:42px;margin-bottom:auto;display:grid}.kpi .ic svg{color:#fff;width:22px;height:22px}.kpi .k{opacity:.92;margin-top:12px;font-size:12.5px;font-weight:600}.kpi .v{letter-spacing:-.01em;white-space:nowrap;margin-top:3px;font-size:clamp(16px,1.1vw,20px);font-weight:700;line-height:1.2}.kpi .spark{opacity:.16;z-index:0;pointer-events:none;position:absolute;bottom:-16px;right:-12px}.kpi .spark svg{color:#fff;width:92px;height:92px}.kpi.blue{background:linear-gradient(135deg,#2563eb,#3b82f6)}.kpi.violet{background:linear-gradient(135deg,#7c3aed,#a855f7)}.kpi.green{background:linear-gradient(135deg,#059669,#10b981)}.kpi.amber{background:linear-gradient(135deg,#d97706,#f59e0b)}.kpi.red{background:linear-gradient(135deg,#dc2626,#f43f5e)}.kpi.teal{background:linear-gradient(135deg,#0891b2,#06b6d4)}.kpi.indigo{background:linear-gradient(135deg,#4f46e5,#6366f1)}.kpi.pink{background:linear-gradient(135deg,#db2777,#ec4899)}.ic.blue{background:var(--brand-50);color:var(--brand)}.ic.green{background:var(--good-bg);color:var(--good)}.ic.amber{background:var(--warn-bg);color:var(--warn)}.ic.red{background:var(--bad-bg);color:var(--bad)}.ic.sky{background:var(--info-bg);color:var(--info)}.dash-2col{grid-template-columns:2fr 1fr;gap:16px;margin-top:16px;display:grid}.rep-2col{grid-template-columns:1fr 1fr;gap:16px;margin-top:16px;display:grid}@media (width<=1000px){.dash-2col,.rep-2col{grid-template-columns:1fr}}.tablewrap{background:var(--surface);border-radius:var(--r);border:0;overflow:hidden;box-shadow:0 1px 2px #0f172a0a,0 6px 20px -6px #0f172a1f}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--line);padding:8px 14px;font-size:13.5px}th{background:var(--surface-2);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:11.5px;font-weight:600}tbody tr:last-child td{border-bottom:0}tbody tr:hover td{background:var(--surface-2)}.right{text-align:right}.center{text-align:center}.empty{text-align:center;color:var(--faint);padding:40px}.loading{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;min-height:50vh;display:flex}.loading-ring{width:64px;height:64px;color:var(--brand);background:var(--brand-50);border-radius:50%;place-items:center;display:grid;position:relative}.loading-ring:before{content:"";border:3px solid var(--brand-50);border-top-color:var(--brand);border-radius:50%;animation:.8s linear infinite spin;position:absolute;inset:-4px}.loading-ring svg{animation:1.6s ease-in-out infinite wrench-wobble}.loading .muted{letter-spacing:.02em;font-size:13px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes wrench-wobble{0%,to{transform:rotate(-12deg)}50%{transform:rotate(12deg)}}.listcard{background:var(--surface);border-radius:var(--r);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden;box-shadow:0 1px 2px #0f172a0a,0 6px 20px -6px #0f172a1f}.listscroll{flex:1;min-height:0;overflow:auto}.listscroll thead th{z-index:1;position:sticky;top:0}.pager{border-top:1px solid var(--line);background:var(--surface-2);color:var(--muted);justify-content:flex-end;align-items:center;gap:12px;padding:8px 14px;font-size:13px;display:flex}.pager .btn.sm{padding:4px 10px}input,select,textarea{font:inherit;border:1px solid var(--line-2);border-radius:var(--r-sm);width:100%;color:var(--ink);background:#fff;padding:9px 11px;transition:border .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-50);outline:none}label{color:var(--ink-2);margin-bottom:5px;font-size:12.5px;font-weight:500;display:block}.field{margin-bottom:14px}textarea{resize:vertical;min-height:70px}.sel{position:relative}.sel-btn{border:1px solid var(--line-2);border-radius:var(--r-sm);width:100%;color:var(--ink);font:inherit;text-align:left;background:#fff;justify-content:space-between;align-items:center;gap:8px;padding:9px 11px;transition:border .12s,box-shadow .12s;display:flex}.sel-btn:hover{border-color:var(--muted)}.sel-btn:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-50);outline:none}.sel-btn svg{color:var(--muted);flex:none}.sel.disabled{opacity:.55;pointer-events:none}.sel-list{z-index:40;border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--sh-lg);background:#fff;max-height:280px;padding:5px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.sel-opt{width:100%;font:inherit;text-align:left;color:var(--ink-2);cursor:pointer;background:0 0;border:0;border-radius:6px;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;display:flex}.sel-opt:hover{background:var(--surface-2)}.sel-opt.on{background:var(--brand-50);color:var(--brand);font-weight:600}.sel-hint{color:var(--faint);flex:none;font-size:11.5px}.sel-empty{color:var(--faint);padding:10px;font-size:13px}.btn{background:var(--brand);color:#fff;border:1px solid var(--brand);border-radius:var(--r-sm);box-shadow:var(--sh-sm);align-items:center;gap:7px;padding:9px 15px;font-weight:600;transition:all .12s;display:inline-flex}.btn:hover{background:var(--brand-600);border-color:var(--brand-600)}.btn svg{width:16px;height:16px}.btn.ghost{color:var(--ink-2);border-color:var(--line-2);box-shadow:none;background:#fff}.btn.ghost:hover{background:var(--surface-2);border-color:var(--muted)}.btn.sm{padding:6px 10px;font-size:12.5px}.btn.danger{background:var(--bad);border-color:var(--bad)}.btn.danger:hover{filter:brightness(.95)}.btn.danger-soft{background:var(--bad-bg);color:var(--bad);box-shadow:none;border-color:#0000}.btn.danger-soft:hover{background:#fecaca}.btn.success{background:var(--good);border-color:var(--good)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.icon-btn{justify-content:center;width:30px;height:30px;padding:6px}.btn.icon-btn svg{width:15px;height:15px}.btn-row{justify-content:flex-end;gap:9px;margin-top:16px;display:flex}.badge{background:var(--line);color:var(--ink-2);border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.badge:before{content:"";opacity:.7;background:currentColor;border-radius:50%;width:6px;height:6px}.badge.Open{background:var(--info-bg);color:#0369a1}.badge.InProgress{background:var(--warn-bg);color:#b45309}.badge.AwaitingApproval{color:#a16207;background:#fef9c3}.badge.Approved{color:#6d28d9;background:#ede9fe}.badge.ReadyForCollection{background:var(--good-bg);color:#15803d}.badge.Invoiced{color:#6d28d9;background:#ede9fe}.badge.Closed{background:var(--line);color:var(--muted)}.badge.Cancelled{background:var(--bad-bg);color:#b91c1c}.badge.Paid{background:var(--good-bg);color:#15803d}.badge.Partial{background:var(--warn-bg);color:#b45309}.badge.Unpaid{background:var(--bad-bg);color:#b91c1c}.badge.plain:before{display:none}.modal-bg{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:60;background:#0f172a80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--r-lg);width:520px;max-width:100%;max-height:92vh;box-shadow:var(--sh-lg);background:#fff;padding:24px;overflow:auto}.modal-head{border-radius:var(--r-lg) var(--r-lg) 0 0;justify-content:space-between;align-items:center;gap:10px;margin:-24px -24px 18px;padding:13px 20px;display:flex}.modal-head h3{font-size:16px}.modal-x{color:#fff;background:#fff3;border:0;border-radius:7px;width:28px;height:28px;font-size:14px}.modal-x:hover{background:#ffffff52}.modal.confirm{text-align:center;width:400px}.confirm-ic{background:var(--brand-50);width:56px;height:56px;color:var(--brand);border-radius:50%;place-items:center;margin:0 auto;display:grid}.confirm-ic.danger{background:var(--bad-bg);color:var(--bad)}.modal.confirm .btn-row{justify-content:center}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.toolbar input,.toolbar select{max-width:260px}.search{position:relative}.search svg{width:16px;height:16px;color:var(--faint);position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search input{padding-left:32px}.err{color:var(--bad);background:var(--bad-bg);border-radius:var(--r-sm);border:1px solid #fecaca;margin:8px 0;padding:8px 11px;font-size:13px}hr{border:0;border-top:1px solid var(--line);margin:12px 0}.login-wrap{background:radial-gradient(1200px 600px at 70% -10%,#1e3a8a 0%,#0b1220 55%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-box{width:380px;box-shadow:var(--sh-lg);background:#fff;border-radius:18px;padding:34px}.login-box .blogo{background:linear-gradient(135deg, var(--brand), #60a5fa);color:#fff;border-radius:13px;place-items:center;width:48px;height:48px;margin-bottom:14px;font-size:22px;display:grid}.pub-garage{border-bottom:1px solid var(--line);align-items:center;gap:12px;margin-bottom:4px;padding-bottom:12px;display:flex}.pub-garage b{font-size:16px}.bars{justify-content:flex-start;align-items:flex-end;gap:8px;height:160px;padding-top:8px;display:flex;overflow-x:auto}.bars .col{flex-direction:column;flex:1 1 0;justify-content:flex-end;gap:2px;min-width:14px;max-width:54px;display:flex}.bars .seg{border-radius:4px 4px 0 0;min-height:2px;transition:height .2s}.bars .seg.s{background:var(--brand)}.bars .seg.p{background:#60a5fa}.bars .lbl{color:var(--faint);text-align:center;white-space:nowrap;text-overflow:ellipsis;margin-top:5px;font-size:9px;overflow:hidden}.board{flex:1;gap:12px;min-height:0;display:grid}.board-col{background:var(--surface-2);border-radius:var(--r);flex-direction:column;min-height:0;display:flex;overflow:hidden;box-shadow:0 1px 2px #0f172a0a,0 6px 20px -8px #0f172a1f}.board-col-head{color:#fff;z-index:1;justify-content:space-between;align-items:center;padding:11px 13px;display:flex;position:sticky;top:0}.board-col-head .bch-left{letter-spacing:-.01em;align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.board-col-head .bch-left svg{width:16px;height:16px}.board-col-head .bch-count{color:#fff;background:#ffffff40;border-radius:999px;justify-content:center;align-items:center;min-width:24px;height:22px;padding:0 8px;font-size:12px;font-weight:700;display:inline-flex}.board-col-body{flex-direction:column;flex:1;gap:8px;min-height:0;padding:10px;transition:background .12s,box-shadow .12s;display:flex;overflow-y:auto}.board-col-body.drop-over{background:var(--brand-50);box-shadow:inset 0 0 0 2px var(--brand)}.board-card{background:var(--surface);border-radius:var(--r-sm);box-shadow:var(--sh-sm);border-left:3px solid var(--brand);padding:10px 12px;transition:transform .1s,box-shadow .1s;display:block}.board-card:hover{box-shadow:var(--sh);transform:translateY(-1px)}.board-card{cursor:grab}.board-card:active{cursor:grabbing}.board-card .bc-line{color:var(--ink-2);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:12px;overflow:hidden}.jce{flex-direction:column;flex:1;gap:14px;min-height:0;display:flex}.jce-info{flex:none}.jce-mid{flex:1;grid-template-columns:1fr 340px;gap:14px;min-height:0;display:grid}.lines-card{background:var(--surface);border-radius:var(--r);flex-direction:column;min-height:0;display:flex;overflow:hidden;box-shadow:0 1px 2px #0f172a0a,0 6px 20px -6px #0f172a1f}.lines-scroll{flex:1;min-height:0;overflow:auto}.lines-scroll thead th{z-index:1;padding-top:11px;padding-bottom:11px;position:sticky;top:0}.jce-bottom{flex:none;grid-template-columns:1fr 1fr 340px;gap:14px;display:grid}.jce-bottom.locked{grid-template-columns:1fr}.lines-bar{background:var(--warn-bg);color:#92400e;border-top:1px solid #fde68a;justify-content:space-between;align-items:center;gap:10px;padding:8px 12px;font-size:13px;font-weight:600;display:flex}.row-dirty td{background:#fffbeb!important}.cell-in{text-align:right;width:84px;margin-left:auto;padding:5px 8px;font-size:13px;display:block}.cell-in.sm{width:60px}.jc-summary{flex-direction:column;display:flex}.jc-summary .jc-grand{border-top:1px solid var(--line);color:var(--ink);margin-top:auto;padding-top:12px;font-size:20px;font-weight:800}.jce .card .section-title{color:#fff;background:linear-gradient(135deg, var(--brand), #60a5fa);border-radius:var(--r) var(--r) 0 0;margin:-18px -18px 14px;padding:11px 16px;font-size:13px}.jce .jc-summary .section-title{background:linear-gradient(135deg,#7c3aed,#a855f7)}.jce .jce-bottom .card:last-child .section-title{background:linear-gradient(135deg,#d97706,#f59e0b)}.jce .jce-bottom .card:first-child .section-title{background:linear-gradient(135deg,#059669,#10b981)}.status-actions{flex-direction:column;gap:8px;display:flex}.status-actions .btn{justify-content:flex-start;width:100%}.addrow{align-items:flex-end}.addrow .field{margin-bottom:0}.addrow input{height:38px}.addrow .add-btn{white-space:nowrap;height:38px;padding-top:0;padding-bottom:0}@media (width<=1100px){.jce-mid,.jce-bottom{grid-template-columns:1fr}}.info-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;display:grid}.info-cell .info-k,.info-note .info-k{text-transform:uppercase;letter-spacing:.04em;color:var(--faint);font-size:11px;font-weight:700}.info-cell .info-v{margin-top:2px;font-size:14px}.info-note{border-top:1px dashed var(--line);color:var(--ink-2);margin-top:12px;padding-top:10px;font-size:13.5px}.info-note .info-k{margin-right:6px;display:inline}.seg{background:#ffffff26;border-radius:8px;padding:2px;display:inline-flex}.seg button{color:#fff;background:0 0;border:0;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:600}.seg button.on{color:var(--brand-700);background:#fff}.cal-wrap{flex-direction:column;flex:1;min-height:0;display:flex}.seg-light{background:var(--surface-2);border:1px solid var(--line)}.seg-light button{color:var(--muted)}.seg-light button.on{background:var(--brand);color:#fff}.cal-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.cal-grid.month{flex:1;grid-auto-rows:1fr;min-height:0}.cal-head{flex:none;margin-bottom:6px}.cal-wd{text-align:center;color:var(--muted);text-transform:uppercase;font-size:11px;font-weight:700}.cal-cell{border:1px solid var(--line);background:var(--surface);border-radius:8px;flex-direction:column;gap:3px;min-height:84px;padding:5px;display:flex;overflow:hidden}.cal-cell-body{flex-direction:column;flex:1;gap:3px;min-height:0;display:flex;overflow-y:auto}.cal-cell.muted-day{background:var(--surface-2)}.cal-cell.muted-day .cal-d{color:var(--faint)}.cal-cell.today{border-color:var(--brand);box-shadow:inset 0 0 0 1px var(--brand)}.cal-d{color:var(--ink-2);flex:none;font-size:12px;font-weight:700}.cal-appt{white-space:nowrap;text-overflow:ellipsis;cursor:grab;padding:2px 6px;font-size:10.5px;overflow:hidden}.cal-appt:active{cursor:grabbing}.cal-appt:before{display:none}.cal-cell.drop-over,.cal-col-body.drop-over{background:var(--brand-50);box-shadow:inset 0 0 0 2px var(--brand)}.cal-week{flex:1;grid-template-columns:repeat(7,1fr);gap:6px;min-height:0;display:grid}.cal-col{border:1px solid var(--line);background:var(--surface);border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.cal-col.today{border-color:var(--brand);box-shadow:inset 0 0 0 1px var(--brand)}.cal-col-head{text-align:center;background:var(--surface-2);border-bottom:1px solid var(--line);padding:6px;font-size:12px;font-weight:700}.cal-col-body{flex-direction:column;flex:1;gap:4px;min-height:0;padding:6px;display:flex;overflow-y:auto}.cal-day{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex;overflow-y:auto}.cal-day-row{align-items:center;gap:14px;padding:12px 14px;display:flex}.cal-day-time{width:72px;color:var(--brand);flex:none;font-size:16px;font-weight:800}.tg-scroll{border:1px solid var(--line);border-radius:8px;flex:1;min-height:0;overflow-y:auto}.tg{display:grid}.tg-corner{z-index:2;background:var(--surface-2);border-bottom:1px solid var(--line);position:sticky;top:0}.tg-dayhead{z-index:2;background:var(--surface-2);border-bottom:1px solid var(--line);border-left:1px solid var(--line);text-align:center;padding:7px 6px;font-size:12px;font-weight:700;position:sticky;top:0}.tg-dayhead.today{color:var(--brand)}.tg-time{color:var(--muted);text-align:right;border-bottom:1px solid var(--line);padding:4px 6px;font-size:11px}.tg-cell{border-bottom:1px solid var(--line);border-left:1px solid var(--line);flex-direction:column;gap:3px;min-height:46px;padding:3px;display:flex}.tg-cell.drop-over{background:var(--brand-50);box-shadow:inset 0 0 0 2px var(--brand)}.legend{color:var(--muted);gap:16px;font-size:12px;display:flex}.legend i{vertical-align:middle;border-radius:3px;width:10px;height:10px;margin-right:6px;display:inline-block}@media (width<=820px){.sidebar{width:64px}.brand b,.brand small,.nav .group,.nav a span,.userchip .nm,.userchip .rl{display:none}.nav a{justify-content:center}}
