@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Sans+Thai:wght@300;400;500;600;700&display=swap";@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.container{width:100%}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.inline{display:inline}.table{display:table}.flex-shrink{flex-shrink:1}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}:root{--primary-color:#2563eb;--primary-hover:#1d4ed8;--secondary-color:#64748b;--accent-color:#f59e0b;--danger-color:#ef4444;--success-color:#10b981;--bg-body:#f8fafc;--bg-card:#fff;--bg-sidebar:#1e293b;--text-primary:#0f172a;--text-secondary:#475569;--text-light:#f1f5f9;--border-color:#e2e8f0;--viewer-footer-height:36px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--radius-md:.5rem;--radius-lg:.75rem;--radius-full:9999px;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-body);color:var(--text-primary);height:100vh;line-height:1.5;overflow:hidden}html[data-lang=ja] body,html:lang(ja) body{font-family:Meiryo UI,Noto Sans JP,Hiragino Sans,Yu Gothic UI,Meiryo,sans-serif}html[data-lang=ko] body,html:lang(ko) body{font-family:Noto Sans KR,Apple SD Gothic Neo,Malgun Gothic,NanumGothic,sans-serif}html[data-lang=zh-CN] body,html:lang(zh-CN) body{font-family:Noto Sans SC,PingFang SC,Microsoft YaHei,Source Han Sans CN,sans-serif}html[data-lang=zh-TW] body,html:lang(zh-TW) body{font-family:Noto Sans TC,PingFang TC,Microsoft JhengHei,Source Han Sans TW,sans-serif}html[data-lang=th] body,html:lang(th) body{font-family:Noto Sans Thai,Leelawadee UI,Tahoma,sans-serif}html[data-lang=en] body,html[data-lang=en-GB] body,html[data-lang=de] body,html[data-lang=fr] body,html[data-lang=sv] body,html[data-lang=vi] body,html:lang(en) body,html:lang(en-GB) body,html:lang(de) body,html:lang(fr) body,html:lang(sv) body,html:lang(vi) body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}#root{height:100%}.app-wrapper{flex-direction:column;width:100%;height:100%;display:flex}.app-layout{flex:1;width:100%;display:flex;overflow:hidden}.sidebar{background-color:var(--bg-sidebar);width:260px;color:var(--text-light);flex-direction:column;flex-shrink:0;padding:1.5rem .75rem;display:flex}.brand{color:#fff;align-items:center;gap:.75rem;margin-bottom:2.5rem;font-size:1.25rem;font-weight:700;display:flex}.brand-icon{background:#64748b;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;transition:all .2s;display:flex}.brand-icon:hover{background:#475569;transform:scale(1.05)}.brand-icon.connecting{animation:1.5s ease-in-out infinite pen-connecting-pulse}@keyframes pen-connecting-pulse{0%{background:#64748b}50%{background:#f59e0b}to{background:#64748b}}.brand-icon.connected{background:var(--primary-color)}.brand-icon.connected:hover{background:var(--primary-hover)}.nav-menu{flex-direction:column;gap:.5rem;list-style:none;display:flex}.nav-item{border-radius:var(--radius-md);color:#94a3b8;cursor:pointer;align-items:center;gap:.75rem;padding:.75rem 1rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover,.nav-item.active{color:#fff;background-color:#ffffff1a}.nav-item i{text-align:center;width:20px}.sidebar{transition:width .3s;position:relative}.sidebar.collapsed{width:72px;padding:1.5rem .75rem}.sidebar.collapsed .brand{justify-content:center;margin-bottom:1.5rem}.sidebar.collapsed .nav-item{justify-content:center;padding:.75rem}.sidebar-toggle{background:var(--bg-sidebar);cursor:pointer;color:#94a3b8;z-index:10;border:1px solid #374151;border-left:none;border-radius:0 8px 8px 0;justify-content:center;align-items:center;width:16px;height:48px;transition:all .2s;display:flex;position:absolute;top:50%;right:-16px;transform:translateY(-50%)}.sidebar-toggle:hover{color:#fff;background:#374151;width:24px;right:-24px;box-shadow:4px 0 15px #0003}.main-content{flex-direction:column;flex:1;gap:2rem;padding:2rem;display:flex;overflow-y:auto}.top-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.page-title h1{color:var(--text-primary);font-size:1.5rem;font-weight:700}.page-title p{color:var(--text-secondary);font-size:.875rem}.card{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);padding:1.5rem;transition:transform .2s,box-shadow .2s}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-title{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:1rem;font-weight:600;display:flex}.stat-card{flex-direction:column;display:flex}.stat-value{color:var(--text-primary);margin:.5rem 0;font-size:2.5rem;font-weight:700}.stat-diff{align-items:center;gap:.25rem;font-size:.875rem;display:flex}.diff-positive{color:var(--success-color)}.diff-negative{color:var(--danger-color)}.status-badge{border-radius:var(--radius-full);align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-urgent{color:#ef4444;background-color:#fef2f2}.status-progress{color:#3b82f6;background-color:#eff6ff}.status-done{color:#10b981;background-color:#ecfdf5}.auth-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:500;opacity:1;background:#f8fafc99;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .5s;display:flex;position:fixed;top:0;left:0}.auth-card{text-align:center;background:#fff;border:1px solid #ffffff80;border-radius:20px;width:100%;max-width:400px;padding:40px;animation:.5s cubic-bezier(.16,1,.3,1) slideUp;box-shadow:0 20px 50px #0000001a}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.viewer-layout{height:100vh;display:flex;overflow:hidden}.viewer-content{background-color:#94a3b8;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.drawing-marker{cursor:pointer;z-index:999;border:3px solid #fff;border-radius:50% 50% 50% 0;justify-content:center;align-items:center;width:36px;height:36px;transition:box-shadow .3s,filter .3s;display:flex;position:absolute;box-shadow:0 4px 10px #0006;pointer-events:auto!important}.drawing-marker i{color:#fff;font-size:14px;transform:rotate(45deg)}.drawing-marker:hover{z-index:1000;filter:brightness(1.1);box-shadow:0 8px 20px #00000080}.drawing-marker.dimmed{opacity:.25;z-index:40;box-shadow:none;filter:grayscale()}.cluster-marker{color:#475569;cursor:pointer;pointer-events:auto;background:#fff;border:3px solid #64748b;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-weight:800;transition:all .2s ease-out;display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 4px 12px #0000004d;z-index:100!important}.cluster-marker:hover{transform:translate(-50%,-50%)scale(1.1);z-index:105!important}.toolbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:100;border:1px solid var(--border-color);background:#fffffff2;gap:.5rem;padding:.5rem 1rem;display:flex;position:absolute;top:1.5rem;left:50%;transform:translate(-50%)}.tool-btn{cursor:pointer;min-width:32px;height:32px;color:var(--text-secondary);background:0 0;border:none;border-radius:16px;justify-content:center;align-items:center;padding:0 8px;font-size:.85rem;transition:background .2s;display:flex}.tool-btn:hover{color:var(--text-primary);background:#f1f5f9}.tool-btn.active{color:#0284c7;background:#e0f2fe}.tool-btn.page-lock-toggle{gap:4px;transition:all .2s}.tool-btn.page-lock-toggle:not(.active){color:#16a34a;background:#dcfce7}.tool-btn.page-lock-toggle:not(.active):hover{background:#bbf7d0}.tool-btn.page-lock-toggle.active{color:#d97706;background:#fef3c7}.tool-btn.page-lock-toggle.active:hover{background:#fde68a}.detail-panel{border-left:1px solid var(--border-color);z-index:200;background:#fff;flex-direction:column;width:340px;height:100%;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:0;right:0;transform:translate(100%);box-shadow:-4px 0 15px #0000000d}.detail-panel.open{transform:translate(0)}.viewer-app-container .detail-panel{width:0;min-width:0;height:100%;box-shadow:none;border-left:none;flex-shrink:0;transition:width .3s cubic-bezier(.4,0,.2,1),min-width .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;transform:none}.viewer-app-container .detail-panel.open{border-left:1px solid var(--border-color);width:340px;min-width:340px;box-shadow:-4px 0 15px #0000000d}.side-handle{cursor:pointer;z-index:250;color:#64748b;background:#fff;border:1px solid #cbd5e1;border-right:none;border-radius:8px 0 0 8px;flex-direction:column;align-items:center;gap:6px;padding:12px 6px;transition:all .2s;display:flex;position:absolute;top:40px;right:0;box-shadow:-4px 4px 10px #0000000d}.side-handle.panel-open{right:340px}.viewer-app-container .side-handle.panel-open{right:0}.side-handle:hover{color:var(--primary-color);background:#f1f5f9;padding-right:12px;box-shadow:-6px 0 15px #2563eb1a}.side-handle span{writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:2px;font-size:.75rem;font-weight:700}.minimap-container{z-index:50;background:#fff;border:1px solid #cbd5e1;border-radius:8px;position:absolute;bottom:20px;right:20px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background:#fff;border-radius:16px;flex-direction:column;width:400px;max-height:80vh;display:flex;overflow:hidden;box-shadow:0 10px 25px #0003}.drawing-card{border:1px solid var(--border-color);cursor:pointer;background:#fff;border-radius:12px;transition:all .2s;position:relative;overflow:hidden}.drawing-card:hover{border-color:#cbd5e1;transform:translateY(-4px);box-shadow:0 10px 20px #0000000d}.card-thumb{color:#94a3b8;background:#e2e8f0;justify-content:center;align-items:center;height:180px;display:flex;position:relative;overflow:hidden}.card-thumb img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;transition:transform .3s}.drawing-card:hover .card-thumb img{transform:scale(1.05)}@media(max-width:768px){.sidebar{height:calc(100vh - var(--viewer-footer-height,36px));z-index:1000;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:2px 0 10px #0000001a}.sidebar.active{transform:translate(0)}.sidebar .sidebar-toggle{display:none}.main-content{width:100%;padding:16px}.dashboard-grid{grid-template-columns:repeat(2,1fr)!important}.menu-overlay{z-index:900;background:#00000080;width:100%;height:100%;display:none;position:fixed;top:0;left:0}.menu-overlay.active{display:block}.toolbar .tool-btn span{display:none}}.filter-menu{border:1px solid var(--border-color);z-index:1000;background:#fff;border-radius:0 0 12px 12px;min-width:360px;padding:16px;position:fixed;top:80px;left:50%;transform:translate(-50%);box-shadow:0 10px 25px #00000026}.filter-item{color:#475569;cursor:pointer;align-items:center;gap:8px;padding:6px 12px;font-size:.9rem;display:flex}.filter-item:hover{background:#f8fafc}.btn-primary{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;padding:14px;font-size:1rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:var(--primary-hover)}.input-group{margin-bottom:20px;position:relative}.input-group i{color:#94a3b8;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.input-group input{border:1px solid var(--border-color);box-sizing:border-box;background:#f8fafc;border-radius:10px;width:100%;padding:14px 14px 14px 48px;font-size:1rem;transition:all .2s}.input-group input:focus{border-color:var(--primary-color);background:#fff;outline:none;box-shadow:0 0 0 3px #2563eb1a}.app-container{background-color:#f8fafc;width:100vw;height:calc(100vh - 60px);display:flex;position:relative;overflow:hidden}.viewer-sidebar{z-index:50;border-right:1px solid var(--border-color);background:#fff;flex-direction:column;flex-shrink:0;align-items:center;height:100%;padding-top:1rem;display:flex;position:relative;width:56px!important}.menu-item{color:#64748b;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:.5rem;font-size:.95rem;transition:all .2s;display:flex}.menu-item:hover,.menu-item.active{color:var(--primary-color);background:#eff6ff}.feed-item{border-bottom:1px solid var(--border-color);gap:1rem;padding-bottom:1rem;display:flex}.feed-item:last-child{border-bottom:none}.feed-icon{border-radius:var(--radius-full);width:36px;height:36px;color:var(--primary-color);background-color:#eef2ff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.memo-list-item{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:8px;margin-bottom:8px;padding:12px;transition:all .2s;box-shadow:0 1px 2px #00000008}.memo-list-item:hover{border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 4px 6px #0000000d}.drawing-wrapper{transform-origin:0 0;background:#fff;line-height:0;display:inline-block;position:absolute;box-shadow:0 10px 25px -5px #0000001a}.drawing-image{width:auto;max-width:none;height:auto;display:block}.common-header{border-bottom:1px solid var(--border-color);z-index:200;background:#fff;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:relative;box-shadow:0 1px 3px #0000000d}.logo{color:var(--primary-color);cursor:pointer;align-items:center;gap:8px;font-size:1.2rem;font-weight:800;display:flex}.hidden{display:none!important}.dashboard-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;display:grid}.dashboard-bottom-row{gap:1.5rem;margin-top:1.5rem;display:flex}.dashboard-bottom-row .feed-card{flex:4;min-height:350px}.dashboard-bottom-row .chart-card{flex:6;min-height:350px}.feed-list{flex-direction:column;gap:1rem;display:flex}.feed-content h4{color:var(--text-primary);margin-bottom:4px;font-size:.95rem;font-weight:600}.feed-content p{color:var(--text-secondary);margin-bottom:4px;font-size:.85rem}.feed-time{color:#94a3b8;font-size:.75rem}.drawing-list-header{border-bottom:1px solid var(--border-color);z-index:100;background:#fff;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 1px 3px #0000000d}.main-container{box-sizing:border-box;width:100%;padding:0}.action-bar{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.btn-new{background:var(--primary-color);color:#fff;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-weight:600;text-decoration:none;transition:transform .2s;display:flex}.btn-new:hover{background:var(--primary-hover);transform:translateY(-2px)}.filters{gap:12px;margin-bottom:24px;display:flex}.search-box{border:1px solid var(--border-color);background:#fff;border-radius:8px;align-items:center;gap:8px;width:300px;padding:8px 16px;display:flex}.search-box input{border:none;outline:none;width:100%;font-size:.95rem}.drawing-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;width:100%;display:grid}.card-body{padding:16px}.card-body .card-title{color:var(--text-primary);margin-bottom:4px;font-size:1.1rem;font-weight:700;display:block}.card-sub{color:var(--text-secondary);margin-bottom:12px;font-size:.85rem}.card-meta{color:#94a3b8;border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding-top:12px;font-size:.8rem;display:flex}.memo-count{align-items:center;gap:4px;font-weight:600;display:flex}.status-badge{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;background:#0009;border-radius:4px;padding:4px 8px;font-size:.75rem;position:absolute;top:12px;right:12px}.viewer-page{flex-direction:column;height:100vh;display:flex;overflow:hidden}.mobile-sidebar-toggle{z-index:1001;color:#fff;cursor:pointer;background:#000000b3;border:none;border-radius:0 8px 8px 0;width:24px;height:56px;transition:width .2s,opacity .3s,background .2s;display:none;position:fixed;top:50%;left:0;transform:translateY(-50%);box-shadow:2px 0 8px #00000026}.mobile-sidebar-toggle:hover{background:#000000d9;width:32px}.mobile-sidebar-toggle.hidden{opacity:0;pointer-events:none}.mobile-sidebar-toggle i{font-size:14px}@media(max-width:768px){.mobile-sidebar-toggle{justify-content:center;align-items:center;display:flex}}.viewer-page.viewer-no-header .viewer-app-container{height:calc(100vh - var(--viewer-footer-height,36px));flex:1}.viewer-app-container{flex:1;height:calc(100vh - 60px);display:flex;position:relative}.viewer-app-container .sidebar{height:100%}.viewer-app-container .menu-overlay{display:none}@media(max-width:768px){.viewer-app-container .menu-overlay.active{display:block}}.viewer-header{border-bottom:1px solid var(--border-color);z-index:200;background:#fff;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:relative;box-shadow:0 1px 3px #0000000d}.header-center{align-items:center;gap:24px;display:flex}.header-title-section{border-right:1px solid var(--border-color);flex-direction:column;padding-right:24px;display:flex}.header-project-name{color:var(--text-primary);font-size:.95rem;font-weight:700}.header-drawing-name{color:#64748b;font-size:.75rem}.header-toolbar{align-items:center;gap:8px;display:flex}.header-toolbar .tool-btn{cursor:pointer;color:#475569;background:#fff;border:1px solid #cbd5e1;border-radius:6px;align-items:center;gap:6px;height:36px;padding:0 12px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.header-toolbar .tool-btn:hover{background:#f1f5f9}.header-toolbar .tool-btn.active{border-color:var(--primary-color);color:var(--primary-color);background:#eff6ff}.filter-section-title{color:#94a3b8;margin-bottom:4px;padding:4px 8px;font-size:.8rem;font-weight:600}.filter-divider{background:#f1f5f9;height:1px;margin:4px 0}.sidebar-divider{background:#f1f5f9;width:32px;height:1px;margin:4px 0 8px}#drawingContainer{width:100%;height:100%;position:relative;overflow:hidden}#markerContainer{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}#minimapContainer{z-index:50;background:#fff;border:1px solid #cbd5e1;border-radius:8px;position:absolute;bottom:20px;right:20px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a}#miniViewport{box-sizing:border-box;pointer-events:none;z-index:10;background:#ef444426;border:2px solid #ef4444;position:absolute}.viewer-top-toolbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);z-index:100;background:#fffffff2;border-radius:12px;align-items:center;gap:16px;padding:12px 16px;display:flex;position:absolute;top:16px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000014}.toolbar-title-section{border-right:1px solid var(--border-color);flex-direction:column;gap:2px;padding-right:16px;display:flex}.toolbar-project-name{color:var(--text-primary);font-size:.95rem;font-weight:700}.toolbar-drawing-name{color:#64748b;font-size:.75rem}.toolbar-buttons{align-items:center;gap:8px;display:flex}.toolbar-buttons .tool-btn{cursor:pointer;color:#475569;background:#fff;border:1px solid #cbd5e1;border-radius:6px;align-items:center;gap:6px;height:36px;padding:0 12px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.toolbar-buttons .tool-btn:hover{background:#f1f5f9}.toolbar-buttons .tool-btn.active{border-color:var(--primary-color);color:var(--primary-color);background:#eff6ff}.toolbar-buttons.icon-only .tool-btn{gap:0;min-width:36px;padding:0 10px}.toolbar-buttons.icon-only .tool-btn span{display:none}.toolbar-buttons.icon-only .tool-btn i{margin:0;font-size:1rem}@media(max-width:1440px){.viewer-top-toolbar{flex-direction:column;gap:10px;max-width:calc(100% - 100px);padding:10px 14px}.toolbar-title-section{border-right:none;border-bottom:1px solid var(--border-color);text-align:center;width:100%;padding-bottom:8px;padding-right:0}.toolbar-buttons{flex-wrap:wrap;justify-content:center}.toolbar-buttons .tool-btn{height:32px;padding:0 10px}.toolbar-buttons .tool-btn span{display:none}.toolbar-buttons .tool-btn i{margin:0}}@media(max-width:480px){.viewer-top-toolbar{max-width:calc(100% - 60px);padding:8px 10px;top:8px}.toolbar-project-name{font-size:.85rem}.toolbar-drawing-name{font-size:.7rem}.toolbar-buttons .tool-btn{height:30px;padding:0 8px;font-size:.85rem}}.viewer-filter-menu{border:1px solid var(--border-color);background:#fff;border-radius:12px;min-width:280px;margin-top:8px;padding:16px;animation:.2s slideDown;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 10px 25px #00000026}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.panel-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:1rem;display:flex}.panel-header h3{color:var(--text-primary);align-items:center;gap:8px;margin:0;font-size:1.1rem;display:flex}.memo-count-badge{background:var(--primary-color);color:#fff;border-radius:12px;padding:2px 8px;font-size:.75rem}.panel-close-btn{cursor:pointer;color:#94a3b8;background:0 0;border:none;font-size:1.2rem}.panel-content{flex:1;padding:1rem;overflow-y:auto}.memo-detail{flex-direction:column;gap:1rem;display:flex}.memo-header{align-items:center;gap:12px;display:flex}.author-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.memo-author{font-size:.9rem;font-weight:600}.memo-time{color:#94a3b8;font-size:.75rem}.memo-location{color:#64748b;align-items:center;gap:6px;font-size:.85rem;display:flex}.memo-description{color:var(--text-primary);font-size:.95rem;line-height:1.6}.memo-content-image{border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.memo-content-image img{width:100%;display:block}.back-to-list-btn{color:#475569;cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 16px;font-weight:600;transition:all .2s;display:flex}.back-to-list-btn:hover{background:var(--border-color)}.memo-item-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.memo-item-description{color:var(--text-primary);margin-bottom:8px;font-size:.9rem}.memo-item-footer{justify-content:space-between;align-items:center;font-size:.75rem;display:flex}.status-badge.small{-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;padding:2px 8px;font-size:.7rem;position:static}.ncode-main{flex-direction:column;justify-content:flex-start;align-items:center;height:100%;padding:1.5rem;display:flex;overflow-y:auto}.ncode-main.fullwidth{padding:1rem}.ncode-title-section{text-align:center;margin-bottom:24px}.ncode-title-section h1{margin:0 0 8px;font-size:1.8rem}.ncode-title-section p{color:#64748b;margin:0}.ncode-container{border:1px solid var(--border-color);background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:800px;min-height:500px;display:flex;overflow:hidden;box-shadow:0 10px 25px -5px #0000001a}.ncode-main.fullwidth .ncode-container{border-radius:12px;max-width:none;height:100%}.stepper{border-bottom:1px solid var(--border-color);background:#fff;padding:24px 40px;display:flex}.step-item{color:var(--text-secondary);flex:1;align-items:center;gap:12px;font-weight:500;display:flex;position:relative}.step-item.active{color:var(--primary-color);font-weight:700}.step-circle{background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;transition:all .3s;display:flex}.step-item.active .step-circle{background:var(--primary-color);color:#fff}.step-item.completed .step-circle{color:#fff;background:#10b981}.step-content{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px;animation:.4s fadeIn;display:flex}.ncode-main.fullwidth .step-content{justify-content:center;align-items:center;padding:2rem;overflow:auto}.ncode-main.fullwidth .step-content.page-selection{text-align:left;justify-content:flex-start;align-items:stretch;padding:1rem 1.5rem;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.input-label{color:var(--text-primary);text-align:left;margin-bottom:8px;font-size:.95rem;font-weight:600;display:block}.required{color:#ef4444}.input-field{border:1px solid var(--border-color);box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:12px 16px;font-family:inherit;font-size:1rem;transition:all .2s}.input-field:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.upload-area{cursor:pointer;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;width:100%;height:300px;transition:all .3s;display:flex}.upload-area:hover,.upload-area.dragover{border-color:var(--primary-color);background:#eff6ff}.upload-icon{color:#94a3b8;margin-bottom:16px;font-size:3rem}.upload-text{color:var(--text-primary);margin-bottom:8px;font-size:1.1rem}.upload-sub{color:var(--text-secondary);font-size:.9rem}.processing-graphic{border:2px solid var(--border-color);background:#fff;border-radius:4px;justify-content:center;align-items:center;width:120px;height:150px;margin-bottom:30px;display:flex;position:relative;box-shadow:0 4px 10px #0000000d}.scan-line{background:#ef4444;width:120%;height:2px;animation:2s ease-in-out infinite scan;position:absolute;top:0;left:-10%;box-shadow:0 0 10px #ef4444}@keyframes scan{0%{opacity:0;top:0}10%{opacity:1}90%{opacity:1}to{opacity:0;top:100%}}.ncode-pattern{opacity:0;background-image:radial-gradient(#cbd5e1 1px,#0000 1px);background-size:8px 8px;width:100%;height:100%;animation:3s forwards patternFade;position:absolute;top:0;left:0}@keyframes patternFade{0%{opacity:0}to{opacity:.5}}.process-sub{color:#64748b;margin-top:8px}.progress-bar-container{background:#e2e8f0;border-radius:3px;width:300px;height:6px;margin-top:20px;overflow:hidden}.progress-bar{background:var(--primary-color);height:100%;transition:width .3s}.complete-icon{color:#10b981;margin-bottom:16px;font-size:3rem}.preview-card{border:1px solid var(--border-color);text-align:left;background:#fff;border-radius:12px;align-items:center;gap:24px;width:100%;max-width:500px;margin-bottom:30px;padding:20px;display:flex}.file-icon{width:60px;height:80px;color:var(--primary-color);background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;justify-content:center;align-items:center;font-size:2rem;display:flex}.file-info h3{margin:0 0 4px;font-size:1.1rem}.file-info p{color:var(--text-secondary);margin:0;font-size:.9rem}.action-buttons{flex-wrap:wrap;justify-content:center;gap:12px;max-width:100%;display:flex}.action-buttons .btn-primary{width:auto}.ncode-main.fullwidth .action-buttons{flex-shrink:0;justify-content:center;align-self:center;max-width:100%;padding-top:.5rem}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;flex-shrink:0;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-outline{color:var(--text-primary);background:#fff;border:1px solid #cbd5e1}.btn-outline:hover{border-color:var(--text-secondary);background:#f8fafc}.settings-container{box-sizing:border-box;width:100%;max-width:800px;margin:0 auto;padding:0}.settings-header{border-bottom:1px solid var(--border-color);margin-bottom:32px;padding-bottom:16px}.settings-header h1{color:var(--text-primary);margin:0;font-size:1.8rem}.settings-header p{color:var(--text-secondary);margin:8px 0 0}.settings-card{border:1px solid var(--border-color);background:#fff;border-radius:12px;margin-bottom:24px;padding:24px;box-shadow:0 2px 4px #00000005}.settings-card .card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.settings-card .card-header h2{align-items:center;gap:10px;margin:0;font-size:1.1rem;display:flex}.settings-card .card-header h2 i{color:var(--primary-color)}.status-row{background:#f8fafc;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px;display:flex}.status-label{color:#475569;align-items:center;gap:8px;font-weight:600;display:flex}.status-badge.success{color:#15803d;background:#dcfce7;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.85rem;font-weight:700;display:flex;position:static}.status-note{color:#94a3b8;margin:0;font-size:.85rem}.device-list{flex-direction:column;gap:12px;display:flex}.device-card{border:1px solid var(--border-color);border-radius:8px;align-items:center;gap:20px;padding:20px;transition:all .2s;display:flex}.device-card:hover{border-color:var(--primary-color);background:#eff6ff}.device-card.disconnected{opacity:.7}.device-icon{color:#64748b;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;font-size:1.8rem;display:flex;box-shadow:0 2px 8px #0000000d}.device-info{flex:1}.device-name{color:var(--text-primary);margin-bottom:4px;font-size:1rem;font-weight:700}.device-meta{color:var(--text-secondary);gap:12px;font-size:.85rem;display:flex}.battery-level{color:#15803d;align-items:center;gap:4px;display:flex}.connect-btn,.scan-btn{border:1px solid var(--primary-color);color:var(--primary-color);cursor:pointer;background:#fff;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-weight:600;transition:all .2s;display:flex}.connect-btn:hover,.scan-btn:hover{background:var(--primary-color);color:#fff}.connect-btn.connected{color:#64748b;cursor:default;background:#f1f5f9;border-color:#cbd5e1}.firmware-list{flex-direction:column;display:flex}.firmware-info{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.firmware-info:last-child{border-bottom:none}.fw-label{color:#64748b;font-size:.9rem}.fw-val{color:#334155;font-weight:600}.update-btn{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:16px;padding:10px 20px;font-weight:600;display:flex}.update-btn:disabled{cursor:not-allowed;background:#cbd5e1}.update-btn.success{background:#10b981}.pen-not-connected-section{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.pen-not-connected-icon{color:#94a3b8;background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:16px;font-size:2.5rem;display:flex}.pen-not-connected-text{color:#64748b;margin:0 0 20px;font-size:1rem}.connect-pen-btn{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.connect-pen-btn:hover{background:var(--primary-dark,#2563eb);transform:translateY(-1px)}.connect-pen-btn:disabled{cursor:not-allowed;background:#cbd5e1;transform:none}.update-available-badge{color:#d97706;background:#fef3c7;border-radius:12px;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.db-stats-section{margin-bottom:20px}.db-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.db-stat-item{background:#f8fafc;border-radius:8px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.db-stat-item.total{border:1px solid var(--primary-color);background:#eff6ff;grid-column:span 2}.db-stat-label{color:#64748b;font-size:.9rem}.db-stat-value{color:#334155;font-weight:600}.db-stat-item.total .db-stat-label,.db-stat-item.total .db-stat-value{color:var(--primary-color)}.db-actions-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}.db-action-btn.export{border-color:var(--primary-color);color:var(--primary-color);background:#fff}.db-action-btn.export:hover:not(:disabled){background:var(--primary-color);color:#fff}.db-action-btn.import:hover:not(:disabled){color:#fff;background:#10b981}.db-action-btn.reset:hover:not(:disabled){color:#fff;background:#ef4444}.import-result-banner{border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:.9rem;display:flex}.import-result-banner.success{color:#15803d;background:#dcfce7}.import-result-banner.error{color:#dc2626;background:#fee2e2}.db-help-note{color:#94a3b8;align-items:center;gap:8px;margin:0;font-size:.85rem;display:flex}.ncode-settings-section{flex-direction:column;gap:20px;margin-bottom:20px;display:flex}.setting-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;padding:16px;display:flex}.setting-info{flex:1;margin-right:16px}.setting-label{color:#1e293b;margin-bottom:4px;font-size:.95rem;font-weight:600;display:block}.setting-desc{color:#64748b;margin:0;font-size:.85rem;line-height:1.4}.toggle-switch{flex-shrink:0;width:52px;height:28px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:#cbd5e1;border-radius:28px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:22px;height:22px;transition:all .3s;position:absolute;bottom:3px;left:3px;box-shadow:0 2px 4px #00000026}.toggle-switch input:checked+.toggle-slider{background-color:#3b82f6}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.slider-control{flex-shrink:0;align-items:center;gap:12px;display:flex}.range-slider{-webkit-appearance:none;cursor:pointer;background:#e2e8f0;border-radius:3px;outline:none;width:140px;height:6px}.range-slider::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#3b82f6;border-radius:50%;width:18px;height:18px;-webkit-transition:transform .15s;transition:transform .15s;box-shadow:0 2px 4px #3b82f64d}.range-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.range-slider::-moz-range-thumb{cursor:pointer;background:#3b82f6;border:none;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 4px #3b82f64d}.slider-value{text-align:center;color:#3b82f6;min-width:36px;font-size:.95rem;font-weight:600}.reset-settings-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 16px;font-size:.9rem;transition:all .2s;display:flex}.reset-settings-btn:hover{color:#475569;background:#f8fafc;border-color:#cbd5e1}.loading-text{color:#64748b;align-items:center;gap:8px;display:flex}@media(max-width:640px){.db-actions-grid,.db-stats-grid{grid-template-columns:1fr}.db-stat-item.total{grid-column:span 1}}.mobile-menu-btn{color:#1e293b;cursor:pointer;margin-right:16px;font-size:1.5rem;display:none}@media(max-width:768px){.mobile-menu-btn{display:block}.dashboard-bottom-row{flex-direction:column}.main-container{padding:0}.action-bar{flex-direction:column-reverse;align-items:stretch;gap:16px}.search-box{width:100%}.header-title-section,.header-toolbar .tool-btn span{display:none}.filter-menu{min-width:auto;width:90%!important}}.user-profile{align-items:center;gap:12px;display:flex}.user-avatar{color:#64748b;background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.user-role{color:var(--text-secondary);font-size:.75rem}.auth-footer{color:#64748b;font-size:.9rem}.auth-footer a{color:var(--primary-color);font-weight:600;text-decoration:none}.auth-card h2{color:#1e293b;margin-bottom:8px;font-size:1.8rem}.auth-card p{color:#64748b;margin-bottom:32px;font-size:.95rem}.app-footer{color:#64748b;background:#f1f5f9;border-top:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 24px;font-size:.8rem;display:flex}.footer-left{color:#94a3b8;align-items:center;gap:8px;font-weight:700;display:flex}.footer-center{font-size:.8rem}.footer-right{gap:16px;display:flex}.footer-right a{color:#64748b;text-decoration:none;transition:color .2s}.footer-right a:hover{color:var(--primary-color)}.viewer-footer{height:var(--viewer-footer-height,36px);color:#64748b;z-index:100;background:#f1f5f9;border-top:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 24px;font-size:.75rem;display:flex;position:relative}.viewer-footer .footer-left{color:#94a3b8;align-items:center;gap:8px;font-weight:700;display:flex}.viewer-footer .page-info{margin-left:4px;font-weight:400}.viewer-footer .page-info .sobp{color:#2563eb;font-weight:500}.viewer-footer .page-info .page-size{color:#64748b}.viewer-footer .footer-center{font-size:.75rem}.viewer-footer .footer-right{gap:16px;display:flex}.viewer-footer .footer-right a{color:#64748b;text-decoration:none;transition:color .2s}.viewer-footer .footer-right a:hover{color:var(--primary-color)}.viewer-footer .footer-right a i,.viewer-footer .copyright-short{display:none}@media(max-width:1024px){.viewer-footer{padding:8px 16px}.viewer-footer .copyright-full{display:none}.viewer-footer .copyright-short{display:inline}.viewer-footer .footer-right a .link-text{display:none}.viewer-footer .footer-right a i{font-size:1rem;display:inline}.viewer-footer .footer-right{gap:12px}}.settings-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.settings-modal{background:#fff;border-radius:12px;flex-direction:column;width:90%;max-width:480px;max-height:80vh;animation:.2s slideUp;display:flex;overflow:hidden;box-shadow:0 20px 40px #0003}.settings-modal-header{background:#f8fafc;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.settings-modal-header h2{color:#1e293b;align-items:center;gap:8px;margin:0;font-size:1.1rem;font-weight:600;display:flex}.settings-modal-header h2 i{color:#64748b}.settings-modal-header .close-btn{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:6px;padding:8px;transition:all .15s}.settings-modal-header .close-btn:hover{color:#1e293b;background:#e5e7eb}.settings-modal-content{flex-direction:column;gap:24px;padding:20px;display:flex;overflow-y:auto}.settings-section{flex-direction:column;gap:12px;display:flex}.settings-section h3{color:#475569;border-bottom:1px solid #e5e7eb;align-items:center;gap:8px;margin:0;padding-bottom:8px;font-size:.9rem;font-weight:600;display:flex}.settings-section h3 i{color:#2563eb;font-size:.85rem}.pen-info-grid,.storage-info{flex-direction:column;gap:8px;display:flex}.info-row{background:#f8fafc;border-radius:6px;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.info-label{color:#64748b;font-size:.85rem}.info-value{color:#1e293b;align-items:center;gap:8px;font-size:.9rem;font-weight:500;display:flex}.update-badge{color:#d97706;background:#fef3c7;border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:500;display:inline-flex}.pen-not-connected{color:#94a3b8;background:#f8fafc;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;display:flex}.pen-not-connected i{font-size:1.5rem}.pen-not-connected span{font-size:.9rem}.loading-text,.error-text{text-align:center;color:#64748b;padding:12px;font-size:.9rem}.loading-text i{margin-right:6px}.error-text{color:#ef4444}.clear-storage-btn{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:10px 16px;font-size:.9rem;font-weight:500;transition:all .15s;display:flex}.clear-storage-btn:hover:not(:disabled){background:#fee2e2;border-color:#f87171}.clear-storage-btn:disabled{opacity:.5;cursor:not-allowed}.db-stats-info{background:#f8fafc;border-radius:8px;margin-bottom:12px;padding:12px}.db-stats-info .info-row.total{border-top:1px solid #e2e8f0;margin-top:8px;padding-top:8px;font-weight:600}.import-result{border-radius:6px;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;font-size:.85rem;display:flex}.import-result.success{color:#15803d;background:#dcfce7}.import-result.error{color:#dc2626;background:#fef2f2}.db-actions{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.db-action-btn{cursor:pointer;border:1px solid;border-radius:6px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:.9rem;font-weight:500;transition:all .15s;display:flex}.db-action-btn.export{color:#2563eb;background:#eff6ff;border-color:#bfdbfe}.db-action-btn.export:hover:not(:disabled){background:#dbeafe;border-color:#60a5fa}.db-action-btn.import{color:#16a34a;background:#f0fdf4;border-color:#bbf7d0}.db-action-btn.import:hover:not(:disabled){background:#dcfce7;border-color:#4ade80}.db-action-btn.reset{color:#dc2626;background:#fef2f2;border-color:#fecaca}.db-action-btn.reset:hover:not(:disabled){background:#fee2e2;border-color:#f87171}.db-action-btn:disabled{opacity:.5;cursor:not-allowed}.db-help-text{color:#64748b;align-items:flex-start;gap:6px;margin:0;font-size:.8rem;line-height:1.4;display:flex}.db-help-text i{color:#94a3b8;margin-top:2px}.memo-marker{cursor:pointer;z-index:999;border:3px solid #fff;border-radius:50% 50% 50% 0;justify-content:center;align-items:center;width:36px;height:36px;transition:box-shadow .3s,filter .3s;display:flex;position:absolute;box-shadow:0 4px 10px #0006;pointer-events:auto!important}.memo-marker i{color:#fff;font-size:14px;transform:rotate(45deg)}.memo-marker:hover{z-index:1000;filter:brightness(1.1);box-shadow:0 8px 20px #00000080}.memo-marker.highlighted{animation:1s ease-in-out infinite marker-pulse}@keyframes marker-pulse{0%,to{box-shadow:0 0 0 3px #ea580c80,0 4px 10px #0006}50%{box-shadow:0 0 0 6px #ea580c4d,0 4px 10px #0006}}.stroke-boundary-overlay .boundary-rect,.stroke-boundary-overlay .connector-line,.stroke-boundary-overlay .marker-center-dot{animation:2s ease-in-out infinite boundary-pulse}@keyframes boundary-pulse{0%,to{opacity:1;filter:drop-shadow(0 0 4px #ea580c99)}50%{opacity:.5;filter:drop-shadow(0 0 8px #ea580c4d)}}.marker-priority-badge{color:#fff;background:#ef4444;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;font-weight:700;display:flex;position:absolute;top:-8px;right:-8px;transform:rotate(45deg)}.marker-priority-badge.urgent{animation:1s ease-in-out infinite urgent-pulse}@keyframes urgent-pulse{0%,to{transform:rotate(45deg)scale(1)}50%{transform:rotate(45deg)scale(1.1)}}.memo-marker-preview{z-index:1001;background-color:#10b981;border:3px solid #fff;border-radius:50% 50% 50% 0;justify-content:center;align-items:center;width:36px;height:36px;animation:1.5s ease-in-out infinite marker-preview-pulse;display:flex;position:absolute;box-shadow:0 4px 10px #0006,0 0 0 4px #10b9814d}.memo-marker-preview i{color:#fff;font-size:14px;transform:rotate(45deg)}.memo-marker-preview .marker-drag-hint{color:#fff;white-space:nowrap;pointer-events:none;background:#000c;border-radius:4px;padding:2px 6px;font-size:10px;position:absolute;bottom:-28px;left:50%;transform:translate(-50%)rotate(45deg)}@keyframes marker-preview-pulse{0%,to{box-shadow:0 4px 10px #0006,0 0 0 4px #10b9814d}50%{box-shadow:0 4px 10px #0006,0 0 0 8px #10b98133}}.memo-marker-preview.editing{background-color:#f59e0b;animation:1.5s ease-in-out infinite marker-edit-pulse;box-shadow:0 4px 10px #0006,0 0 0 4px #f59e0b4d}@keyframes marker-edit-pulse{0%,to{box-shadow:0 4px 10px #0006,0 0 0 4px #f59e0b4d}50%{box-shadow:0 4px 10px #0006,0 0 0 8px #f59e0b33}}.memo-marker-context-menu{background:#fff;border-radius:8px;min-width:180px;padding:4px;animation:.15s ease-out context-menu-appear;box-shadow:0 4px 20px #00000026,0 0 0 1px #0000000d}@keyframes context-menu-appear{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.memo-marker-context-menu .context-menu-item{cursor:pointer;color:#374151;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:14px;transition:background-color .15s,color .15s;display:flex}.memo-marker-context-menu .context-menu-item:hover{background-color:#f3f4f6}.memo-marker-context-menu .context-menu-item i{text-align:center;color:#6b7280;width:16px}.memo-marker-context-menu .context-menu-item:hover i{color:#374151}.memo-marker-context-menu .context-menu-item.danger{color:#dc2626}.memo-marker-context-menu .context-menu-item.danger:hover{background-color:#fef2f2}.memo-marker-context-menu .context-menu-item.danger i{color:#dc2626}.memo-marker-context-menu .context-menu-divider{background-color:#e5e7eb;height:1px;margin:4px 0}.floating-memo-btn-container{z-index:300;gap:8px;animation:.3s float-in;display:flex;position:absolute;bottom:100px;left:50%;transform:translate(-50%)}@keyframes float-in{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.floating-memo-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:50px;align-items:center;gap:10px;padding:14px 24px;font-size:1rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 8px 25px #2563eb66}.floating-memo-btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px #2563eb80}.floating-memo-btn i{font-size:1.1rem}.floating-memo-btn .stroke-count{background:#fff3;border-radius:20px;padding:2px 10px;font-size:.85rem}.floating-memo-btn.positioning{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 8px 25px #10b98166}.floating-memo-btn.positioning:hover{box-shadow:0 12px 30px #10b98180}.floating-memo-cancel-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.2rem;transition:all .2s;display:flex}.floating-memo-cancel-btn:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.memo-dialog-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.memo-dialog{background:#fff;border-radius:16px;flex-direction:column;width:90%;max-width:480px;max-height:90vh;animation:.3s slideUp;display:flex;overflow:hidden;box-shadow:0 20px 40px #0003}.memo-dialog-header{background:#f8fafc;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.memo-dialog-header h3{color:#1e293b;align-items:center;gap:8px;margin:0;font-size:1.1rem;font-weight:600;display:flex}.memo-dialog-header h3 i{color:var(--primary-color)}.dialog-close-btn{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:6px;padding:8px;transition:all .15s}.dialog-close-btn:hover{color:#1e293b;background:#e5e7eb}.memo-dialog-content{flex-direction:column;gap:16px;padding:20px;display:flex;overflow-y:auto}.stroke-info{color:var(--primary-color);background:#eff6ff;border-radius:8px;align-items:center;gap:8px;padding:12px 16px;font-weight:500;display:flex}.stroke-info i{font-size:1.1rem}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#475569;font-size:.9rem;font-weight:600}.form-group input,.form-group textarea{border:1px solid #e2e8f0;border-radius:8px;padding:12px 14px;font-family:inherit;font-size:1rem;transition:all .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{resize:vertical;min-height:80px}.priority-options{flex-wrap:wrap;gap:8px;display:flex}.priority-option{cursor:pointer;border:2px solid #e2e8f0;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.priority-option input{display:none}.priority-option:hover{border-color:#cbd5e1}.priority-option.selected{border-width:2px}.priority-dot{border-radius:50%;width:10px;height:10px}.memo-dialog-footer{background:#f8fafc;border-top:1px solid #e5e7eb;gap:12px;padding:16px 20px;display:flex}.memo-dialog-footer .btn-secondary{cursor:pointer;color:#475569;background:#fff;border:1px solid #cbd5e1;border-radius:8px;flex:1;padding:12px;font-size:.95rem;font-weight:600;transition:all .2s}.memo-dialog-footer .btn-secondary:hover{background:#f1f5f9}.memo-dialog-footer .btn-primary{background:var(--primary-color);cursor:pointer;color:#fff;border:none;border-radius:8px;flex:2;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.memo-dialog-footer .btn-primary:hover:not(:disabled){background:var(--primary-hover)}.memo-dialog-footer .btn-primary:disabled{opacity:.6;cursor:not-allowed}.memo-panel .panel-content{background:#f8fafc}.empty-memo-list{color:#94a3b8;text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.empty-memo-list i{margin-bottom:16px;font-size:3rem}.empty-memo-list p{margin:0;font-size:.95rem}.empty-memo-list .hint{margin-top:8px;font-size:.85rem}.memo-list-item.highlighted{background:#fef2f2;border-color:#fca5a5}.memo-list-item.expanded{border-color:var(--primary-color);background:#fff}.memo-author-info{flex:1}.memo-badges{gap:6px;display:flex}.priority-badge{border-radius:4px;align-items:center;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.priority-badge.small{padding:2px 6px;font-size:.7rem}.priority-badge-btn{cursor:pointer;border:1px solid;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:.8rem;font-weight:600;transition:all .2s;display:inline-flex}.priority-badge-btn:hover{opacity:.85}.priority-badge-btn .dropdown-arrow{opacity:.7;font-size:.65rem}.dropdown-wrapper.header-dropdown{margin-left:auto;position:relative}.dropdown-wrapper.header-dropdown .dropdown-menu{border:1px solid var(--border-color);z-index:100;background:#fff;border-radius:8px;min-width:120px;margin-top:4px;position:absolute;top:100%;left:auto;right:0;overflow:hidden;box-shadow:0 4px 12px #00000026}.dropdown-wrapper.header-dropdown .dropdown-item{cursor:pointer;width:100%;color:var(--item-color);background:#fff;border:none;align-items:center;gap:8px;padding:10px 12px;font-size:.85rem;transition:background .15s;display:flex}.dropdown-wrapper.header-dropdown .dropdown-item:hover{background:var(--item-bg)}.dropdown-wrapper.header-dropdown .dropdown-item.active{background:var(--item-bg);font-weight:600}.dropdown-wrapper.header-dropdown .dropdown-item .check-icon{margin-left:auto;font-size:.75rem}.memo-actions{border-top:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9;flex-wrap:nowrap;align-items:center;gap:8px;padding:12px 0;display:flex}.memo-actions .action-spacer{flex:1}.action-btn{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:6px;padding:8px 14px;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.action-btn:hover{background:#f1f5f9;border-color:#cbd5e1}.action-btn.highlight-btn.active{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.action-btn.resolve-btn{color:#059669;background:#ecfdf5;border-color:#a7f3d0}.action-btn.resolve-btn:hover{background:#d1fae5}.action-btn.delete-btn{color:#dc2626;background:#fff;border-color:#fecaca}.action-btn.delete-btn:hover{background:#fef2f2}.action-btn.edit-marker-btn{color:#ea580c;background:#fff;border-color:#fed7aa}.action-btn.edit-marker-btn:hover{background:#fff7ed}.action-btn.cancel-btn{color:#6b7280;background:#fff;border-color:#e5e7eb}.action-btn.cancel-btn:hover{background:#f9fafb}.status-actions{gap:6px;display:flex}.memo-actions.icon-only{flex-wrap:nowrap;gap:6px}.memo-actions.icon-only .action-btn,.memo-actions>.action-btn:not(.dropdown-btn){justify-content:center;min-width:36px;padding:8px 10px}.memo-actions .dropdown-wrapper{position:relative}.memo-actions .dropdown-btn{align-items:center;gap:6px;padding:6px 10px;font-weight:500;display:flex}.memo-actions .dropdown-btn .dropdown-arrow{opacity:.7;margin-left:2px;font-size:.7rem}.memo-actions .dropdown-menu{border:1px solid var(--border-color);z-index:100;background:#fff;border-radius:8px;min-width:120px;margin-top:4px;position:absolute;top:100%;left:0;overflow:hidden;box-shadow:0 4px 12px #00000026}.memo-actions .dropdown-item{cursor:pointer;width:100%;color:var(--item-color);background:#fff;border:none;align-items:center;gap:8px;padding:10px 12px;font-size:.85rem;transition:background .15s;display:flex}.memo-actions .dropdown-item:hover{background:var(--item-bg)}.memo-actions .dropdown-item.active{background:var(--item-bg);font-weight:600}.memo-actions .dropdown-item .check-icon{margin-left:auto;font-size:.75rem}.memo-update-history{margin-top:12px}.memo-update-history.empty{color:#94a3b8;background:#f8fafc;border-radius:8px;align-items:center;gap:8px;padding:16px;font-size:.9rem;display:flex}.history-title{color:#475569;cursor:pointer;border-radius:8px;align-items:center;gap:8px;margin:0;padding:10px 12px;font-size:.9rem;font-weight:600;transition:background-color .15s;display:flex}.history-title:hover{background-color:#f1f5f9}.history-title i.fa-clock-rotate-left{color:var(--primary-color)}.history-title .history-count{color:#64748b;background-color:#e2e8f0;border-radius:10px;padding:2px 6px;font-size:.75rem;font-weight:500}.history-title .expand-icon{color:#94a3b8;margin-left:auto;font-size:.75rem;transition:transform .2s}.history-title .expand-icon.rotated{transform:rotate(180deg)}.memo-update-history.collapsed,.memo-update-history.expanded{border-top:1px solid var(--border-color);margin-top:16px}.memo-update-history.expanded .history-title{margin-bottom:12px}.history-timeline{flex-direction:column;gap:12px;display:flex}.history-item{gap:12px;display:flex}.history-icon{width:32px;height:32px;color:var(--primary-color);background:#eff6ff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;display:flex}.history-content{flex:1;min-width:0}.history-header{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.history-author{color:#1e293b;font-size:.85rem;font-weight:600}.history-type{color:#94a3b8;font-size:.75rem}.history-time{color:#94a3b8;margin-left:auto;font-size:.75rem}.history-body{color:#475569;font-size:.85rem}.change-detail{align-items:center;gap:6px;display:flex}.change-detail .old-value{color:#94a3b8;text-decoration:line-through}.change-detail .new-value{color:var(--primary-color);font-weight:500}.comment-text{background:#f8fafc;border-radius:6px;margin-top:4px;padding:8px 12px;display:block}@media(max-width:768px){.floating-memo-btn-container{bottom:80px}.floating-memo-btn{padding:12px 20px;font-size:.9rem}.memo-dialog{max-width:none;margin:16px}.priority-options{flex-direction:column}.priority-option{justify-content:center;width:100%}.memo-actions{flex-direction:column}.action-btn{justify-content:center;width:100%}.status-actions{flex-direction:column;width:100%}}.viewer-content.selection-mode{cursor:crosshair}.viewer-content.selection-mode.panning{cursor:grabbing}.tool-btn.active{color:#fff;background-color:#3b82f6}@media(pointer:coarse){.viewer-content.selection-mode{touch-action:none}}.language-selector{position:relative}.language-selector.collapsed{justify-content:center;padding:.75rem;display:flex}.language-selector.expanded{align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.language-selector .language-icon{text-align:center;width:20px;color:var(--text-light);flex-shrink:0;font-size:1rem}.language-selector-btn{border-radius:var(--radius-md);color:var(--text-light);cursor:pointer;background:0 0;border:none;flex:1;align-items:center;gap:.75rem;padding:0;font-size:.875rem;transition:background-color .2s;display:flex}.language-selector.collapsed .language-selector-btn{flex:none;justify-content:center;width:auto;padding:.75rem}.language-selector.collapsed .language-selector-btn:hover,.language-selector.collapsed .language-selector-btn.active{background-color:#ffffff1a}.language-selector.expanded{border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s}.language-selector.expanded:hover{background-color:#ffffff1a}.language-selector-content{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.language-selector-content .language-flag{flex-shrink:0;font-size:1rem}.language-selector-content .language-name{text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.language-selector-content .chevron{flex-shrink:0;margin-left:auto;font-size:.75rem;transition:transform .2s}.language-selector-content .chevron.open{transform:rotate(180deg)}.language-dropdown{border-radius:var(--radius-md);z-index:1000;background:#1e293b;border:1px solid #ffffff1a;flex-direction:column;display:flex;position:absolute;overflow:hidden;box-shadow:0 -4px 20px #0000004d}.language-dropdown.upward{margin-bottom:4px;bottom:100%;left:0;right:0}.language-selector.collapsed .language-dropdown.upward{width:220px;margin-bottom:4px;margin-left:0;bottom:100%;left:0;right:auto}.language-dropdown-header{text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;background:#1e293b;border-bottom:1px solid #ffffff1a;flex-shrink:0;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.language-options-list{flex:1;overflow-y:auto}.language-option{color:#cbd5e1;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.625rem 1rem;font-size:.875rem;transition:background-color .15s;display:flex}.language-option:hover{background-color:#ffffff14}.language-option.active{color:#93c5fd;background-color:#3b82f633}.language-option .language-flag{flex-shrink:0;font-size:1rem}.language-option .language-name{flex:1}.language-option i.fa-check{color:#3b82f6;flex-shrink:0;font-size:.75rem}.language-options-list::-webkit-scrollbar{width:6px}.language-options-list::-webkit-scrollbar-track{background:0 0}.language-options-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.language-options-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
