.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.db-board-types{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-3, .75rem)}.db-board-card{border:2px solid var(--color-border-main, #d1d5db);border-radius:var(--radius-lg, 12px);padding:var(--spacing-4, 1rem);cursor:pointer;transition:border-color .15s,box-shadow .15s;background:var(--color-bg-paper, white);text-align:left}.db-board-card:hover{border-color:var(--color-primary-400, #4ade80)}.db-board-card.selected{border-color:var(--color-primary-500, #2d5a27);box-shadow:0 0 0 3px #2d5a271a}.db-board-card-icon{font-size:1.5rem;margin-bottom:var(--spacing-2, .5rem);display:block}.db-board-card-name{font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-primary, #1e293b);display:block;margin-bottom:.25rem}.db-board-card-desc{font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #64748b);display:block}.db-subview-list{display:flex;flex-direction:column;gap:var(--spacing-2, .5rem)}.db-subview-item{display:flex;align-items:center;gap:var(--spacing-3, .75rem);padding:var(--spacing-3, .75rem) var(--spacing-4, 1rem);border:1px solid var(--color-border-light, #e5e7eb);border-radius:var(--radius-md, 8px);background:var(--color-bg-secondary, #f9fafb);cursor:pointer;transition:background .15s,border-color .15s}.db-subview-item:hover{background:var(--color-bg-paper, white);border-color:var(--color-border-main, #d1d5db)}.db-subview-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary-500, #2d5a27);cursor:pointer;flex-shrink:0}.db-subview-icon{font-size:1.25rem;color:var(--color-text-secondary, #64748b);flex-shrink:0;width:1.5rem;text-align:center}.db-subview-text{display:flex;flex-direction:column;gap:.1rem}.db-subview-name{font-weight:var(--font-weight-medium, 500);color:var(--color-text-primary, #1e293b);font-size:var(--font-size-sm, .875rem)}.db-subview-desc{font-size:var(--font-size-xs, .75rem);color:var(--color-text-secondary, #64748b)}.db-interval-options{display:flex;gap:var(--spacing-2, .5rem)}.db-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#0f172a;font-size:24px;color:#f1f5f9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}.db-fullscreen.cursor-hidden{cursor:none}.db-view-container{position:absolute;top:0;right:0;bottom:0;left:0;padding:2rem;opacity:1;transition:opacity .5s ease-in-out}.db-view-container.transitioning{opacity:0}.db-clock{position:fixed;top:1.5rem;right:2rem;z-index:10001;text-align:right}.db-clock-time{font-size:1.75rem;font-weight:700;color:#f1f5f9;letter-spacing:.02em}.db-clock-date{font-size:.75rem;color:#94a3b8;margin-top:.1rem}.db-dots{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:10001;display:flex;gap:8px;align-items:center}.db-dot{width:8px;height:8px;border-radius:4px;background:#94a3b866;transition:width .3s,background .3s}.db-dot.active{width:24px;background:#6366f1}.db-settings-area{position:fixed;bottom:1rem;left:1.5rem;z-index:10001;display:flex;align-items:center;gap:.75rem}.db-settings-gear{font-size:1.5rem;opacity:.3;cursor:pointer;transition:opacity .3s;background:none;border:none;color:#94a3b8;padding:.25rem}.db-settings-gear:hover{opacity:1}.db-exit-btn{padding:.5rem 1rem;border:1px solid rgba(148,163,184,.3);border-radius:6px;background:#0f172acc;color:#f1f5f9;font-size:.75rem;cursor:pointer;transition:background .15s}.db-exit-btn:hover{background:#1e293be6}.db-view-title{font-size:2rem;font-weight:700;color:#f1f5f9;margin:0 0 1.5rem}.db-kanban{height:100%;display:flex;flex-direction:column}.db-kanban-columns{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;flex:1;overflow:hidden}.db-kanban-col{background:#1e293b80;border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.db-kanban-col-header{padding:.75rem 1rem;border-top:4px solid;display:flex;align-items:center;justify-content:space-between}.db-kanban-col-header.pending{border-top-color:#6b7280}.db-kanban-col-header.in-progress{border-top-color:#3b82f6}.db-kanban-col-header.review{border-top-color:#8b5cf6}.db-kanban-col-header.completed{border-top-color:#22c55e}.db-kanban-col-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8}.db-kanban-col-count{font-size:.65rem;font-weight:700;color:#64748b;background:#64748b33;padding:.15rem .5rem;border-radius:10px}.db-kanban-cards{flex:1;overflow-y:auto;padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.db-kanban-cards::-webkit-scrollbar{display:none}.db-kanban-card{background:#0f172a99;border-radius:8px;padding:.6rem .75rem;border-left:3px solid;display:flex;flex-direction:column;gap:.3rem}.db-kanban-card.priority-low{border-left-color:#6b7280}.db-kanban-card.priority-medium{border-left-color:#3b82f6}.db-kanban-card.priority-high{border-left-color:#f97316}.db-kanban-card.priority-urgent{border-left-color:#ef4444}.db-kanban-card-title{font-size:.625rem;font-weight:500;color:#e2e8f0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.db-kanban-card-meta{display:flex;align-items:center;gap:.5rem;font-size:.5rem;color:#64748b}.db-kanban-card-assignee{color:#94a3b8}.db-timer-badge{display:inline-flex;align-items:center;gap:.2rem;background:#ef444433;color:#fca5a5;padding:.1rem .4rem;border-radius:10px;font-size:.45rem;font-weight:600;animation:db-pulse 2s ease-in-out infinite}@keyframes db-pulse{0%,to{opacity:1}50%{opacity:.6}}.db-dashboard{height:100%;display:flex;flex-direction:column;gap:1.5rem}.db-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.db-kpi-card{background:#1e293b80;border-radius:12px;padding:1.25rem;text-align:center}.db-kpi-value{font-size:3rem;font-weight:700;line-height:1;margin-bottom:.25rem}.db-kpi-value.pending{color:#6b7280}.db-kpi-value.in-progress{color:#3b82f6}.db-kpi-value.review{color:#8b5cf6}.db-kpi-value.completed{color:#22c55e}.db-kpi-value.overdue{color:#ef4444}.db-kpi-label{font-size:.625rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-weight:500}.db-workload{flex:1;display:flex;flex-direction:column}.db-workload h3{font-size:.875rem;font-weight:600;color:#94a3b8;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.db-workload-bars{display:flex;flex-direction:column;gap:.5rem;flex:1;overflow:hidden}.db-workload-row{display:flex;align-items:center;gap:1rem}.db-workload-name{font-size:.625rem;color:#e2e8f0;width:120px;flex-shrink:0;text-align:right}.db-workload-bar-bg{flex:1;height:20px;background:#1e293b80;border-radius:4px;overflow:hidden;display:flex}.db-workload-bar-fill{height:100%;transition:width .5s ease}.db-workload-bar-fill.pending{background:#6b7280}.db-workload-bar-fill.active{background:#3b82f6}.db-workload-count{font-size:.55rem;color:#94a3b8;width:40px;flex-shrink:0}.db-trend{display:flex;flex-direction:column}.db-trend h3{font-size:.875rem;font-weight:600;color:#94a3b8;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.db-trend-bars{display:flex;align-items:flex-end;gap:.5rem;height:120px}.db-trend-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.db-trend-bar{width:100%;max-width:40px;background:#22c55e;border-radius:4px 4px 0 0;transition:height .5s ease}.db-trend-bar-label{font-size:.45rem;color:#64748b;margin-top:.25rem}.db-activity{height:100%;display:flex;flex-direction:column}.db-activity-list{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:.5rem}.db-activity-item{display:flex;gap:.75rem;padding:.75rem 1rem;background:#1e293b66;border-radius:8px;animation:db-slideIn .3s ease-out both}@keyframes db-slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.db-activity-item:nth-child(1){animation-delay:0ms}.db-activity-item:nth-child(2){animation-delay:50ms}.db-activity-item:nth-child(3){animation-delay:.1s}.db-activity-item:nth-child(4){animation-delay:.15s}.db-activity-item:nth-child(5){animation-delay:.2s}.db-activity-item:nth-child(6){animation-delay:.25s}.db-activity-item:nth-child(7){animation-delay:.3s}.db-activity-item:nth-child(8){animation-delay:.35s}.db-activity-item:nth-child(9){animation-delay:.4s}.db-activity-item:nth-child(10){animation-delay:.45s}.db-activity-icon{font-size:1rem;flex-shrink:0;width:1.5rem;text-align:center}.db-activity-content{flex:1;min-width:0}.db-activity-text{font-size:.625rem;color:#e2e8f0;line-height:1.4}.db-activity-text strong{color:#f1f5f9;font-weight:600}.db-activity-task{color:#818cf8;font-weight:500}.db-activity-time{font-size:.5rem;color:#64748b;margin-top:.15rem}.db-spotlight{height:100%;display:flex;flex-direction:column}.db-spotlight-count{font-size:.75rem;font-weight:400;color:#64748b;margin-left:1rem}.db-spotlight-layout{flex:1;display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;overflow:hidden}.db-spotlight-featured{background:#1e293b80;border-radius:16px;padding:2rem;opacity:1;transition:opacity .4s ease-in-out;display:flex;flex-direction:column}.db-spotlight-featured.transitioning{opacity:0}.db-spotlight-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.db-spotlight-title{font-size:1.5rem;font-weight:700;color:#f1f5f9;margin:0;flex:1}.db-spotlight-priority{font-size:.6rem;font-weight:600;padding:.25rem .75rem;border-radius:20px;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;margin-left:1rem}.db-spotlight-priority.low{background:#6b728033;color:#9ca3af}.db-spotlight-priority.medium{background:#3b82f633;color:#93c5fd}.db-spotlight-priority.high{background:#f9731633;color:#fdba74}.db-spotlight-priority.urgent{background:#ef444433;color:#fca5a5}.db-spotlight-meta{display:flex;gap:2rem;margin-bottom:1.5rem;flex-wrap:wrap}.db-spotlight-meta-item{display:flex;flex-direction:column;gap:.15rem}.db-spotlight-meta-label{font-size:.5rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.db-spotlight-meta-value{font-size:.75rem;color:#e2e8f0;font-weight:500}.db-spotlight-desc{font-size:.7rem;color:#94a3b8;line-height:1.5;margin-bottom:1rem}.db-spotlight-timer-inline.running{color:#ef4444;animation:db-pulse 2s ease-in-out infinite}.db-spotlight-body{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;flex:1;overflow:hidden}.db-spotlight-body:has(>.db-spotlight-details:only-child){grid-template-columns:1fr}.db-spotlight-photos{display:flex;flex-direction:column;gap:.5rem;overflow:hidden}.db-spotlight-photo-main{flex:1;border-radius:10px;overflow:hidden;background:#0000004d;position:relative;min-height:0}.db-spotlight-photo-main img{width:100%;height:100%;object-fit:contain;display:block;opacity:1;transition:opacity .3s ease-in-out}.db-spotlight-photo-main img.fading{opacity:0}.db-spotlight-photo-caption{position:absolute;bottom:0;left:0;right:0;padding:.4rem .75rem;background:#0009;color:#e2e8f0;font-size:.55rem}.db-spotlight-photo-counter{position:absolute;bottom:.5rem;right:.5rem;background:#0009;color:#e2e8f0;font-size:.5rem;font-weight:600;padding:.2rem .5rem;border-radius:10px;letter-spacing:.05em}.db-spotlight-photo-strip{display:flex;gap:.4rem;flex-shrink:0}.db-spotlight-photo-thumb{width:60px;height:60px;border-radius:6px;overflow:hidden;background:#0000004d;border:2px solid transparent;transition:border-color .3s}.db-spotlight-photo-thumb.active{border-color:#818cf8}.db-spotlight-photo-thumb img{width:100%;height:100%;object-fit:cover}.db-spotlight-details{display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.db-spotlight-details::-webkit-scrollbar{display:none}.db-spotlight-sections{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;flex:1}.db-spotlight-section h4{font-size:.625rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}.db-checklist-bar{height:6px;background:#64748b33;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.db-checklist-fill{height:100%;background:#22c55e;border-radius:3px;transition:width .5s ease}.db-checklist-text{font-size:.55rem;color:#64748b}.db-checklist-items{display:flex;flex-direction:column;gap:.3rem;margin-top:.4rem}.db-checklist-item{display:flex;align-items:flex-start;gap:.4rem;font-size:.6rem;color:#e2e8f0;line-height:1.3}.db-checklist-item.completed{color:#64748b;text-decoration:line-through}.db-checklist-check{flex-shrink:0;font-size:.55rem}.db-checklist-item-text{min-width:0}.db-spotlight-comments{display:flex;flex-direction:column;gap:.5rem}.db-spotlight-comment{background:#0f172a66;border-radius:8px;padding:.5rem .75rem;border-left:2px solid #818cf8}.db-spotlight-comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;font-size:.5rem;color:#94a3b8}.db-spotlight-comment-header strong{color:#e2e8f0}.db-spotlight-comment-text{font-size:.6rem;color:#cbd5e1;line-height:1.4}.db-spotlight-timer{font-size:1.5rem;font-weight:700;color:#3b82f6}.db-spotlight-timer.running{color:#ef4444;animation:db-pulse 2s ease-in-out infinite}.db-spotlight-timer-detail{font-size:.55rem;color:#64748b;margin-top:.25rem}.db-spotlight-activity{display:flex;flex-direction:column;gap:.4rem}.db-spotlight-activity-item{font-size:.55rem;color:#94a3b8;padding:.3rem 0;border-bottom:1px solid rgba(100,116,139,.1)}.db-spotlight-dots{display:flex;gap:6px;justify-content:center;margin-top:auto;padding-top:1rem}.db-spotlight-dot{width:6px;height:6px;border-radius:3px;background:#94a3b84d;transition:width .3s,background .3s}.db-spotlight-dot.active{width:18px;background:#818cf8}.db-spotlight-empty{text-align:center;color:#64748b;font-size:1rem;margin-top:4rem}.db-spotlight-sidebar{display:flex;flex-direction:column;overflow:hidden}.db-spotlight-sidebar-title{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem}.db-spotlight-sidebar-list{display:flex;flex-direction:column;gap:.5rem;overflow-y:auto}.db-spotlight-sidebar-list::-webkit-scrollbar{display:none}.db-spotlight-sidebar-card{background:#1e293b80;border-radius:10px;padding:.75rem 1rem;border-left:3px solid}.db-spotlight-sidebar-card.priority-low{border-left-color:#6b7280}.db-spotlight-sidebar-card.priority-medium{border-left-color:#3b82f6}.db-spotlight-sidebar-card.priority-high{border-left-color:#f97316}.db-spotlight-sidebar-card.priority-urgent{border-left-color:#ef4444}.db-spotlight-sidebar-card-title{font-size:.625rem;font-weight:500;color:#e2e8f0;line-height:1.3;margin-bottom:.3rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.db-spotlight-sidebar-card-meta{display:flex;align-items:center;gap:.5rem;font-size:.5rem;color:#94a3b8}.db-task-type-badge{display:inline-block;font-size:.45rem;font-weight:600;padding:.1rem .4rem;border-radius:8px;text-transform:uppercase;letter-spacing:.04em;margin-left:.4rem;vertical-align:middle}.db-task-type-badge.quick{background:#22c55e33;color:#86efac}.db-task-type-badge.standard{background:#3b82f633;color:#93c5fd}.db-task-type-badge.review{background:#8b5cf633;color:#c4b5fd}.db-task-type-badge.timed{background:#f9731633;color:#fdba74}.db-overdue{color:#fca5a5}:root{--color-primary-50: #e8f5e9;--color-primary-100: #c8e6c9;--color-primary-200: #a5d6a7;--color-primary-300: #81c784;--color-primary-400: #66bb6a;--color-primary-500: #2d5a27;--color-primary-600: #265021;--color-primary-700: #1e401a;--color-primary-800: #173014;--color-primary-900: #0f200d;--color-neutral-50: #fafafa;--color-neutral-100: #f5f5f5;--color-neutral-200: #eeeeee;--color-neutral-300: #e0e0e0;--color-neutral-400: #bdbdbd;--color-neutral-500: #9e9e9e;--color-neutral-600: #757575;--color-neutral-700: #616161;--color-neutral-800: #424242;--color-neutral-900: #212121;--color-accent-50: #fff8e1;--color-accent-100: #ffecb3;--color-accent-200: #ffe082;--color-accent-300: #ffd54f;--color-accent-400: #ffca28;--color-accent-500: #d4a520;--color-accent-600: #b8860b;--color-accent-700: #9a6f0a;--color-accent-800: #7c5809;--color-accent-900: #5e4108;--color-success-light: #d4edda;--color-success-main: #28a745;--color-success-dark: #155724;--color-warning-light: #fff3cd;--color-warning-main: #ffc107;--color-warning-dark: #856404;--color-error-light: #f8d7da;--color-error-main: #dc3545;--color-error-dark: #721c24;--color-info-light: #cce5ff;--color-info-main: #17a2b8;--color-info-dark: #004085;--color-bg-default: #f5f5f5;--color-bg-paper: #ffffff;--color-bg-subtle: #fafafa;--color-text-primary: #212121;--color-text-secondary: #666666;--color-text-disabled: #9e9e9e;--color-text-hint: #bdbdbd;--color-text-inverse: #ffffff;--color-border-light: #e0e0e0;--color-border-main: #bdbdbd;--color-border-dark: #9e9e9e;--font-family-primary: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-family-mono: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-20: 5rem;--radius-none: 0;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-none: none;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family-primary);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-default);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.app{min-height:100vh;display:flex;flex-direction:column}header{background:var(--color-primary-500);color:var(--color-text-inverse);padding:var(--spacing-4) var(--spacing-6);box-shadow:var(--shadow-md)}header h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);letter-spacing:-.025em}main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:var(--spacing-6)}.card{background:var(--color-bg-paper);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-6);margin-bottom:var(--spacing-6)}.dashboard-section{margin-top:var(--spacing-8);padding-top:var(--spacing-6);border-top:1px solid var(--color-border-light)}.dashboard-section:first-of-type{margin-top:var(--spacing-6)}.dashboard-section .section-header{border-bottom:none;padding-bottom:var(--spacing-2);margin-bottom:var(--spacing-4)}.last-inspection-card{background:#fff;border:2px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-5);margin-bottom:var(--spacing-6);box-shadow:0 2px 8px #0000000f}.last-inspection-card.overdue{border-color:var(--color-warning-500, #f59e0b);background:linear-gradient(to bottom,#fffbeb,#fff 100px)}.last-inspection-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-4)}.last-inspection-header .header-title{display:flex;align-items:center;gap:var(--spacing-3)}.last-inspection-header h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.days-ago-badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-default);border-radius:var(--radius-full)}.days-ago-badge.overdue{color:var(--color-warning-700, #b45309);background:var(--color-warning-100, #fef3c7);font-weight:var(--font-weight-semibold)}.overdue-message{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);margin-bottom:var(--spacing-4);background:var(--color-warning-50, #fffbeb);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-warning-700, #b45309)}.overdue-message .overdue-icon{font-size:var(--font-size-base)}.last-inspection-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}.inspection-detail{display:flex;flex-direction:column;gap:var(--spacing-1)}.inspection-detail.full-width{grid-column:1 / -1}.inspection-detail .detail-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.inspection-detail .detail-value{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border-light)}.section-header h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.inspections-header{border-bottom:none;padding-bottom:0;margin-bottom:var(--spacing-4)}.search-row{margin-bottom:var(--spacing-3)}.search-row .search-input{width:100%;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border-light)}.filter-row.compact{align-items:center;gap:var(--spacing-2)}.filter-row.compact .filter-input{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm)}.filter-separator{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-1)}.filter-group label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.filter-input{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);min-width:120px}.filter-spacer{flex:1}.export-buttons{display:flex;gap:var(--spacing-2)}.export-buttons .btn{display:flex;align-items:center;gap:var(--spacing-1)}.selection-info{color:var(--color-primary-600);font-weight:var(--font-weight-medium)}.bulk-action-toolbar{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);background:var(--color-primary-50);border:1px solid var(--color-primary-200);border-radius:var(--radius-md);margin-bottom:var(--spacing-4);flex-wrap:wrap}.bulk-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-700)}.bulk-action-group{display:flex;align-items:center;gap:var(--spacing-2)}.bulk-action-group .form-input-sm{padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-sm);min-width:140px}.bulk-action-group .custom-select,.bulk-action-group .user-select{min-width:160px}.bulk-action-group .custom-select-sm .custom-select-trigger{height:32px}.bulk-action-group .user-select-trigger{height:32px;font-size:var(--font-size-sm)}@media (max-width: 768px){.bulk-action-toolbar{flex-direction:column;align-items:stretch}.bulk-action-group{width:100%}.bulk-action-group .form-input-sm,.bulk-action-group .custom-select,.bulk-action-group .user-select{flex:1}}.checklist-list-header{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:var(--spacing-4);padding:var(--spacing-2) var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border-light);margin-bottom:var(--spacing-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.checklist-list-item{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:var(--spacing-4);padding:var(--spacing-4);border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.checklist-list-item:last-child{border-bottom:none}.checklist-list-item:hover{background:var(--color-primary-50, #f0fdf4);cursor:pointer}.checklist-list-item.has-failures{background:#fef2f2}.checklist-list-item.has-failures:hover{background:#fee2e2}.checklist-date{display:flex;align-items:baseline;gap:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.checklist-date .date-primary{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.checklist-date .date-secondary{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.checklist-date .date-remarks{margin-left:var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.checklist-date .date-remarks:before{content:"—";margin-right:var(--spacing-2);color:var(--color-border-light)}.checklist-inspector{color:var(--color-text-primary)}.checklist-actions{display:flex;gap:var(--spacing-1);justify-content:flex-end;min-width:100px}.checklist-remarks{grid-column:1 / 3;margin-top:var(--spacing-1)}.checklist-remarks .remarks-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-style:italic}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-2) var(--spacing-4);border:none;border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:focus{outline:none;box-shadow:0 0 0 3px #2d5a274d}.btn-primary{background:#fff;color:var(--color-primary-600);border:1px solid var(--color-primary-500)}.btn-primary:hover{background:var(--color-primary-50, #f0fdf4);border-color:var(--color-primary-600)}.btn-cta{background:var(--color-primary-500);color:var(--color-text-inverse);border:1px solid var(--color-primary-500)}.btn-cta:hover{background:var(--color-primary-600);border-color:var(--color-primary-600)}.btn-secondary{background:var(--color-neutral-200);color:var(--color-text-primary)}.btn-secondary:hover{background:var(--color-neutral-300)}.btn-danger{background:var(--color-error-main);color:var(--color-text-inverse)}.btn-danger:hover{background:var(--color-error-dark)}.btn-sm{padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs)}.btn-icon{padding:var(--spacing-2);min-width:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-border-light)}.data-table th{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);background:var(--color-bg-subtle)}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-bg-subtle)}.data-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-error{background:var(--color-error-light);color:var(--color-error-dark)}.badge-info{background:var(--color-info-light);color:var(--color-info-dark)}.badge-neutral{background:var(--color-neutral-200);color:var(--color-neutral-700)}.role-badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.role-admin{background:var(--color-info-light);color:var(--color-info-dark)}.role-manager{background:var(--color-success-light);color:var(--color-success-dark)}.role-worker{background:var(--color-warning-light);color:var(--color-warning-dark)}.role-viewer{background:var(--color-neutral-200);color:var(--color-neutral-700)}.status-badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.status-active{background:var(--color-success-light);color:var(--color-success-dark)}.status-inactive{background:var(--color-error-light);color:var(--color-error-dark)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:400;padding:var(--spacing-4)}.modal{background:var(--color-bg-paper);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--color-border-light);flex-shrink:0}.modal-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal-body{padding:var(--spacing-6);overflow-y:auto;flex:1;min-height:0}.modal-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-border-light);display:flex;gap:var(--spacing-3);justify-content:flex-end;flex-shrink:0}.custom-select-dropdown-portal,.user-select-dropdown-portal{background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:280px;overflow-y:auto}.form-group{margin-bottom:var(--spacing-4)}.form-group label{display:block;margin-bottom:var(--spacing-1);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-paper);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-hint)}.form-group .help-text{margin-top:var(--spacing-1);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.form-check{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) 0}.form-check input[type=checkbox],.form-check input[type=radio]{width:auto;margin:0}.form-check label{margin:0;font-weight:var(--font-weight-normal)}.permission-group{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.permission-group h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-3)}.permission-checkboxes{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-2)}.permission-view-toggle{display:flex;gap:var(--spacing-2)}.permission-group.effective-view{background:var(--color-bg-default)}.permission-items{display:flex;flex-direction:column;gap:var(--spacing-2)}.permission-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);background:var(--color-bg-paper)}.permission-item.granted{background:#22c55e1a;border:1px solid rgba(34,197,94,.2)}.permission-item.denied{background:#ef44440d;border:1px solid rgba(239,68,68,.1)}.permission-status{display:flex;align-items:center;gap:var(--spacing-2)}.permission-indicator{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:12px;font-weight:700}.permission-indicator.granted{background:var(--color-success-main);color:#fff}.permission-indicator.denied{background:var(--color-error-light);color:var(--color-error-main)}.permission-label{font-size:var(--font-size-sm);color:var(--color-text-primary)}.permission-sources{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.source-tag{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-weight-medium);color:#fff}.source-tag.source-direct{background:var(--color-primary-500)}.permissions-card{padding:var(--spacing-4)}.app-permissions-list{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.app-permission-item{border-bottom:1px solid var(--color-border)}.app-permission-item:last-child{border-bottom:none}.app-permission-header{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);cursor:pointer;transition:background .15s ease;-webkit-user-select:none;user-select:none}.app-permission-header:hover{background:var(--color-bg-secondary)}.app-permission-item.expanded .app-permission-header{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.app-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.app-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.app-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:var(--font-size-base)}.app-access-summary{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.app-expand-icon{color:var(--color-text-secondary);flex-shrink:0}.app-permission-content{padding:var(--spacing-4);background:var(--color-bg-subtle)}.app-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-4)}.permission-details{display:flex;flex-direction:column;gap:var(--spacing-2)}.permission-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);background:var(--color-bg-paper)}.permission-row.granted{background:#22c55e14}.permission-row.denied{background:#ef44440a}.permission-toggles{display:flex;flex-direction:column;gap:var(--spacing-1)}.permission-toggle-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3);background:var(--color-bg-paper);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.toggle-info{display:flex;flex-direction:column;gap:2px}.toggle-label{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-text-primary)}.toggle-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;border-radius:28px;transition:.2s}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:.2s;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 0 2px #2563eb33}@media (max-width: 640px){.app-permission-header{padding:var(--spacing-3)}.app-icon{width:36px;height:36px;font-size:18px}.permission-toggle-row{padding:var(--spacing-2)}.toggle-switch{width:46px;height:24px}.toggle-slider:before{height:18px;width:18px}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}}.actions{display:flex;gap:var(--spacing-2);flex-wrap:wrap}.empty-state{text-align:center;padding:var(--spacing-12) var(--spacing-6);color:var(--color-text-secondary)}.empty-state p{margin-bottom:var(--spacing-4)}.loading{text-align:center;padding:var(--spacing-12);color:var(--color-text-secondary)}.alert{padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);margin-bottom:var(--spacing-4)}.alert-error{background:var(--color-error-light);color:var(--color-error-dark);border:1px solid var(--color-error-main)}.alert-success{background:var(--color-success-light);color:var(--color-success-dark);border:1px solid var(--color-success-main)}nav.sidebar{width:240px;background:var(--color-bg-paper);border-right:1px solid var(--color-border-light);padding:var(--spacing-4)}nav.sidebar a{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);color:var(--color-text-secondary);text-decoration:none;font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}nav.sidebar a:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}nav.sidebar a.active{background:var(--color-primary-50);color:var(--color-primary-500)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-600) 0%,var(--color-primary-800) 100%);padding:var(--spacing-4)}.login-card{background:var(--color-bg-paper);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:400px;overflow:hidden}.login-header{background:var(--color-primary-500);color:var(--color-text-inverse);padding:var(--spacing-8) var(--spacing-6);text-align:center}.login-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-2)}.login-header p{font-size:var(--font-size-sm);opacity:.9}.login-form{padding:var(--spacing-6)}.login-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-border-light);text-align:center;background:var(--color-bg-subtle)}.login-footer p{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.link-button{background:none;border:none;color:var(--color-primary-500);cursor:pointer;font-weight:var(--font-weight-medium);text-decoration:underline}.link-button:hover{color:var(--color-primary-600)}.btn-block{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center}.loading-screen h1{color:var(--color-primary-500);margin-bottom:var(--spacing-4)}header{display:flex;justify-content:space-between;align-items:center}.home-page{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--color-primary-500) 0%,var(--color-primary-700) 50%,var(--color-primary-800) 100%)}.home-header{background:transparent;color:var(--color-text-inverse);padding:var(--spacing-4) var(--spacing-6);display:flex;justify-content:space-between;align-items:center;box-shadow:none}.home-header h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);letter-spacing:-.025em;text-shadow:0 2px 4px rgba(0,0,0,.2)}.home-header-right{display:flex;align-items:center;gap:var(--spacing-4)}.user-greeting{font-size:var(--font-size-sm);opacity:.9;text-shadow:0 1px 2px rgba(0,0,0,.2)}.home-signout-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s ease}.home-signout-btn:hover{background:#ffffff40;border-color:#ffffff80}.home-main{flex:1;padding:var(--spacing-4);display:flex;align-items:center;justify-content:center}.home-content{text-align:center}.home-welcome{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:#fff;margin-bottom:var(--spacing-2);text-shadow:0 2px 4px rgba(0,0,0,.2)}.home-subtitle{font-size:var(--font-size-base);color:#ffffffd9;margin-bottom:var(--spacing-8);text-shadow:0 1px 2px rgba(0,0,0,.15)}.app-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4);width:100%;max-width:400px}@media (min-width: 640px){.app-grid{grid-template-columns:repeat(3,1fr);max-width:500px;gap:var(--spacing-5)}}@media (min-width: 1024px){.app-grid{grid-template-columns:repeat(4,1fr);max-width:700px;gap:var(--spacing-6)}}.app-tile{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-4);background:#fffffff2;border:none;border-radius:var(--radius-xl);color:var(--color-text-primary);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 8px 32px #00000026,0 2px 8px #0000001a;text-align:center}.app-tile:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 16px 48px #0003,0 4px 16px #00000026}.app-tile:active{transform:translateY(-2px) scale(1.01)}.app-tile:focus{outline:none;box-shadow:0 0 0 4px #ffffff80,var(--shadow-lg)}.app-tile-icon{font-size:2rem;line-height:1;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--tile-color, var(--color-primary-500));border-radius:var(--radius-lg);margin-bottom:var(--spacing-1)}@media (min-width: 640px){.app-tile-icon{font-size:2.25rem;width:64px;height:64px}}.app-tile-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.app-tile-description{font-size:var(--font-size-xs);color:var(--color-text-secondary);display:none}@media (min-width: 640px){.app-tile-description{display:block}}.page-container{min-height:100vh;display:flex;flex-direction:column}.page-header{background:var(--color-bg-paper);border-bottom:1px solid var(--color-border-light);padding:var(--spacing-4) var(--spacing-6);display:flex;justify-content:space-between;align-items:center}.page-header h1{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.page-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:var(--spacing-6)}.coming-soon{text-align:center;padding:var(--spacing-12) var(--spacing-6)}.coming-soon-icon{font-size:4rem;display:block;margin-bottom:var(--spacing-4)}.coming-soon h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.coming-soon p{color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.coming-soon-status{display:inline-block;margin-top:var(--spacing-4);padding:var(--spacing-2) var(--spacing-4);background:var(--color-warning-light);color:var(--color-warning-dark);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.settings-layout{display:flex;flex-direction:column;gap:var(--spacing-6)}@media (min-width: 768px){.settings-layout{flex-direction:row}}.settings-tabs{display:flex;gap:var(--spacing-2);flex-wrap:wrap}@media (min-width: 768px){.settings-tabs{flex-direction:column;min-width:200px;gap:var(--spacing-1)}}.settings-tab{padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.settings-tab:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.settings-tab.active{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-600)}.settings-content{flex:1}.settings-content .card{margin-bottom:0}.settings-content .card h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.form-actions{margin-top:var(--spacing-6);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.input-disabled{background:var(--color-bg-subtle);color:var(--color-text-secondary);cursor:not-allowed}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.stat-card{background:var(--color-bg-paper);border-radius:var(--radius-lg);padding:var(--spacing-4);text-align:center;box-shadow:var(--shadow-sm)}.stat-value{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-500)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.user-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.user-list-item{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.user-list-item:hover{background:var(--color-primary-50);transform:translate(4px)}.user-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:var(--color-primary-500);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.user-email{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role,.user-status{flex-shrink:0}.user-arrow{color:var(--color-text-hint);font-size:var(--font-size-lg)}.user-detail-layout{display:grid;gap:var(--spacing-6)}@media (min-width: 768px){.user-detail-layout{grid-template-columns:280px 1fr}}.user-sidebar{background:var(--color-bg-paper);border-radius:var(--radius-lg);padding:var(--spacing-6);text-align:center;box-shadow:var(--shadow-sm);height:fit-content}.user-avatar-large{width:96px;height:96px;margin:0 auto var(--spacing-4);border-radius:var(--radius-full);overflow:hidden}.user-avatar-large img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:var(--color-primary-500);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:var(--font-weight-bold)}.user-sidebar h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-1)}.user-sidebar .user-email{margin-bottom:var(--spacing-3)}.user-sidebar .user-role{margin-bottom:var(--spacing-4)}.user-groups-preview{border-top:1px solid var(--color-border-light);padding-top:var(--spacing-4);text-align:left}.user-groups-preview h4{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.group-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.group-tag{display:inline-block;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:#fff}.user-detail-content{min-width:0}.detail-tabs{display:flex;gap:var(--spacing-1);margin-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border-light);padding-bottom:var(--spacing-3)}.detail-tab{padding:var(--spacing-2) var(--spacing-4);background:none;border:none;font-family:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.detail-tab:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.detail-tab.active{background:var(--color-primary-500);color:#fff}.tab-content .card{margin-bottom:0}.tab-content .card h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.profile-info{display:grid;grid-template-columns:1fr 2fr;gap:var(--spacing-3)}.profile-info dt{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.profile-info dd{color:var(--color-text-primary)}.header-actions{display:flex;align-items:center;gap:var(--spacing-3)}.group-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.group-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.group-item:hover{background:var(--color-primary-50)}.group-item.is-member{background:var(--color-primary-50);border:1px solid var(--color-primary-200)}.group-color{width:12px;height:12px;border-radius:var(--radius-full);flex-shrink:0}.group-info{flex:1}.group-name{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.group-description{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.group-toggle{flex-shrink:0}.group-toggle input[type=checkbox]{width:18px;height:18px}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-4)}.group-card{background:var(--color-bg-paper);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.group-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.group-card.inactive{opacity:.7}.group-card-header{padding:var(--spacing-4);color:#fff;position:relative}.group-card-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.group-inactive-badge{position:absolute;top:var(--spacing-2);right:var(--spacing-2);padding:var(--spacing-1) var(--spacing-2);background:#0000004d;border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.group-card-body{padding:var(--spacing-4)}.group-card-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4);min-height:40px}.group-card-actions,.color-picker{display:flex;gap:var(--spacing-2);flex-wrap:wrap}.color-option{width:36px;height:36px;border-radius:var(--radius-md);border:3px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--color-text-primary);box-shadow:0 0 0 2px #fff}.group-preview{padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg);text-align:center}.form-group textarea{resize:vertical;min-height:80px}.groups-preview-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.group-preview-item{display:flex;flex-direction:column;padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md);border-left:4px solid}.group-preview-item .group-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.group-preview-item .group-description{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.group-detail-layout{display:grid;gap:var(--spacing-6)}@media (min-width: 768px){.group-detail-layout{grid-template-columns:280px 1fr}}.group-sidebar{background:var(--color-bg-paper);border-radius:var(--radius-lg);padding:var(--spacing-6);text-align:center;box-shadow:var(--shadow-sm);height:fit-content}.group-avatar-large{width:96px;height:96px;margin:0 auto var(--spacing-4);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:var(--font-weight-bold);color:#fff}.group-sidebar h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-2)}.group-description-sidebar{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4)}.group-stats{display:flex;justify-content:center;gap:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.group-stat{text-align:center}.group-stat-value{display:block;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary-500)}.group-stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.group-detail-content{min-width:0}@media (max-width: 768px){main{padding:var(--spacing-4)}.section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-3)}.data-table{display:block;overflow-x:auto}.actions{flex-direction:column}.page-header{padding:var(--spacing-3) var(--spacing-4)}.page-header h1{font-size:var(--font-size-base)}.page-main{padding:var(--spacing-4)}}.app-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--spacing-6);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app-panel{background:var(--color-bg-paper);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:1400px;height:100%;max-height:calc(100vh - var(--spacing-12));display:flex;flex-direction:column;overflow:hidden;animation:slideUp .25s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.app-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--color-border-light);background:var(--color-bg-paper);flex-shrink:0}.app-panel-title-section{display:flex;align-items:baseline;gap:var(--spacing-3)}.app-panel-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.app-panel-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.app-panel-close{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.app-panel-close:hover{background:var(--color-bg-default);color:var(--color-text-primary)}.app-panel-toolbar{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-6);padding-bottom:0;background:#fff;flex-shrink:0}.app-panel-content{flex:1;overflow-y:scroll;padding:var(--spacing-6);padding-right:0;animation:contentFadeIn .15s ease-out;border-top:1px solid var(--color-border-light);background:#fff;max-width:none;margin:0}.app-panel-content>*{padding-right:var(--spacing-6)}.app-panel-content::-webkit-scrollbar{width:12px}.app-panel-content::-webkit-scrollbar-track{background:#eaeaea;border-radius:0}.app-panel-content::-webkit-scrollbar-thumb{background:#bbb;border-radius:6px;border:2px solid #eaeaea}.app-panel-content::-webkit-scrollbar-thumb:hover{background:#999}@keyframes contentFadeIn{0%{opacity:0}to{opacity:1}}.app-panel-content .card{margin-bottom:var(--spacing-4)}.app-panel-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--spacing-6);height:100%}.app-panel-sidebar{border-right:1px solid var(--color-border-light);padding-right:var(--spacing-6);overflow-y:auto}.app-panel-main{overflow-y:auto}.toolbar-with-action{display:flex;align-items:flex-end;justify-content:space-between;width:100%;gap:var(--spacing-4)}.toolbar-with-action .panel-tabs{padding:0}.toolbar-action-btn{display:inline-flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-2);white-space:nowrap;flex-shrink:0}.panel-tabs{display:flex;gap:0;padding:0 var(--spacing-6);background:transparent;position:relative;margin-bottom:-1px}.panel-tab{padding:var(--spacing-2) var(--spacing-5);border:1px solid transparent;border-bottom:none;background:transparent;border-radius:var(--radius-md) var(--radius-md) 0 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);position:relative;z-index:1}.panel-tab:hover{color:var(--color-text-primary)}.panel-tab.active{background:#fff;color:var(--color-text-primary);font-weight:var(--font-weight-semibold);border-color:var(--color-border-light);z-index:2}.toolbar-divider{width:1px;height:24px;background:var(--color-border-light);margin:0 var(--spacing-3)}.panel-toolbar-actions{display:flex;align-items:center;gap:var(--spacing-2);margin-left:auto}@media (max-width: 768px){.app-panel-overlay{padding:0}.app-panel{border-radius:0;max-height:100vh}.app-panel-layout{grid-template-columns:1fr}.app-panel-sidebar{display:none}.app-panel-header{padding:var(--spacing-3) var(--spacing-4)}.app-panel-content{padding:var(--spacing-4)}}.app-panel-content:has(.tasks-content){overflow:hidden;display:flex;flex-direction:column}.tasks-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.task-detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--spacing-4);color:var(--color-text-secondary)}.task-detail-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--spacing-6);height:100%;min-height:0}.task-detail-sidebar{display:flex;flex-direction:column;gap:var(--spacing-4);padding-right:var(--spacing-6);border-right:1px solid var(--color-border-light);overflow-y:auto}.sidebar-section{display:flex;flex-direction:column;gap:var(--spacing-2)}.sidebar-section-header{display:flex;justify-content:space-between;align-items:center}.sidebar-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.task-status-large{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.task-status-large.status-pending{background:var(--color-warning-100, #fef3c7);color:var(--color-warning-800, #92400e)}.task-status-large.status-in_progress{background:var(--color-info-100, #dbeafe);color:var(--color-info-800, #1e40af)}.task-status-large.status-pending_review{background:#f3e8ff;color:#6b21a8}.task-status-large.status-completed{background:var(--color-success-100, #dcfce7);color:var(--color-success-800, #166534)}.task-status-large.status-rejected{background:var(--color-error-100, #fee2e2);color:var(--color-error-800, #991b1b)}.task-status-large.status-cancelled{background:var(--color-bg-subtle);color:var(--color-text-secondary)}.task-blocked-notice{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--color-error-50, #fef2f2);border:1px solid var(--color-error-200, #fecaca);border-radius:var(--radius-md);font-size:var(--font-size-xs);color:var(--color-error-700, #b91c1c)}.sidebar-assignee{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-primary)}.sidebar-due-date{font-size:var(--font-size-sm);color:var(--color-text-primary)}.sidebar-due-date.overdue{color:var(--color-error-600, #dc2626)}.sidebar-due-date .overdue-badge{display:inline-block;margin-left:var(--spacing-2);padding:2px var(--spacing-2);background:var(--color-error-100, #fee2e2);color:var(--color-error-700, #b91c1c);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm)}.sidebar-due-date .no-date{color:var(--color-text-tertiary);font-style:italic}.task-type-badge{display:inline-block;padding:var(--spacing-1) var(--spacing-2);background:var(--color-bg-subtle);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:capitalize}.sidebar-actions{display:flex;flex-direction:column;gap:var(--spacing-2);padding-top:var(--spacing-2);border-top:1px solid var(--color-border-light)}.btn-block{width:100%;justify-content:center}.watchers-avatars{display:flex;align-items:center;gap:-4px}.watchers-avatars>*{margin-left:-4px}.watchers-avatars>*:first-child{margin-left:0}.watchers-more{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-left:var(--spacing-2)}.sidebar-meta{padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.meta-item{display:flex;justify-content:space-between;font-size:var(--font-size-xs);margin-bottom:var(--spacing-1)}.meta-label{color:var(--color-text-secondary)}.meta-value{color:var(--color-text-primary)}.task-detail-main{overflow-y:auto;padding-right:var(--spacing-4)}.task-title-large{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-4) 0;line-height:1.3}.task-description-section{margin-bottom:var(--spacing-6)}.task-description{font-size:var(--font-size-base);color:var(--color-text-primary);line-height:1.6;white-space:pre-wrap}.task-section{margin-bottom:var(--spacing-6);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.section-header h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.checklist-count,.subtask-count{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.checklist-items{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.add-checklist-item{display:flex;gap:var(--spacing-2)}.add-checklist-item .form-input{flex:1}.comment-input-section{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-4)}.comment-input-section .btn{align-self:flex-end}.comment-item{padding:var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md);margin-bottom:var(--spacing-3)}.comment-header{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-2)}.comment-meta{display:flex;flex-direction:column}.comment-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.activity-tab h2,.files-tab h2,.time-tab h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-4) 0}.activity-timeline{display:flex;flex-direction:column;gap:var(--spacing-3)}.activity-timeline-item{display:flex;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md)}.activity-timeline-item .activity-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-paper);border-radius:var(--radius-full);flex-shrink:0}.activity-timeline-item .activity-content{flex:1}.activity-timeline-item .activity-text{font-size:var(--font-size-sm);color:var(--color-text-primary);display:block;margin-bottom:var(--spacing-1)}.activity-timeline-item .activity-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.file-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);border:2px dashed var(--color-border-main);border-radius:var(--radius-lg);background:var(--color-bg-subtle);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--spacing-6)}.file-upload-zone:hover{border-color:var(--color-primary);background:var(--color-primary-50, #f0fdf4)}.file-upload-zone svg{color:var(--color-text-tertiary);margin-bottom:var(--spacing-3)}.file-upload-zone p{font-size:var(--font-size-base);color:var(--color-text-primary);margin:0 0 var(--spacing-1) 0}.file-upload-zone .file-types{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.no-files{text-align:center;color:var(--color-text-secondary);font-style:italic}.files-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.files-header h2{margin:0}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-3)}.file-card{border:1px solid var(--color-border-light);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-paper);transition:box-shadow var(--transition-fast)}.file-card:hover{box-shadow:var(--shadow-md, 0 2px 8px rgba(0,0,0,.1))}.file-thumbnail-link{display:block}.file-thumbnail{width:100%;height:140px;object-fit:cover;display:block;background:var(--color-bg-subtle)}.file-icon-box{display:flex;align-items:center;justify-content:center;height:140px;background:var(--color-bg-subtle);color:var(--color-text-tertiary)}.file-card-info{padding:var(--spacing-2) var(--spacing-3);display:flex;flex-direction:column;gap:2px}.file-card-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-card-uploader,.file-card-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.file-card-actions{display:flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);border-top:1px solid var(--color-border-light)}.btn-danger-text{color:var(--color-danger, #dc3545)!important}.compact-task-more{text-align:center;padding:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-style:italic}.time-summary-card{display:flex;gap:var(--spacing-6);padding:var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4)}.time-stat{display:flex;flex-direction:column;gap:var(--spacing-1)}.time-stat-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.time-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.time-progress-section{flex:1;display:flex;align-items:center;gap:var(--spacing-3)}.timer-section{margin-bottom:var(--spacing-6)}.timer-running-card{padding:var(--spacing-4);background:var(--color-success-50, #f0fdf4);border:1px solid var(--color-success-200, #bbf7d0);border-radius:var(--radius-lg)}.timer-indicator{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3)}.timer-elapsed{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-success-700, #15803d)}.time-entries-section h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-3) 0}.time-entries-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.time-entry-card{padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md)}.time-entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-1)}.time-entry-user{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.time-entry-duration{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-600)}.time-entry-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-1)}.time-entry-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 var(--spacing-1);margin-left:var(--spacing-1);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);background:var(--color-primary);color:#fff;border-radius:var(--radius-full)}@media (max-width: 768px){.task-detail-layout{grid-template-columns:1fr}.task-detail-sidebar{border-right:none;border-bottom:1px solid var(--color-border-light);padding-right:0;padding-bottom:var(--spacing-4)}.time-summary-card{flex-direction:column;gap:var(--spacing-3)}}.task-dashboard{padding:0}.dashboard-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}@media (max-width: 768px){.dashboard-stats-row{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--color-bg-subtle);border-radius:var(--radius-lg);padding:var(--spacing-4);text-align:center;border:1px solid var(--color-border-light)}.stat-card.warning{background:var(--color-warning-50, #fffbeb);border-color:var(--color-warning-200, #fde68a)}.stat-card.success{background:var(--color-success-50, #f0fdf4);border-color:var(--color-success-200, #bbf7d0)}.stat-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);display:block}.stat-card.warning .stat-card-value{color:var(--color-warning-600, #d97706)}.stat-card.success .stat-card-value{color:var(--color-success-600, #16a34a)}.stat-card-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.dashboard-columns{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-6)}@media (max-width: 768px){.dashboard-columns{grid-template-columns:1fr}}.dashboard-section h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.empty-state-sm{padding:var(--spacing-6);text-align:center;background:var(--color-bg-subtle);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.empty-state-sm.success{background:var(--color-success-50, #f0fdf4);color:var(--color-success-700, #15803d)}.task-list-compact{display:flex;flex-direction:column;gap:var(--spacing-2)}.compact-task-card{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.compact-task-card:hover{background:var(--color-primary-50, #f0fdf4);border-color:var(--color-primary-200)}.compact-task-priority{width:4px;height:100%;min-height:36px;border-radius:2px;flex-shrink:0}.compact-task-content{flex:1;min-width:0}.compact-task-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compact-task-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.btn-link{background:none;border:none;padding:var(--spacing-1) var(--spacing-2);color:var(--color-primary-600);font-weight:var(--font-weight-medium);cursor:pointer}.btn-link:hover{color:var(--color-primary-700);text-decoration:underline}.btn-icon{padding:var(--spacing-2);min-width:auto;background:transparent;border:1px solid var(--color-border-light);color:var(--color-text-secondary)}.btn-icon:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.btn-ghost{background:transparent;border:none;color:var(--color-text-secondary);padding:var(--spacing-2)}.btn-ghost:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.task-list-view{display:flex;flex-direction:column;gap:0;height:100%;min-height:0;overflow:hidden}.task-filter-header{flex-shrink:0;background:var(--color-bg-paper, #ffffff);padding:var(--spacing-4);border-bottom:1px solid var(--color-border-light);display:flex;flex-direction:column;gap:var(--spacing-3)}.filter-main-row{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.quick-filters{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap}.filter-chip{display:inline-flex!important;visibility:visible!important;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-subtle);border:1px solid var(--color-border-light);border-radius:var(--radius-full);cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap;flex-shrink:0;min-width:fit-content}.filter-chip:hover{background:var(--color-bg-paper);border-color:var(--color-border-medium);color:var(--color-text-primary)}.filter-chip.active{display:inline-flex!important;visibility:visible!important;background:var(--color-primary)!important;background-color:#265021!important;border-color:var(--color-primary)!important;border-color:#265021!important;color:#fff!important}.filter-chip.active:hover{background:var(--color-primary-600, #16a34a);border-color:var(--color-primary-600, #16a34a)}.filter-chip svg{opacity:.7;flex-shrink:0}.filter-chip.active svg{opacity:1}.filter-toggle-btn{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-left:auto}.filter-toggle-btn:hover{background:var(--color-bg-subtle);border-color:var(--color-border-medium)}.filter-toggle-btn.active{background:var(--color-bg-subtle);border-color:var(--color-primary);color:var(--color-primary)}.filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 var(--spacing-1);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:#fff;background:var(--color-primary);border-radius:var(--radius-full)}.filter-advanced-row{display:flex;align-items:flex-end;gap:var(--spacing-4);flex-wrap:wrap;padding-top:var(--spacing-3);border-top:1px solid var(--color-border-light)}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-1);min-width:160px}.filter-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.clear-filters-btn{color:var(--color-text-tertiary);text-decoration:underline;font-size:var(--font-size-sm)}.clear-filters-btn:hover{color:var(--color-text-secondary)}.filter-results-row{display:flex;align-items:center;justify-content:space-between;padding-top:var(--spacing-2)}.results-count .selection-info{color:var(--color-primary);font-weight:var(--font-weight-medium)}.filter-actions{display:flex;gap:var(--spacing-2)}.task-list-scrollable{flex:1;min-height:0;overflow-y:auto;padding:var(--spacing-4)}@media (max-width: 768px){.filter-main-row{flex-direction:column;align-items:stretch}.search-input-wrapper{max-width:none}.quick-filters{justify-content:flex-start}.filter-chip{padding:var(--spacing-2) var(--spacing-3)}.filter-toggle-btn{margin-left:0;justify-content:center}.filter-advanced-row{flex-direction:column;align-items:stretch}.filter-group{width:100%}}.search-input-wrapper{position:relative;flex:1;max-width:300px}.search-input-wrapper svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none}.search-input-wrapper .form-input{padding-left:36px}.results-count{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:var(--spacing-2) 0}.task-table{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);overflow:hidden}.task-table-header{display:grid;grid-template-columns:40px 2fr 100px 100px 150px 100px;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-subtle);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.task-table-row{display:grid;grid-template-columns:40px 2fr 100px 100px 150px 100px;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast)}.task-table-row:last-child{border-bottom:none}.task-table-row:hover{background:var(--color-primary-50, #f0fdf4)}.task-table-row.selected{background:var(--color-primary-100, #dcfce7)}.task-checkbox-col{width:40px;flex-shrink:0;justify-content:center}.task-checkbox-col input[type=checkbox]{width:16px;height:16px;cursor:pointer}.task-table-cell{display:flex;align-items:center;font-size:var(--font-size-sm);color:var(--color-text-primary);min-width:0}.task-title-col{font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-status-col .badge,.task-priority-col .badge{font-size:var(--font-size-xs)}@media (max-width: 768px){.task-table-header,.task-table-row{grid-template-columns:1fr;gap:var(--spacing-2)}.task-table-header{display:none}.task-table-cell:before{content:attr(data-label);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-right:var(--spacing-2);display:none}}.kanban-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-4);min-height:500px}.kanban-column{background:var(--color-bg-subtle);border-radius:var(--radius-lg);display:flex;flex-direction:column;min-height:400px}.kanban-column-header{padding:var(--spacing-3) var(--spacing-4);border-top:4px solid var(--color-primary-500);display:flex;justify-content:space-between;align-items:center}.kanban-column-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-sm)}.kanban-column-count{background:var(--color-bg-paper);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full)}.kanban-column-content{flex:1;padding:var(--spacing-2) var(--spacing-3);display:flex;flex-direction:column;gap:var(--spacing-2);overflow-y:auto}.kanban-card{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--spacing-3);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.kanban-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-md)}.kanban-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.kanban-card-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-2)}.kanban-card-meta .unassigned-text{color:var(--color-text-tertiary);font-style:italic}.task-calendar{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-4)}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-4)}.calendar-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.calendar-nav{display:flex;gap:var(--spacing-2)}.calendar-day-labels{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-1);margin-bottom:var(--spacing-2)}.calendar-day-label{text-align:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;padding:var(--spacing-2)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-1)}.calendar-day{min-height:100px;background:var(--color-bg-subtle);border-radius:var(--radius-sm);padding:var(--spacing-2);cursor:pointer;transition:background var(--transition-fast)}.calendar-day:hover{background:var(--color-primary-50, #f0fdf4)}.calendar-day.other-month{opacity:.4}.calendar-day.today{background:var(--color-primary-100);border:2px solid var(--color-primary-500)}.calendar-day-number{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.calendar-day-tasks{display:flex;flex-direction:column;gap:2px}.calendar-task{font-size:var(--font-size-xs);padding:2px var(--spacing-1);border-radius:2px;background:var(--color-primary-100);color:var(--color-primary-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.calendar-task-more{font-size:var(--font-size-xs);color:var(--color-text-secondary);padding:2px var(--spacing-1)}.task-statistics{display:flex;flex-direction:column;gap:var(--spacing-6)}.stats-summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-4)}@media (max-width: 768px){.stats-summary-row{grid-template-columns:repeat(2,1fr)}}.stats-card{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-4);text-align:center}.stats-card.warning{background:var(--color-warning-50, #fffbeb);border-color:var(--color-warning-200)}.stats-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-600);display:block}.stats-card.warning .stats-card-value{color:var(--color-warning-600, #d97706)}.stats-card-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.stats-card-pct{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.stats-charts-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-6)}@media (max-width: 768px){.stats-charts-row{grid-template-columns:1fr}}.stats-chart-card{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-4)}.stats-chart-card h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-4)}.bar-chart{display:flex;flex-direction:column;gap:var(--spacing-3)}.bar-chart-row{display:grid;grid-template-columns:80px 1fr 40px;gap:var(--spacing-3);align-items:center}.bar-chart-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.bar-chart-bar-wrapper{height:24px;background:var(--color-bg-subtle);border-radius:var(--radius-sm);overflow:hidden}.bar-chart-bar{height:100%;border-radius:var(--radius-sm);transition:width .3s ease}.bar-chart-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);text-align:right}.stats-team-section{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-4)}.stats-team-section h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-4)}.team-stats-table{display:flex;flex-direction:column}.team-stats-header{display:grid;grid-template-columns:1fr repeat(3,80px);gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.team-stats-row{display:grid;grid-template-columns:1fr repeat(3,80px);gap:var(--spacing-3);padding:var(--spacing-3);border-bottom:1px solid var(--color-border-light)}.team-stats-row:last-child{border-bottom:none}.team-member-name{display:flex;align-items:center;gap:var(--spacing-2);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.task-detail-modal{max-width:600px}.task-detail-modal .modal-header{display:flex;justify-content:space-between;align-items:flex-start}.task-detail-modal .modal-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;padding-right:var(--spacing-4)}.modal-close{background:transparent;border:none;font-size:var(--font-size-xl);color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-1);line-height:1}.modal-close:hover{color:var(--color-text-primary)}.task-detail-status{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md);margin-bottom:var(--spacing-4)}.task-blocked-badge{background:var(--color-error-100);color:var(--color-error-700);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.task-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-4)}.task-detail-label{display:block;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:var(--spacing-1)}.task-detail-section{margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.task-detail-section h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-3)}.task-detail-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.checklist-readonly{display:flex;flex-direction:column;gap:var(--spacing-2)}.checklist-readonly-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-primary)}.checklist-readonly-item.completed{color:var(--color-text-secondary);text-decoration:line-through}.dependencies-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.dependency-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-1)}.dependency-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-sm)}.dependency-title{font-size:var(--font-size-sm);color:var(--color-text-primary)}.dependency-remove{background:transparent;border:none;color:var(--color-error-500);cursor:pointer;padding:var(--spacing-1);font-size:var(--font-size-lg)}.dependency-remove:hover{color:var(--color-error-700)}.no-dependencies{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.dependency-add-form{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md);margin-top:var(--spacing-3)}.dependency-add-actions{display:flex;gap:var(--spacing-2);justify-content:flex-end}.blocked-list{background:var(--color-warning-50, #fffbeb);padding:var(--spacing-3);border-radius:var(--radius-md);margin-top:var(--spacing-3)}.watchers-list{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-top:var(--spacing-2)}.watcher-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-1) var(--spacing-2);background:var(--color-bg-subtle);border-radius:var(--radius-full);font-size:var(--font-size-sm)}.watcher-name{color:var(--color-text-primary)}.watcher-reason{color:var(--color-text-tertiary);font-size:var(--font-size-xs)}.no-watchers{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.time-summary{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-3);margin-bottom:var(--spacing-3)}.time-summary-row{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap}.time-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.time-value{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.time-progress{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-2)}.time-progress-bar{flex:1;height:8px;background:var(--color-border-main);border-radius:var(--radius-full);overflow:hidden}.time-progress-fill{height:100%;background:var(--color-primary-500);border-radius:var(--radius-full);transition:width .3s ease}.time-progress-percent{font-size:var(--font-size-sm);color:var(--color-text-secondary);min-width:40px;text-align:right}.timer-controls{margin-bottom:var(--spacing-3)}.timer-running{background:var(--color-success-50, #f0fdf4);border:1px solid var(--color-success-200, #bbf7d0);border-radius:var(--radius-md);padding:var(--spacing-3)}.timer-indicator{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.timer-pulse{width:12px;height:12px;background:var(--color-success-500);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.timer-elapsed{font-weight:var(--font-weight-semibold);color:var(--color-success-700, #15803d)}.timer-stop-form{display:flex;gap:var(--spacing-2)}.timer-stop-form .form-input{flex:1}.time-entries-list{margin-top:var(--spacing-3)}.time-entries-list h5{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.time-entry-item{padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-sm);margin-bottom:var(--spacing-2)}.time-entry-main{display:flex;justify-content:space-between;align-items:center}.time-entry-user{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.time-entry-duration{font-size:var(--font-size-sm);color:var(--color-primary-600);font-weight:var(--font-weight-semibold)}.time-entry-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.time-entry-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--spacing-1)}.checklist-progress{margin-bottom:var(--spacing-3)}.checklist-progress-bar{height:6px;background:var(--color-border-main);border-radius:var(--radius-full);overflow:hidden}.checklist-progress-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width .3s ease}.checklist-interactive{display:flex;flex-direction:column;gap:var(--spacing-1)}.checklist-item-btn{display:flex;align-items:center;gap:var(--spacing-3);width:100%;padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.checklist-item-btn:hover:not(:disabled){background:var(--color-bg-subtle);border-color:var(--color-primary-200, #bbf7d0)}.checklist-item-btn.completed{background:var(--color-success-50, #f0fdf4);border-color:var(--color-success-200, #bbf7d0)}.checklist-item-btn:disabled{cursor:default;opacity:.6}.checklist-item-btn .checkbox-icon{display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);flex-shrink:0}.checklist-item-btn.completed .checkbox-icon{color:var(--color-success-600, #16a34a)}.checklist-item-text{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary)}.checklist-item-btn.completed .checklist-item-text{text-decoration:line-through;color:var(--color-text-secondary)}.task-detail-tabs{display:flex;gap:var(--spacing-1);margin-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border-light)}.task-detail-tabs .tab-btn{padding:var(--spacing-2) var(--spacing-4);background:transparent;border:none;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;position:relative;transition:color var(--transition-fast)}.task-detail-tabs .tab-btn:hover{color:var(--color-text-primary)}.task-detail-tabs .tab-btn.active{color:var(--color-primary)}.task-detail-tabs .tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--color-primary);border-radius:var(--radius-full)}.comments-section{display:flex;flex-direction:column;gap:var(--spacing-3)}.comment-input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-2)}.comment-textarea{resize:none;min-height:60px}.comment-input-wrapper .btn{align-self:flex-end}.comments-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.comment-item{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-3)}.comment-header{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.comment-author{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.comment-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-left:auto}.comment-content{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.5;white-space:pre-wrap}.no-comments{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic;text-align:center;padding:var(--spacing-4)}.activity-feed{max-height:300px;overflow-y:auto}.activity-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.activity-item{display:flex;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-2);font-size:var(--font-size-sm)}.activity-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-subtle);border-radius:var(--radius-full);font-size:12px;flex-shrink:0}.activity-content{flex:1;display:flex;flex-direction:column;gap:2px}.activity-text{color:var(--color-text-primary)}.activity-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.no-activity{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic;text-align:center;padding:var(--spacing-4)}.task-action-footer{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-3)}.footer-left,.footer-right{display:flex;align-items:center;gap:var(--spacing-2)}.footer-right .btn{display:inline-flex;align-items:center;gap:var(--spacing-1)}.btn-danger{background-color:var(--color-error-600, #dc2626);border-color:var(--color-error-600, #dc2626);color:#fff}.btn-danger:hover{background-color:var(--color-error-700, #b91c1c);border-color:var(--color-error-700, #b91c1c)}.subtask-checkbox{color:var(--color-text-tertiary)}.subtask-checkbox.checked{color:var(--color-success-600, #16a34a)}.subtask-status{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:capitalize}.subtask-add-form{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md);margin-top:var(--spacing-2)}.parent-task-info{background:var(--color-info-light, #eff6ff);padding:var(--spacing-3);border-radius:var(--radius-md)}.parent-label{font-size:var(--font-size-sm);color:var(--color-info-dark, #1e40af)}.create-task-modal{max-width:560px}.modal-back-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;margin-right:var(--spacing-2);background:transparent;border:1px solid var(--color-border-light);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.modal-back-btn:hover{background:var(--color-bg-subtle);border-color:var(--color-border-medium);color:var(--color-text-primary)}.task-type-prompt{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--spacing-4);text-align:center}.task-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-3)}.task-type-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--color-bg-paper);border:2px solid var(--color-border-light);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center}.task-type-card:hover{border-color:var(--color-primary-300, #86efac);background:var(--color-primary-50, #f0fdf4)}.task-type-card.selected{border-color:var(--color-primary);background:var(--color-primary-50, #f0fdf4)}.task-type-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-primary-100, #dcfce7);border-radius:var(--radius-full);color:var(--color-primary)}.task-type-card:hover .task-type-icon,.task-type-card.selected .task-type-icon{background:var(--color-primary);color:#fff}.task-type-content{display:flex;flex-direction:column;gap:var(--spacing-1)}.task-type-title{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);color:var(--color-text-primary)}.task-type-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.4}.task-type-info-box{display:flex;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--color-info-light, #eff6ff);border:1px solid var(--color-info-main, #3b82f6);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-info-dark, #1e40af);margin-top:var(--spacing-4)}.task-type-info-box svg{flex-shrink:0;margin-top:2px}.more-options-section{margin-top:var(--spacing-4);border-top:1px solid var(--color-border-light);padding-top:var(--spacing-3)}.more-options-toggle{display:flex;align-items:center;gap:var(--spacing-2);background:none;border:none;padding:var(--spacing-2) 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast)}.more-options-toggle:hover{color:var(--color-text-primary)}.more-options-chevron{transition:transform var(--transition-fast)}.more-options-chevron.expanded{transform:rotate(180deg)}.more-options-content{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-3) 0}.more-option-item{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-2);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.more-option-item:hover{background:var(--color-bg-secondary)}.more-option-item input[type=checkbox]{width:18px;height:18px;margin-top:2px;flex-shrink:0;accent-color:var(--color-primary-500);cursor:pointer}.more-option-item .option-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);line-height:1.4}.more-option-item .option-hint{width:100%;padding-left:26px;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:0;line-height:1.4}@media (max-width: 480px){.task-type-grid{grid-template-columns:1fr}.task-type-card{flex-direction:row;text-align:left}.task-type-icon{width:40px;height:40px}}.form-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-1)}.form-label-row .form-label{margin-bottom:0}.field-remove-btn{background:none;border:none;padding:2px 6px;font-size:16px;line-height:1;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.field-remove-btn:hover{background:var(--color-error-light, #fef2f2);color:var(--color-error-500)}.add-field-menu-container{position:relative;margin-top:var(--spacing-3)}.add-field-trigger{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:none;border:1px dashed var(--color-border-main);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.add-field-trigger:hover{border-color:var(--color-primary-500);color:var(--color-primary-600, #166534);background:var(--color-primary-50, #f0fdf4)}.add-field-dropdown{position:absolute;bottom:100%;left:0;z-index:50;margin-bottom:4px;min-width:200px;background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-lg);box-shadow:0 4px 16px #0000001f;padding:var(--spacing-1)}.add-field-item{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);background:none;border:none;font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-fast)}.add-field-item:hover{background:var(--color-bg-subtle)}.add-field-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}.watcher-combo{position:relative}.watcher-tags-input{display:flex;flex-wrap:wrap;gap:6px;padding:6px 8px;min-height:38px;border:1px solid var(--color-border-main);border-radius:var(--radius-md);background:var(--color-bg-paper);cursor:text;align-items:center;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.watcher-tags-input:focus-within{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.watcher-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--color-primary-100, #dcfce7);color:var(--color-primary-700, #15803d);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap}.watcher-tag.locked{background:var(--color-bg-subtle);color:var(--color-text-secondary)}.watcher-tag-badge{font-size:10px;opacity:.7;margin-left:2px}.watcher-tag-remove{background:none;border:none;padding:0 2px;color:inherit;cursor:pointer;opacity:.6;font-size:14px;line-height:1}.watcher-tag-remove:hover{opacity:1}.watcher-search-input{border:none;outline:none;background:transparent;flex:1;min-width:80px;font-size:var(--font-size-sm);color:var(--color-text-primary);padding:2px 0}.watcher-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;margin-top:4px;background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001a;max-height:180px;overflow-y:auto}.watcher-dropdown-item{display:block;width:100%;padding:8px 12px;background:none;border:none;font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.watcher-dropdown-item:hover{background:var(--color-bg-subtle)}.photo-preview-row{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.photo-preview-thumb{position:relative;width:64px;height:64px;border-radius:var(--radius-md);overflow:hidden}.photo-preview-thumb img{width:100%;height:100%;object-fit:cover}.photo-remove-btn{position:absolute;top:2px;right:2px;width:20px;height:20px;background:#0009;color:#fff;border:none;border-radius:50%;font-size:12px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.photo-remove-btn:hover{background:#000c}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.form-input{width:100%;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-paper);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.error-message{padding:var(--spacing-3);background:var(--color-error-light);border:1px solid var(--color-error-main);border-radius:var(--radius-md);color:var(--color-error-dark);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4)}.checklist-builder{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-3)}.checklist-builder-items{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.checklist-builder-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2);background:var(--color-bg-paper);border-radius:var(--radius-sm)}.checklist-icon{color:var(--color-text-secondary);font-size:var(--font-size-sm);flex-shrink:0;width:16px;text-align:center}.checklist-builder-item span:nth-child(2){flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary)}.checklist-builder-remove{background:transparent;border:none;color:var(--color-error-500);cursor:pointer;padding:var(--spacing-1);font-size:var(--font-size-base);opacity:.6}.checklist-builder-remove:hover{opacity:1}.checklist-builder-add,.checklist-builder-input{display:flex;gap:var(--spacing-2)}.checklist-builder-add .form-input,.checklist-builder-input .form-input{flex:1}.templates-tab{display:flex;flex-direction:column;gap:var(--spacing-4);flex:1;min-height:0;overflow-y:auto;padding:var(--spacing-4)}.templates-header{display:flex;justify-content:space-between;align-items:flex-start}.templates-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-1) 0}.templates-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.templates-empty{text-align:center;padding:var(--spacing-12) var(--spacing-6);background:var(--color-bg-subtle);border-radius:var(--radius-lg)}.templates-empty-icon{font-size:3rem;margin-bottom:var(--spacing-4)}.templates-empty h4{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.templates-empty p{color:var(--color-text-secondary);margin-bottom:var(--spacing-4)}.templates-grid{display:flex;flex-direction:column;gap:var(--spacing-6)}.templates-category{display:flex;flex-direction:column;gap:var(--spacing-3)}.templates-category-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;padding-bottom:var(--spacing-2);border-bottom:1px solid var(--color-border-light)}.templates-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-4)}.template-card{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-4);transition:all var(--transition-fast)}.template-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-md)}.template-card-header{display:flex;align-items:flex-start;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.template-priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}.template-name{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.template-shared-badge{background:var(--color-info-100);color:var(--color-info-700);padding:2px var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.template-feature-tag{background:var(--color-warning-100, #fef3c7);color:var(--color-warning-700, #92400e);padding:2px var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.template-task-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.template-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-3)}.template-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-3);margin-bottom:var(--spacing-3)}.template-meta-item{font-size:var(--font-size-xs);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--spacing-1)}.template-actions{display:flex;gap:var(--spacing-2);padding-top:var(--spacing-3);border-top:1px solid var(--color-border-light)}.template-type-badge{display:inline-block;padding:2px 8px;background:var(--color-bg-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:capitalize}.template-feature-badge{color:var(--color-primary-600);font-weight:var(--font-weight-medium)}.feature-toggles{display:flex;flex-direction:column;gap:var(--spacing-2);margin-top:var(--spacing-1)}.feature-toggle{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-secondary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.feature-toggle:hover{background:var(--color-bg-tertiary)}.feature-toggle input[type=checkbox]{width:18px;height:18px;margin:0;flex-shrink:0;accent-color:var(--color-primary-500);cursor:pointer}.feature-toggle span{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1}.use-template-preview{padding:var(--spacing-3);background:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-4)}.use-template-preview .preview-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.use-template-preview .preview-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.form-section-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-4)}.settings-tab{max-width:600px}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6)}.settings-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.settings-saving,.settings-saved{font-size:var(--font-size-sm);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full)}.settings-saving{color:var(--color-warning-700);background:var(--color-warning-100)}.settings-saved{color:var(--color-success-700);background:var(--color-success-100)}.settings-section{margin-bottom:var(--spacing-6)}.settings-section h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.settings-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-4)}.settings-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.settings-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md)}.settings-item-content{flex:1}.settings-item-label{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.settings-item-description{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.settings-timing{max-width:200px}.settings-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-style:italic;margin-top:var(--spacing-4)}.settings-nav{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border-light)}.settings-nav-btn{padding:var(--spacing-2) var(--spacing-4);background:transparent;border:1px solid var(--color-border-main);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.settings-nav-btn:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.settings-nav-btn.active{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-700)}.autorules-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.autorule-item{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.autorule-info{flex:1}.autorule-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.autorule-type{font-size:var(--font-size-xs);color:var(--color-primary-600);background:var(--color-primary-50);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);display:inline-block;margin-bottom:var(--spacing-2)}.autorule-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-1)}.autorule-last-triggered{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.autorule-actions{display:flex;align-items:center;gap:var(--spacing-3)}.archive-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.archive-stat{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-4);text-align:center}.archive-stat-value{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-600);margin-bottom:var(--spacing-1)}.archive-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.archive-info{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-4)}.archive-info h4{margin-bottom:var(--spacing-2)}.archive-info ul{margin:0;padding-left:var(--spacing-4)}.archive-info li{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-1)}.empty-state{text-align:center;padding:var(--spacing-8);color:var(--color-text-secondary);font-style:italic}.subtasks-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.subtask-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-sm)}.subtask-item.completed{opacity:.7}.subtask-item.completed .subtask-title{text-decoration:line-through;color:var(--color-text-secondary)}.subtask-checkbox{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);border:2px solid var(--color-border-main);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.subtask-checkbox.checked{background:var(--color-success-500);border-color:var(--color-success-500);color:#fff}.subtask-title{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary)}.subtask-status{font-size:var(--font-size-xs);text-transform:capitalize;color:var(--color-text-tertiary)}.subtask-add-form{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.subtask-add-actions{display:flex;gap:var(--spacing-2);justify-content:flex-end}.no-subtasks{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.parent-task-info{background:var(--color-bg-subtle);padding:var(--spacing-3);border-radius:var(--radius-md)}.parent-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-neutral-300);transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary-500)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.modal-lg{max-width:700px}.form-section{margin-bottom:var(--spacing-6)}.form-section:last-child{margin-bottom:0}.form-section-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-2);border-bottom:1px solid var(--color-border-light)}.custom-select{position:relative;display:inline-block;min-width:140px}.custom-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-2);width:100%;height:40px;padding:0 var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);background:var(--color-bg-paper);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);text-align:left}.custom-select-trigger:hover:not(.disabled){border-color:var(--color-border-dark)}.custom-select-trigger:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.custom-select-trigger.open{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.custom-select-trigger.disabled{background:var(--color-bg-subtle);color:var(--color-text-secondary);cursor:not-allowed}.custom-select-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select-placeholder{color:var(--color-text-tertiary)}.custom-select-chevron{flex-shrink:0;color:var(--color-text-secondary);transition:transform var(--transition-fast)}.custom-select-chevron.open{transform:rotate(180deg)}.custom-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:280px;overflow-y:auto}.custom-select-options{padding:var(--spacing-1)}.custom-select-option{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);border:none;border-radius:var(--radius-sm);background:transparent;font-family:inherit;font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.custom-select-option:hover{background:var(--color-bg-subtle)}.custom-select-option.selected{background:var(--color-primary-50);color:var(--color-primary-700);font-weight:var(--font-weight-medium)}.custom-select-option-content{display:flex;align-items:center;gap:var(--spacing-2)}.custom-select-option-icon{display:flex;align-items:center;color:var(--color-text-secondary)}.custom-select-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.custom-select-sm .custom-select-trigger{height:32px;padding:0 var(--spacing-2);font-size:var(--font-size-sm)}.custom-select-sm .custom-select-option{padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs)}.user-select{position:relative;display:inline-block;width:100%}.user-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-2);width:100%;height:40px;padding:0 var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);background:var(--color-bg-paper);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.user-select-trigger:hover{border-color:var(--color-border-dark)}.user-select-trigger:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.user-select-value{display:flex;align-items:center;gap:var(--spacing-2);flex:1;overflow:hidden}.user-select-value span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-select-placeholder{color:var(--color-text-tertiary)}.user-select-chevron{flex-shrink:0;color:var(--color-text-secondary);transition:transform var(--transition-fast)}.user-select-chevron.open{transform:rotate(180deg)}.user-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:300px;overflow:hidden;display:flex;flex-direction:column}.user-select-search{padding:var(--spacing-2);border-bottom:1px solid var(--color-border-light)}.user-select-search-input{width:100%;height:36px;padding:0 var(--spacing-3);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-subtle)}.user-select-search-input:focus{outline:none;border-color:var(--color-primary-500);background:var(--color-bg-paper)}.user-select-options{overflow-y:auto;padding:var(--spacing-1);max-height:240px}.user-select-option{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);border:none;border-radius:var(--radius-sm);background:transparent;font-family:inherit;font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.user-select-option:hover{background:var(--color-bg-subtle)}.user-select-option.selected{background:var(--color-primary-50);color:var(--color-primary-700);font-weight:var(--font-weight-medium)}.user-select-option-avatar.empty{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-bg-subtle);color:var(--color-text-tertiary)}.user-select-empty{padding:var(--spacing-4);text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.user-multi-select{position:relative;width:100%}.user-multi-select-trigger{display:flex;align-items:center;gap:var(--spacing-2);min-height:42px;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);background:var(--color-bg-paper);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.user-multi-select-trigger:hover{border-color:var(--color-border-dark)}.user-multi-select-trigger.focused{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.user-multi-chips-area{display:flex;flex-wrap:wrap;align-items:center;gap:6px;flex:1;min-width:0}.user-multi-placeholder{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.user-multi-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px 3px 3px;border-radius:999px;background:var(--color-primary-50);border:1px solid var(--color-primary-200);font-size:var(--font-size-sm);color:var(--color-primary-700);white-space:nowrap;line-height:1.4}.user-multi-chip.locked{background:var(--color-bg-subtle);border-color:var(--color-border-light);color:var(--color-text-secondary);padding-right:8px}.user-multi-chip-name{max-width:100px;overflow:hidden;text-overflow:ellipsis}.user-multi-chip-badge{font-size:10px;opacity:.7;padding:1px 5px;background:#0000000f;border-radius:4px}.user-multi-chip-remove{background:none;border:none;padding:0 2px;cursor:pointer;font-size:14px;line-height:1;color:var(--color-primary-500);opacity:.6;transition:opacity var(--transition-fast)}.user-multi-chip-remove:hover{opacity:1}.user-display{display:inline-flex;align-items:center;gap:var(--spacing-2)}.user-display.unassigned{color:var(--color-text-tertiary)}.user-display-avatar-placeholder{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-bg-subtle);color:var(--color-text-tertiary)}.user-display-name{font-size:var(--font-size-sm);color:inherit}.user-display-inline{display:inline-flex;align-items:center;gap:var(--spacing-1);font-size:var(--font-size-sm)}.user-display-inline.unassigned{color:var(--color-text-tertiary)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex-shrink:0;font-weight:var(--font-weight-medium);color:#fff}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-initials{text-transform:uppercase}.avatar-xs{width:20px;height:20px;font-size:9px}.avatar-sm{width:28px;height:28px;font-size:11px}.avatar-md{width:36px;height:36px;font-size:14px}.avatar-lg{width:48px;height:48px;font-size:18px}.avatar-xl{width:64px;height:64px;font-size:24px}.avatar-group{display:inline-flex;flex-direction:row-reverse}.avatar-group .avatar{margin-left:-8px;border:2px solid var(--color-bg-paper)}.avatar-group .avatar:last-child{margin-left:0}.avatar-more{background:var(--color-bg-subtle);color:var(--color-text-secondary);font-size:10px}.form-input{height:40px}.form-input-sm{height:32px;padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-sm)}textarea.form-input{height:auto;min-height:80px;resize:vertical}select.form-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.master-data-dashboard{display:flex;flex-direction:column;gap:var(--spacing-6)}.master-data-section{display:flex;flex-direction:column;gap:var(--spacing-4)}.master-data-section .section-header{margin-bottom:0;padding-bottom:var(--spacing-2)}.master-data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-4)}.master-data-card{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-left:4px solid var(--card-accent, var(--color-primary-500));border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.master-data-card:hover{border-color:var(--card-accent, var(--color-primary-500));box-shadow:var(--shadow-sm);transform:translateY(-1px)}.master-data-card-icon{font-size:2rem;flex-shrink:0}.master-data-card-content{flex:1;min-width:0}.master-data-card-content h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-1) 0}.master-data-card-content p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.master-data-card-count{display:flex;align-items:baseline;gap:var(--spacing-1);flex-shrink:0}.master-data-card-count .count-active{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.master-data-card-count .count-total{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.master-data-list{display:flex;flex-direction:column}.master-data-list-item{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast)}.master-data-list-item:last-child{border-bottom:none}.master-data-list-item:hover{background:var(--color-primary-50, #f0fdf4)}.master-data-list-item.inactive{opacity:.6;background:var(--color-bg-subtle)}.master-data-list-item.inactive:hover{background:var(--color-bg-default)}.master-data-list-item .item-main{flex:1;display:flex;align-items:center;gap:var(--spacing-3);min-width:0}.master-data-list-item .item-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.master-data-list-item .item-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.master-data-list-item .item-code{font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-bg-subtle);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm)}.master-data-list-item .item-type-badge{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-bg-default);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);text-transform:capitalize}.master-data-list-item .item-status{flex-shrink:0}.master-data-list-item .item-actions{display:flex;gap:var(--spacing-1);flex-shrink:0}.category-header{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4)}.category-header-icon{font-size:2.5rem}.category-header-content h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-1) 0}.category-header-content p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.color-picker{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.color-swatch{width:32px;height:32px;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:var(--color-text-primary);box-shadow:0 0 0 2px var(--color-bg-paper),0 0 0 4px var(--color-text-primary)}.color-swatch.clear{background:var(--color-bg-subtle);border:1px dashed var(--color-border-default);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:var(--font-size-xs)}.list-select{display:flex;flex-direction:column;gap:var(--spacing-1)}.list-select-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.list-select-label .required{color:var(--color-error-500);margin-left:var(--spacing-1)}.list-select-container{display:flex;gap:var(--spacing-2)}.list-select-input{flex:1;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg-paper)}.list-select-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.list-select-add-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-primary-500);background:var(--color-bg-paper);color:var(--color-primary-500);border-radius:var(--radius-md);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-fast)}.list-select-add-btn:hover{background:var(--color-primary-50)}.empty-state .empty-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-3)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.modal-sm{max-width:360px}.btn-danger:hover{background:var(--color-error-50);color:var(--color-error-600)}.btn-ghost{background:transparent;border:none;padding:var(--spacing-1) var(--spacing-2)}.btn-ghost:hover{background:var(--color-bg-subtle)}@media (max-width: 768px){.master-data-grid{grid-template-columns:1fr}.master-data-card{padding:var(--spacing-3)}.master-data-list-item{flex-wrap:wrap}.master-data-list-item .item-actions{width:100%;margin-top:var(--spacing-2);justify-content:flex-end}.category-header{flex-direction:column;text-align:center}}.field-map-container{display:flex;flex-direction:column;gap:var(--spacing-4)}.field-map{border-radius:var(--radius-lg);border:1px solid var(--color-border-light);overflow:hidden}.field-map-popup{min-width:150px}.field-map-popup .popup-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.field-map-popup .popup-code{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.field-map-popup .popup-info{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-3)}.field-map-popup .popup-info p{margin:var(--spacing-1) 0}.field-map-popup .popup-button{width:100%}.field-map-legend{background:var(--color-bg-paper);border-radius:var(--radius-md);padding:var(--spacing-3);border:1px solid var(--color-border-light)}.field-map-legend h5{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.field-map-legend .legend-items{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.field-map-legend .legend-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);background:var(--color-bg-subtle);cursor:pointer;transition:background .2s}.field-map-legend .legend-item:hover{background:var(--color-bg-default)}.field-map-legend .legend-item.selected{background:var(--color-primary-50);border:1px solid var(--color-primary-500)}.field-map-legend .legend-color{width:12px;height:12px;border-radius:var(--radius-sm)}.field-map-legend .legend-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.field-map-legend .legend-area{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.field-map-unmapped{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-3)}.field-map-unmapped h5{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.field-map-unmapped .unmapped-hint{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-bottom:var(--spacing-2)}.field-map-unmapped .unmapped-list{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.field-map-unmapped .unmapped-field{display:inline-block;padding:var(--spacing-1) var(--spacing-2);background:var(--color-bg-paper);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.boundary-editor{display:flex;flex-direction:column;gap:var(--spacing-4)}.boundary-editor__header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-3)}.boundary-editor__header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.boundary-editor__toolbar{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md)}.boundary-editor__toolbar .toolbar-divider{width:1px;height:20px;background:var(--color-border-main)}.boundary-editor__toolbar .toolbar-info{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.boundary-editor__hint{padding:var(--spacing-3);background:var(--color-info-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-info-dark)}.boundary-editor__map{border-radius:var(--radius-lg);border:1px solid var(--color-border-light);overflow:hidden}.boundary-editor__footer{display:flex;justify-content:flex-end;gap:var(--spacing-2)}.boundary-vertex-marker{background:transparent!important;border:none!important}.boundary-vertex-marker .vertex-dot{width:14px;height:14px;background:var(--color-primary-500);border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:move}.boundary-add-marker{background:transparent!important;border:none!important}.boundary-add-marker .add-dot{width:18px;height:18px;background:var(--color-primary-100);border:2px dashed var(--color-primary-500);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--color-primary-500);cursor:pointer}.boundary-add-marker .add-dot:hover{background:var(--color-primary-200)}.area-display{display:flex;align-items:baseline;gap:var(--spacing-2)}.area-display__label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.area-display__value{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-500)}.area-display__secondary{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.area-display--empty .area-display__value{color:var(--color-text-tertiary)}.btn-map-view{display:inline-flex;align-items:center;gap:var(--spacing-2)}.boundary-badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);background:var(--color-success-light);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-success-dark)}.boundary-badge--empty{background:var(--color-neutral-200);color:var(--color-text-secondary)}.map-modal{max-width:900px!important}.map-modal .modal-body{padding:var(--spacing-4)}.linked-tasks{margin-top:var(--spacing-4);padding:var(--spacing-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px}.linked-tasks h4{margin:0 0 var(--spacing-2) 0;font-size:.875rem;font-weight:600;color:var(--color-text-secondary)}.linked-task-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-2);border-radius:6px;transition:background .15s}.linked-task-item:hover{background:var(--color-neutral-100)}.linked-task-item+.linked-task-item{border-top:1px solid var(--color-border-light)}.linked-task-item .task-title{flex:1;font-size:.875rem;font-weight:500;color:var(--color-text)}.linked-task-item .task-status{font-size:.75rem;text-transform:capitalize;color:var(--color-text-secondary)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.status-pending{background-color:var(--color-warning, #f59e0b)}.status-dot.status-in_progress{background-color:var(--color-info, #3b82f6)}.status-dot.status-pending_review{background-color:#8b5cf6}.status-dot.status-completed{background-color:var(--color-success, #22c55e)}.status-dot.status-rejected{background-color:var(--color-danger, #ef4444)}.status-dot.status-cancelled{background-color:var(--color-neutral-400, #9ca3af)}.linked-record-info-bar{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);margin-bottom:var(--spacing-3);background:var(--color-neutral-100);border:1px solid var(--color-border);border-radius:6px;font-size:.875rem}.linked-record-info-bar .linked-label{color:var(--color-text-secondary);font-weight:500}.linked-record-info-bar .linked-value{color:var(--color-text);font-weight:600}.source-record-link{display:flex;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-2);border:1px solid var(--color-border);border-radius:6px;background:var(--color-neutral-50);color:var(--color-primary)!important;font-size:.8125rem;font-weight:500;text-align:left;line-height:1.4;cursor:pointer;transition:background .15s,border-color .15s;text-decoration:none!important;width:100%}.source-record-link:hover{background:var(--color-primary-light, #eff6ff);border-color:var(--color-primary)}.source-record-link svg{flex-shrink:0;margin-top:1px}.sidebar-source-title{font-size:.8125rem;color:var(--color-text-secondary)}.notification-bell-container{position:relative}.notification-bell-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:#ffffff26;color:#fff;cursor:pointer;transition:all .15s ease;position:relative}.notification-bell-button:hover{background:#ffffff40;border-color:#ffffff80}.notification-bell-icon{width:20px;height:20px}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1}.notification-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:480px;background:#fff;border-radius:var(--radius-lg);box-shadow:0 10px 40px #00000026,0 2px 8px #0000001a;z-index:100;overflow:hidden;display:flex;flex-direction:column}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border)}.notification-header h3{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.notification-mark-all-read{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-sm);cursor:pointer;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm)}.notification-mark-all-read:hover{background:var(--color-bg-secondary)}.notification-list{overflow-y:auto;max-height:420px}.notification-loading,.notification-empty{padding:var(--spacing-8) var(--spacing-4);text-align:center;color:var(--color-text-secondary)}.notification-empty-icon{font-size:2rem;display:block;margin-bottom:var(--spacing-2)}.notification-empty p{margin:0;font-size:var(--font-size-sm)}.notification-item{display:flex;align-items:flex-start;gap:var(--spacing-3);width:100%;padding:var(--spacing-3) var(--spacing-4);border:none;border-bottom:1px solid var(--color-border);background:none;cursor:pointer;text-align:left;transition:background .1s ease}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--color-bg-secondary)}.notification-item.unread{background:#3b82f60a}.notification-item.unread:hover{background:#3b82f614}.notification-item-icon{flex-shrink:0;font-size:1.125rem;line-height:1;margin-top:2px}.notification-item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notification-item-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.notification-item-message{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-item-time{font-size:.6875rem;color:var(--color-text-tertiary)}.notification-unread-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:var(--color-primary);margin-top:6px}
