*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#f8fafc;color:#0f172a;overflow:hidden;height:100vh}body.dark{background:#0f172a;color:#e2e8f0}.app-logo{height:28px;width:auto;vertical-align:middle;margin-right:6px}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#f1f5f9,#cbd5e1)}.auth-card{background:#fff;border-radius:24px;padding:24px;width:100%;max-width:360px;box-shadow:0 10px 25px -5px #0000001a}.auth-card h2{margin:0 0 4px;font-size:1.5rem}.auth-card p{margin-bottom:16px;color:#475569}.toggle-group{display:flex;gap:8px;background:#f1f5f9;padding:3px;border-radius:40px;margin-bottom:20px}.toggle-btn{flex:1;padding:6px;border-radius:30px;font-size:.8rem;font-weight:600;cursor:pointer;background:transparent;border:none}.toggle-btn.active{background:#2563eb;color:#fff}.auth-card input{width:100%;padding:10px 12px;margin:8px 0;border:1px solid #cbd5e1;border-radius:20px}.auth-card button[type=submit]{width:100%;background:#2563eb;color:#fff;border:none;padding:10px;border-radius:30px;font-weight:600;cursor:pointer;margin-top:12px}.error-message{color:#dc2626;font-size:.7rem;text-align:center;margin-top:8px}.feature-badge{display:flex;justify-content:center;gap:12px;margin-top:20px;flex-wrap:wrap}.feature-badge span{background:#f1f5f9;padding:4px 8px;border-radius:20px;font-size:.65rem}.app{height:100vh;display:flex;flex-direction:column}.main-header{position:fixed;top:0;left:0;right:0;background:#fff;color:#0f172a;padding:4px 12px;display:flex;justify-content:space-between;align-items:center;z-index:100;box-shadow:0 2px 6px #0000001a;flex-wrap:wrap;gap:8px}body.dark .main-header{background:#1e293b;color:#e2e8f0}.header-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.header-right{display:flex;align-items:right;gap:8px;flex-wrap:nowrap;overflow-x:auto;white-space:nowrap}.project-info{background:#e2e8f0;padding:2px 8px;border-radius:16px;font-size:.7rem}body.dark .project-info{background:#334155}.plan-dropdown{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:20px;padding:4px 8px;font-size:.7rem}body.dark .plan-dropdown{background:#0f172a;border-color:#334155;color:#fff}@media (min-width: 700px){.header-left{flex-wrap:nowrap}.header-left .plan-dropdown{margin-left:6px}}.delete-plan-btn{background:none;border:none;cursor:pointer;color:#ef4444;font-size:.8rem}.header-btn,.mode-btn,.menu-btn{background:#f1f5f9;border:1px solid #cbd5e1;padding:4px 10px;border-radius:20px;cursor:pointer;font-size:.7rem}body.dark .header-btn,body.dark .mode-btn,body.dark .menu-btn{background:#0f172a;border-color:#334155;color:#e2e8f0}.mode-btn.active{background:#10b981;color:#fff;border-color:#10b981}body.dark .dropdown-menu{background:#1e293b;border-color:#334155}.dropdown-menu ul{list-style:none;margin:0;padding:8px 0}.dropdown-menu li{padding:6px 16px;cursor:pointer;font-size:.75rem}.dropdown-menu li:hover{background:#f1f5f9}body.dark .dropdown-menu li:hover{background:#334155}.dropdown-divider{height:1px;background:#e2e8f0;margin:6px 0}body.dark .dropdown-divider{background:#334155}.canvas-area{flex:1;overflow:auto;margin-top:48px;background:#e2e8f0;position:relative}body.dark .canvas-area{background:#0f172a}.panel-header{display:flex;justify-content:space-between;align-items:center;background:#f1f5f9;border-radius:12px;padding:6px 10px;margin-bottom:8px;font-weight:600;color:#0f172a}body.dark .panel-header{background:#1e293b;color:#e2e8f0}.right-panel{position:fixed;bottom:12px;right:70px;width:280px;max-height:55vh;background:#fff;border-radius:16px;overflow-y:auto;z-index:90;border:1px solid #e2e8f0;font-size:.75rem;display:flex;flex-direction:column;gap:8px}body.dark .right-panel{background:#1e293b;border-color:#334155}.pins-section,.lines-section{width:100%;flex-shrink:0;padding:10px}.pins-section{border-bottom:1px solid #e2e8f0;margin-bottom:4px}body.dark .pins-section{border-bottom-color:#334155}.list-header-row{display:flex;align-items:center;gap:8px;font-weight:600;padding:6px 0;border-bottom:1px solid #e2e8f0;margin-top:8px}body.dark .list-header-row{border-bottom-color:#334155}.list-header-row>div:first-child{width:30px}.list-header-row>div:nth-child(2){flex:2}.list-header-row>div:nth-child(3){flex:1}.list-header-row>div:last-child{text-align:right}.pin-item,.line-item{background:#fafafa;margin:8px 0;padding:8px;border-radius:8px;border-left:4px solid;display:flex;align-items:center;gap:8px;flex-wrap:wrap}body.dark .pin-item,body.dark .line-item{background:#0f172a}.pin-summary{flex:2;min-width:150px}.pin-meta{flex:1}.pin-item-actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}.pin-metadata{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px;font-size:.65rem}.pin-tag{background:#e2e8f0;padding:2px 6px;border-radius:12px}body.dark .pin-tag{background:#334155}.pin-assignee{color:#475569}body.dark .pin-assignee{color:#94a3b8}.pin-due{color:#475569}.pin-due.overdue{color:#dc2626;font-weight:700}.pin-summary .coordinates{font-size:.7rem;color:#475569;margin-left:8px}.pin-note{font-size:.7rem;color:#475569}body.dark .pin-note{color:#94a3b8}.status-badge{padding:2px 8px;border-radius:20px;font-size:.7rem}.status-badge.open{background:#dc2626;color:#fff}.status-badge.in-progress{background:#f59e0b;color:#1e293b}.status-badge.completed{background:#10b981;color:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.modal-content{background:#fff;border-radius:16px;padding:20px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto}body.dark .modal-content{background:#1e293b;color:#fff}.detail-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:210}.detail-modal{background:#fff;border-radius:18px;padding:16px;width:min(380px,calc(100% - 32px));box-shadow:0 16px 40px #0f172a2e}body.dark .detail-modal{background:#0f172a;color:#e2e8f0}.detail-modal label{display:block;font-size:.78rem;color:#475569;margin-bottom:10px}body.dark .detail-modal label{color:#cbd5e1}.detail-modal textarea,.detail-modal select{width:100%;border:1px solid #cbd5e1;border-radius:12px;padding:8px 10px;margin-top:6px;background:#f8fafc;color:#0f172a}body.dark .detail-modal textarea,body.dark .detail-modal select{background:#1e293b;border-color:#334155;color:#e2e8f0}.detail-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.detail-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px}.detail-modal button{border:none;border-radius:999px;padding:8px 14px;cursor:pointer;background:#e2e8f0;color:#0f172a}.detail-modal button.danger{background:#f87171;color:#fff}.line-detail-panel{position:fixed;top:90px;right:20px;width:280px;background:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(148,163,184,.2);border-radius:18px;padding:14px;z-index:95;box-shadow:0 18px 40px #0f172a1f}body.dark .line-detail-panel{background:#1e293b;border-color:#334155}.line-detail-panel input,.line-detail-panel textarea,.line-detail-panel select{width:100%;border-radius:12px;border:1px solid #cbd5e1;padding:8px 10px;margin-top:6px}body.dark .line-detail-panel input,body.dark .line-detail-panel textarea,body.dark .line-detail-panel select{background:#1e293b;color:#fff;border-color:#334155}.line-detail-panel button{border:none;border-radius:999px;padding:8px 12px;cursor:pointer;background:#e2e8f0;color:#0f172a}.line-detail-panel button.danger{background:#f87171;color:#fff}.plan-manager-modal{width:80%;max-width:900px;height:80%;max-height:80vh;display:flex;flex-direction:column;background:#fff;border-radius:16px;overflow:hidden}body.dark .plan-manager-modal{background:#1e293b}.plan-manager-layout{display:flex;gap:20px;flex:1;overflow:hidden;padding:0 20px 20px}.plan-tree{width:30%;border-right:1px solid #e2e8f0;overflow-y:auto;padding-right:12px}body.dark .plan-tree{border-right-color:#334155}.plan-tree h4{margin-top:0}.plan-tree-item{padding:6px 8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;border-radius:6px;background:#f1f5f9;margin:4px 0}body.dark .plan-tree-item{background:#0f172a}.plan-tree-item:hover{background:#e2e8f0}body.dark .plan-tree-item:hover{background:#334155}.plan-tree-item.selected{background:#2563eb;color:#fff}.delete-plan-btn-small{background:none;border:none;cursor:pointer;font-size:.8rem;opacity:.6}.delete-plan-btn-small:hover{opacity:1}.plan-details{flex:1;overflow-y:auto;background:#fff;border-radius:12px;padding:12px}body.dark .plan-details{background:#0f172a}.status-filter{margin:12px 0}.pins-lines-summary{display:flex;gap:20px;margin:12px 0}.pins-lines-summary>div{flex:1}.pin-summary-item,.line-summary-item{padding:4px 0;display:flex;align-items:center;gap:6px;font-size:.8rem;cursor:pointer}.status-dot{width:10px;height:10px;border-radius:10px;display:inline-block}.status-dot.open{background:#dc2626}.status-dot.in-progress{background:#f59e0b}.status-dot.completed{background:#10b981}.plan-actions{margin-top:16px;display:flex;gap:12px}.tree-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.upload-plan-btn{background:#2563eb;color:#fff;border:none;border-radius:20px;padding:2px 10px;cursor:pointer;font-size:.8rem}.canvas-container{position:relative;width:100%;min-height:100%;background:#e2e8f0;overflow:auto;cursor:crosshair}body.dark .canvas-container{background:#0f172a}.plan-wrapper{position:absolute}.resize-handle{position:absolute;bottom:0;right:0;width:12px;height:12px;background:#2563eb;cursor:se-resize}.pin-marker{position:absolute;width:20px;height:20px;border-radius:50%;border:2px solid white;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;cursor:pointer;z-index:20}.pin-marker.selected{box-shadow:0 0 0 3px #fffc,0 0 0 4px #3b82f6e6}.pin-tooltip{position:absolute;top:26px;left:50%;transform:translate(-50%);padding:4px 8px;background:#0f172af2;color:#fff;border-radius:8px;font-size:.6rem;white-space:nowrap;pointer-events:none;z-index:40}.pin-cursor-preview{position:absolute;width:24px;height:24px;border:2px solid #2563eb;border-radius:50%;background:#2563eb26;pointer-events:none;z-index:40}.line-svg{position:absolute;top:0;left:0;pointer-events:none}.save-position-btn{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#10b981;color:#fff;border:none;padding:6px 16px;border-radius:30px;cursor:pointer;z-index:50}.line-controls{position:fixed;bottom:90px;left:50%;transform:translate(-50%);z-index:120;display:flex;gap:10px;background:#fffffff2;padding:10px 12px;border-radius:999px;box-shadow:0 12px 30px #0f172a2e}.line-controls button{background:#111827;color:#fff;border:none;padding:8px 14px;border-radius:999px;cursor:pointer;font-weight:600}.line-controls button:last-child{background:#ef4444}.modal-card{width:min(520px,calc(100% - 32px));background:#fff;border-radius:18px;padding:24px;box-shadow:0 32px 80px #0f172a33}body.dark .modal-card{background:#0f172a;color:#e2e8f0}.modal-card h3{margin:0 0 12px}.modal-card label{display:block;margin-top:12px;font-size:.85rem;font-weight:600;color:#334155}body.dark .modal-card label{color:#cbd5e1}.modal-card textarea,.modal-card input,.modal-card select{width:100%;margin-top:6px;padding:10px 12px;border-radius:12px;border:1px solid #cbd5e1;background:#f8fafc;color:#0f172a;font-size:.95rem}body.dark .modal-card textarea,body.dark .modal-card input,body.dark .modal-card select{background:#111827;border-color:#334155;color:#e2e8f0}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.primary-btn{background:#2563eb;color:#fff;border:none;border-radius:999px;padding:10px 16px;cursor:pointer}.secondary-btn{background:#e2e8f0;color:#0f172a;border:none;border-radius:999px;padding:10px 16px;cursor:pointer}body.dark .secondary-btn{background:#1e293b;color:#e2e8f0}.empty-canvas{text-align:center;padding:60px;color:#64748b}.online-btn{background:#2563eb;border-radius:30px;padding:2px 10px;cursor:pointer;font-size:.7rem;color:#fff;border:none;margin-left:8px}.online-modal{width:90%;max-width:350px}.online-user-item{padding:8px;border-bottom:1px solid #e2e8f0}body.dark .online-user-item{border-bottom-color:#334155}.empty-state{text-align:center;padding:16px;color:#64748b}.pin-detail-field,.detail-field{margin-bottom:16px}.pin-detail-field label,.detail-field label{display:block;font-weight:600;margin-bottom:4px}.replies-list{max-height:200px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:8px;padding:8px}body.dark .replies-list{border-color:#334155}.reply-item{border-bottom:1px solid #e2e8f0;padding:8px 0}body.dark .reply-item{border-bottom-color:#334155}.reply-text{margin-bottom:4px}.reply-meta{display:flex;gap:12px;font-size:.65rem;color:#475569;align-items:center}.delete-reply-btn{background:none;border:none;cursor:pointer;color:#ef4444;font-size:.8rem}.add-reply{display:flex;flex-direction:column;gap:8px}.modal-buttons{margin-top:16px;display:flex;justify-content:flex-end}.delete-pin-btn,.delete-btn{background:#dc2626;color:#fff;border:none;padding:6px 12px;border-radius:20px;cursor:pointer}.points-list{background:#f1f5f9;border-radius:8px;padding:8px;max-height:150px;overflow-y:auto}.point-item{font-size:.7rem;padding:4px;border-bottom:1px solid #e2e8f0}.pin-detail-modal,.line-detail-modal{max-width:550px}.pin-detail-modal .modal-body,.line-detail-modal .modal-body{padding:20px}.tag-filter-bar{position:fixed;top:56px;left:0;right:70px;background:#fff;padding:6px 12px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;z-index:89;border-bottom:1px solid #e2e8f0;font-size:.75rem}body.dark .tag-filter-bar{background:#1e293b;border-bottom-color:#334155}.tag-chip{background:#f1f5f9;padding:2px 10px;border-radius:20px;cursor:pointer;transition:.1s}body.dark .tag-chip{background:#0f172a;color:#e2e8f0}.tag-chip.active{background:#2563eb;color:#fff}.clear-tags{background:#64748b;border:none;color:#fff;padding:2px 8px;border-radius:16px;cursor:pointer}.bulk-toolbar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#fff;border:1px solid #e2e8f0;border-radius:40px;padding:8px 16px;display:flex;gap:12px;align-items:center;z-index:100;box-shadow:0 4px 12px #0003}body.dark .bulk-toolbar{background:#1e293b;border-color:#334155}.selection-count{font-weight:600}.bulk-actions{display:flex;gap:8px;flex-wrap:wrap}.bulk-actions button,.bulk-actions select,.bulk-actions input{padding:4px 8px;border-radius:30px;border:1px solid #e2e8f0;background:#fff;color:#0f172a}body.dark .bulk-actions button,body.dark .bulk-actions select,body.dark .bulk-actions input{background:#0f172a;border-color:#334155;color:#e2e8f0}.bulk-actions .danger{background:#ef4444;color:#fff;border:none}.tags-input{display:flex;flex-wrap:wrap;gap:6px;align-items:center;border:1px solid #e2e8f0;border-radius:8px;padding:6px;background:#fff}.tag{background:#2563eb;color:#fff;padding:2px 8px;border-radius:16px;font-size:.7rem;display:inline-flex;align-items:center;gap:4px}.tag button{background:none;border:none;color:#fff;cursor:pointer;font-size:.8rem}.tags-input input{flex:1;border:none;outline:none;background:transparent;min-width:80px}.canvas-toolbar{position:fixed;bottom:20px;left:20px;z-index:95}.scale-btn{background:#2563eb;color:#fff;border:none;padding:6px 12px;border-radius:30px;cursor:pointer;font-size:.7rem}@media (max-width: 700px){.right-panel{right:60px;width:240px}.header-left h2{display:none}.tag-filter-bar{right:60px}}@media (max-width: 550px){.right-panel{right:8px;bottom:8px;width:calc(100% - 16px);max-height:45vh;border-radius:16px}.tag-filter-bar{right:8px}}.modal-body .form-group{margin-bottom:1rem}.section-divider{margin:1.5rem 0 1rem;border-top:1px solid var(--border-color);position:relative}.section-divider span{background:var(--bg-secondary);padding-right:.5rem;position:relative;top:-.7rem;font-size:.85rem;font-weight:600;color:var(--text-secondary)}.modal-close-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-primary)}.primary-btn{background:var(--accent);color:#fff;border:none;border-radius:30px;padding:.4rem 1rem;cursor:pointer;font-size:.8rem}.danger-btn{background:#dc2626;color:#fff;border:none;border-radius:30px;padding:.4rem 1rem;cursor:pointer;font-size:.8rem}.modal-buttons{display:flex;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.points-list .empty-points{padding:.5rem;color:var(--text-secondary);font-style:italic}.modal-card{background:var(--bg-secondary, #ffffff);border-radius:24px;padding:1.5rem;width:90%;max-width:500px;max-height:85vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;position:relative}body.dark .modal-card{background:#1e293b;color:#e2e8f0}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.primary-btn{background:#2563eb;color:#fff;border:none;border-radius:30px;padding:.5rem 1rem;cursor:pointer}.secondary-btn{background:#64748b;color:#fff;border:none;border-radius:30px;padding:.5rem 1rem;cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background:var(--bg-secondary, #ffffff);border-radius:20px;width:90%;max-width:650px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 35px #0003}body.dark .modal-content{background:#1e293b;color:#e2e8f0}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}body.dark .modal-header{border-bottom-color:#334155}.modal-header h3{margin:0;font-size:1.3rem;font-weight:600}.modal-close-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:inherit;opacity:.7;transition:opacity .2s}.modal-close-btn:hover{opacity:1}.modal-body{flex:1;overflow-y:auto;padding:1.5rem}.form-group{margin-bottom:1rem}.form-group.full-width{width:100%}.form-group label{display:block;font-weight:600;margin-bottom:.4rem;font-size:.85rem;color:var(--text-primary, #0f172a)}body.dark .form-group label{color:#e2e8f0}.form-row{display:flex;gap:1rem;margin-bottom:1rem}.form-row .form-group{flex:1;margin-bottom:0}textarea,select,input{width:100%;padding:.6rem .8rem;border-radius:12px;border:1px solid var(--border-color, #cbd5e1);background:var(--input-bg, #ffffff);color:var(--text-primary, #0f172a);font-size:.9rem;transition:border .2s}body.dark textarea,body.dark select,body.dark input{background:#0f172a;border-color:#334155;color:#e2e8f0}textarea:focus,select:focus,input:focus{outline:none;border-color:var(--accent, #2563eb)}.tags-input{display:flex;flex-wrap:wrap;gap:6px;align-items:center;border:1px solid var(--border-color, #cbd5e1);border-radius:12px;padding:.4rem;background:var(--input-bg, #ffffff)}body.dark .tags-input{background:#0f172a;border-color:#334155}.tag{background:var(--accent, #2563eb);color:#fff;padding:2px 8px;border-radius:20px;font-size:.7rem;display:inline-flex;align-items:center;gap:4px}.tag button{background:none;border:none;color:#fff;cursor:pointer;font-size:.8rem;padding:0;margin-left:4px}.tags-input input{flex:1;border:none;outline:none;background:transparent;min-width:80px;padding:.2rem}.tags-input input:focus{border:none}.section-divider{margin:1.5rem 0 1rem;border-top:1px solid var(--border-color, #e2e8f0);position:relative}.section-divider span{background:var(--bg-secondary, #ffffff);padding-right:.8rem;position:relative;top:-.7rem;font-size:.85rem;font-weight:600;color:var(--text-secondary, #475569)}body.dark .section-divider span{background:#1e293b;color:#94a3b8}.replies-list{max-height:200px;overflow-y:auto;border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:.8rem;background:var(--input-bg, #ffffff)}body.dark .replies-list{background:#0f172a;border-color:#334155}.reply-item{border-bottom:1px solid var(--border-color, #e2e8f0);padding:.6rem 0}.reply-item:last-child{border-bottom:none}.reply-text{margin-bottom:.3rem}.reply-meta{display:flex;gap:12px;font-size:.65rem;color:var(--text-secondary, #475569);align-items:center}body.dark .reply-meta{color:#94a3b8}.delete-reply-btn{background:none;border:none;cursor:pointer;color:#ef4444;font-size:.8rem;padding:0}.delete-reply-btn:hover{color:#dc2626}.no-replies{text-align:center;padding:.8rem;color:var(--text-secondary, #64748b);font-style:italic}.add-reply{margin-top:1rem;display:flex;flex-direction:column;gap:.8rem}.add-reply textarea{resize:vertical}.primary-btn{background:var(--accent, #2563eb);color:#fff;border:none;border-radius:30px;padding:.5rem 1rem;cursor:pointer;font-size:.85rem;font-weight:500;transition:background .2s;align-self:flex-end}.primary-btn:hover:not(:disabled){filter:brightness(.9)}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.modal-buttons{padding:1rem 1.5rem;border-top:1px solid var(--border-color, #e2e8f0);display:flex;justify-content:flex-end}body.dark .modal-buttons{border-top-color:#334155}.danger-btn{background:#dc2626;color:#fff;border:none;border-radius:30px;padding:.5rem 1rem;cursor:pointer;font-size:.85rem;font-weight:500;transition:background .2s}.danger-btn:hover{background:#b91c1c}.points-list{background:var(--item-bg, #f1f5f9);border-radius:12px;padding:.8rem;max-height:150px;overflow-y:auto}body.dark .points-list{background:#0f172a}.point-item{font-size:.7rem;padding:4px;border-bottom:1px solid var(--border-color, #e2e8f0)}body.dark .point-item{border-bottom-color:#334155}.point-item:last-child{border-bottom:none}.empty-points{padding:.5rem;color:var(--text-secondary, #64748b);font-style:italic}@media (max-width: 700px){.modal-content{width:95%;max-height:90vh}.form-row{flex-direction:column;gap:.5rem}.form-row .form-group{margin-bottom:.5rem}.modal-header h3{font-size:1.1rem}}.online-btn{background:var(--accent, #2563eb);border-radius:30px;padding:4px 12px;cursor:pointer;font-size:.75rem;font-weight:500;color:#fff;border:none;display:inline-flex;align-items:center;gap:6px;transition:all .2s}.online-btn:hover{filter:brightness(.95);transform:translateY(-1px)}.online-btn:active{transform:translateY(0)}.online-modal{max-width:350px;width:90%}.online-modal .modal-body{padding:.5rem 0}.online-user-item{padding:.75rem 1.25rem;border-bottom:1px solid var(--border-color, #e2e8f0);display:flex;align-items:center;gap:10px;transition:background .1s}.online-user-item:hover{background:var(--item-bg, #f1f5f9)}.online-user-item:before{content:"●";color:#10b981;font-size:.7rem;display:inline-block;animation:pulse 1.5s infinite}body.dark .online-user-item:before{color:#34d399}.empty-state{text-align:center;padding:1.5rem;color:var(--text-secondary, #64748b);font-style:italic}.discipline-filter{background:var(--item-bg, #f1f5f9);border:1px solid var(--border-color, #cbd5e1);border-radius:30px;padding:4px 12px;font-size:.7rem;cursor:pointer;color:var(--text-primary, #0f172a)}body.dark .discipline-filter{background:#0f172a;border-color:#334155;color:#e2e8f0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--bg-color, white);border-radius:12px;max-width:800px;width:90%;max-height:80vh;overflow-y:auto;padding:1.5rem;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.modal-close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer}.dashboard-tabs{display:flex;gap:1rem;margin-bottom:1.5rem}.dashboard-tabs button{padding:.5rem 1rem;border:none;background:#f0f0f0;cursor:pointer;border-radius:8px}.dashboard-tabs button.active{background:#007bff;color:#fff}.stats-cards{display:flex;gap:1rem;margin-bottom:1.5rem}.stat-card{flex:1;padding:.75rem;border-radius:8px;text-align:center;background:#f8f9fa}.items-list{max-height:400px;overflow-y:auto}.dashboard-item{padding:.75rem;border-bottom:1px solid #eee}.item-title{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.status-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.status-dot.open{background:#dc3545}.status-dot.in-progress{background:#ffc107}.status-dot.completed{background:#28a745}.item-meta{font-size:.8rem;color:#666;display:flex;gap:1rem;flex-wrap:wrap}.zoom-controls{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:row;gap:8px;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 12px;border-radius:40px;box-shadow:0 4px 12px #00000026;z-index:100;transition:all .2s}body.dark .zoom-controls{background:#1e293bf2;box-shadow:0 4px 12px #0000004d}.zoom-controls button{background:#fff;border:1px solid #cbd5e1;border-radius:30px;width:32px;height:32px;cursor:pointer;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .1s;color:#0f172a}body.dark .zoom-controls button{background:#0f172a;border-color:#334155;color:#e2e8f0}.zoom-controls button:hover{background:#f1f5f9;transform:scale(1.02)}body.dark .zoom-controls button:hover{background:#1e293b}.zoom-controls span{font-size:.8rem;font-weight:600;min-width:45px;text-align:center;color:#0f172a;line-height:32px}body.dark .zoom-controls span{color:#e2e8f0}@media (max-width: 700px){.zoom-controls{bottom:12px;right:12px;padding:6px 10px;gap:6px}.zoom-controls button{width:28px;height:28px;font-size:1rem}.zoom-controls span{min-width:38px;font-size:.75rem}}.canvas-right-actions{position:fixed;right:20px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:12px;z-index:95}.action-btn{background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #cbd5e1;border-radius:40px;padding:8px 14px;font-size:.75rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s;box-shadow:0 2px 6px #0000000d;white-space:nowrap;color:#0f172a}body.dark .action-btn{background:#1e293bf2;border-color:#334155;color:#e2e8f0}.action-btn:hover{background:#fff;transform:scale(1.02);box-shadow:0 4px 8px #0000001a}body.dark .action-btn:hover{background:#1e293b}@media (max-width: 700px){.canvas-right-actions{right:12px;gap:8px}.action-btn{padding:6px 10px;font-size:.7rem}}.online-btn{background:#2563eb;border-radius:30px;padding:4px 12px;cursor:pointer;font-size:.75rem;font-weight:500;color:#fff;border:none;display:inline-flex;align-items:center;gap:6px}.online-btn:hover{filter:brightness(.95)}.online-modal{max-width:300px}.online-user-item{padding:8px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #e2e8f0}.online-user-item:last-child{border-bottom:none}.online-indicator{width:10px;height:10px;background:#10b981;border-radius:50%;display:inline-block;animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}.user-email{background:#0000000d;padding:4px 12px;border-radius:30px;font-size:.75rem;display:inline-flex;align-items:center;gap:6px;color:inherit}body.dark .user-email{background:#ffffff1a}.logo-wrapper{text-align:center}
