:root,:host{--ol-background-color: white;--ol-accent-background-color: #F5F5F5;--ol-subtle-background-color: rgba(128, 128, 128, .25);--ol-partial-background-color: rgba(255, 255, 255, .75);--ol-foreground-color: #333333;--ol-subtle-foreground-color: #666666;--ol-brand-color: #00AAFF}.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:var(--ol-foreground-color);font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{width:1px;height:15px;background-color:var(--ol-foreground-color);float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:10px;z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{position:absolute;font-size:12px;text-align:center;bottom:25px;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color)}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:var(--ol-subtle-background-color);border-radius:4px}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:var(--ol-subtle-foreground-color);font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:var(--ol-background-color);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{text-decoration:none;outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}.ol-overviewmap .ol-viewport:hover{cursor:pointer}:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#111827;background:#eef2f7}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{margin:0;min-width:0;max-width:100vw;overflow:hidden}button,input,select,textarea{font:inherit}button{border:1px solid #d1d5db;background:#fff;color:#111827;border-radius:6px;min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer}button:hover,button.active{background:#0f172a;border-color:#0f172a;color:#fff}button:disabled,button:disabled:hover,input:disabled,textarea:disabled{cursor:not-allowed;opacity:.58}input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:6px;padding:8px 10px;background:#fff}textarea{min-height:78px;resize:vertical}.app-shell{width:100vw;max-width:100vw;overflow:hidden;height:100vh;height:100dvh;display:grid;grid-template-rows:auto 1fr auto}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:grid;place-items:center;background:#0f172a85;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.auth-card{width:min(380px,calc(100vw - 32px));display:grid;gap:12px;padding:24px;border:1px solid #dbe3ef;border-radius:8px;background:#fff;box-shadow:0 24px 60px #0f172a47}.auth-card h1{margin:0;font-size:22px;letter-spacing:0}.auth-card p{margin:0;font-size:13px;color:#475569}.topbar,.statusbar{background:#fff;border-bottom:1px solid #dbe3ef;display:flex;align-items:center;padding:0 12px;gap:12px;z-index:5}.topbar{min-height:52px;flex-wrap:wrap;padding-block:7px}.brand{display:flex;align-items:center;gap:8px;min-width:220px;font-weight:800}.brand input{border:0;font-weight:800;padding-left:0}.topbar nav{display:flex;gap:8px;flex-wrap:wrap;min-width:0}.user-chip{margin-left:auto;min-width:190px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:2px 8px;font-size:12px;color:#334155}.user-chip span{font-weight:800}.user-chip small{grid-column:1;color:#64748b}.user-chip button{grid-row:1 / span 2;grid-column:2;min-height:30px;padding:0 9px}.workspace{height:100%;min-height:0;display:grid;grid-template-columns:auto 1fr auto;position:relative;overflow:hidden}.admin-panel{position:absolute;top:12px;left:12px;z-index:12;width:360px;max-height:calc(100% - 24px);overflow:auto;padding:14px;border:1px solid #dbe3ef;border-radius:8px;background:#fffffffa;box-shadow:0 18px 44px #0f172a2e}.user-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;padding:9px 0;border-bottom:1px solid #eef2f7}.user-row div{min-width:0;display:grid;gap:2px}.user-row b,.user-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-row span{font-size:12px;color:#64748b}.user-row button{min-height:30px;padding:0 9px}.admin-page{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;grid-template-rows:auto 1fr;gap:14px;padding:18px;overflow:auto;background:#eef2f7}.admin-page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:14px;border-bottom:1px solid #dbe3ef}.admin-page-header h1{margin:0;font-size:22px;letter-spacing:0}.admin-page-header p{margin:4px 0 0;color:#64748b;font-size:13px}.admin-page-actions,.table-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-page-actions button,.table-actions button{padding:0 10px;white-space:nowrap}.admin-layout{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:16px;align-items:start}.user-editor,.users-table-wrap{padding:14px;border:1px solid #dbe3ef;border-radius:8px;background:#fff;box-shadow:0 14px 34px #0f172a14}.users-table-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.users-table-header h2{margin:0}.users-table-header span{font-size:12px;font-weight:800;color:#475569}.users-table{display:grid;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.users-table-row{display:grid;grid-template-columns:minmax(120px,1fr) 150px 120px minmax(240px,auto);gap:10px;align-items:center;min-height:48px;padding:9px 12px;border-bottom:1px solid #e2e8f0;background:#fff;font-size:13px}.users-table-row:last-child{border-bottom:0}.users-table-heading{min-height:38px;background:#f8fafc;color:#475569;font-size:12px;font-weight:800;text-transform:uppercase}.role-badge{width:max-content;padding:4px 8px;border:1px solid #bfdbfe;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-size:12px;font-weight:800}.role-badge.admin{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.side-panel{width:320px;overflow:auto;background:#fffffff5;border-right:1px solid #dbe3ef;padding:14px;z-index:4}.left-panel{grid-column:1}.right-panel{grid-column:3;border-right:0;border-left:1px solid #dbe3ef}section+section{margin-top:18px;padding-top:16px;border-top:1px solid #e5e7eb}h2{margin:0 0 10px;font-size:14px;letter-spacing:0;text-transform:uppercase;color:#334155}label{display:grid;gap:5px;margin:9px 0;font-size:12px;font-weight:700;color:#475569}.segmented-list{display:grid;gap:8px}.segmented-list button{justify-content:flex-start;padding:0 10px}.coordinate-panel{display:grid;gap:9px}.coordinate-tabs,.coordinate-actions{display:grid;gap:6px}.coordinate-tabs{grid-template-columns:repeat(3,1fr)}.coordinate-tabs button,.coordinate-actions button{min-width:0;padding:0 8px;font-size:12px;font-weight:800}.coordinate-actions{grid-template-columns:1fr 1fr 1fr 34px}.coordinate-actions button:last-child{padding:0}.coordinate-readout{display:grid;gap:3px;padding:8px 10px;border:1px solid #dbe3ef;border-radius:6px;background:#f8fafc;color:#334155}.coordinate-readout span,.coordinate-readout small{min-width:0;overflow-wrap:anywhere}.coordinate-readout span{font-size:12px;font-weight:800}.coordinate-readout small{font-size:11px;color:#64748b}.layer-row{display:grid;grid-template-columns:34px 1fr 74px 34px;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid #eef2f7}.layer-row span{font-size:13px;font-weight:650}.grid-layer-row{border-color:#bfdbfe;background:#eff6ff}.grid-layer-row small{margin-left:auto;font-size:11px;font-weight:800;color:#2563eb}.map-stage{grid-column:2;position:relative;min-width:0;min-height:0;overflow:hidden}.map{position:absolute;top:0;right:0;bottom:0;left:0;background:#cbd5e1;touch-action:none}.toolbar{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:3;display:flex;flex-wrap:wrap;justify-content:center;gap:6px;padding:7px;max-width:calc(100% - 96px);background:#fffffff0;border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 12px 28px #0f172a29}.panel-toggles{position:absolute;left:12px;top:12px;z-index:11;display:flex;gap:6px;padding:7px;border:1px solid #dbe3ef;border-radius:8px;background:#fffffff0;box-shadow:0 12px 28px #0f172a29}.panel-toggles button,.toolbar button{width:34px;height:34px;padding:0}.toolbar .scale-button{width:auto;min-width:58px;padding:0 10px;font-size:12px;font-weight:800}.toolbar .finish-tool-button{background:#fee2e2;border-color:#fecaca;color:#b91c1c}.toolbar .finish-tool-button:hover{background:#fecaca;border-color:#fca5a5}.panel-finish-button{width:34px;height:34px;min-width:34px;padding:0;background:#fee2e2;border-color:#fecaca;color:#b91c1c}.panel-finish-button:hover{background:#fecaca;border-color:#fca5a5}.pen-panel{position:absolute;top:66px;left:50%;transform:translate(-50%);z-index:4;width:min(560px,calc(100% - 28px));display:grid;grid-template-columns:auto 1fr 120px 120px auto;align-items:center;gap:10px;padding:9px 10px;border:1px solid #dbe3ef;border-radius:8px;background:#fffffff5;box-shadow:0 12px 28px #0f172a29}.tool-options-panel{position:absolute;top:66px;left:50%;transform:translate(-50%);z-index:4;width:min(760px,calc(100% - 28px));display:flex;align-items:center;gap:10px;padding:9px 10px;border:1px solid #dbe3ef;border-radius:8px;background:#fffffff5;box-shadow:0 12px 28px #0f172a29;overflow-x:auto}.tool-options-panel label{min-width:110px;margin:0;gap:3px}.tool-options-panel input[type=color]{width:42px;height:34px;padding:3px}.segmented-tools,.text-style-buttons{display:flex;align-items:center;gap:6px}.segmented-tools button{min-width:72px;padding:0 10px;font-size:12px;font-weight:800}.tactical-options{width:min(920px,calc(100% - 28px))}.tactical-options .segmented-tools{max-width:560px;overflow-x:auto;padding-bottom:2px}.tactical-options .segmented-tools button{min-width:max-content;white-space:nowrap}.text-style-buttons button{width:34px;height:34px;padding:0}.pen-panel label{margin:0;gap:3px}.pen-modes,.color-row,.pen-actions{display:flex;align-items:center;gap:6px}.pen-modes button,.pen-actions button{width:34px;height:34px;padding:0}.color-row{flex-wrap:wrap}.swatch{width:24px;height:24px;min-height:24px;padding:0;border-radius:50%;border:2px solid #ffffff;box-shadow:0 0 0 1px #cbd5e1}.swatch.active{box-shadow:0 0 0 2px #0f172a}.toolbar svg,button svg{width:17px;height:17px}.north-arrow{position:absolute;right:18px;top:18px;z-index:3;width:42px;height:42px;border-radius:50%;border:2px solid #0f172a;background:#fffffff0;display:grid;place-items:center;font-weight:900}.resize-frame{position:absolute;z-index:4;border:1px solid #2563eb;outline:1px solid rgba(255,255,255,.9);pointer-events:none}.resize-frame.locked{border-color:#64748b;border-style:dashed}.resize-handle{position:absolute;width:12px;height:12px;min-height:12px;padding:0;border-radius:2px;border:2px solid #ffffff;background:#2563eb;box-shadow:0 1px 4px #0f172a4d;pointer-events:auto}.resize-handle:hover{background:#1d4ed8;border-color:#fff}.resize-handle-nw{left:-7px;top:-7px;cursor:nwse-resize}.resize-handle-ne{right:-7px;top:-7px;cursor:nesw-resize}.resize-handle-sw{left:-7px;bottom:-7px;cursor:nesw-resize}.resize-handle-se{right:-7px;bottom:-7px;cursor:nwse-resize}.primary-action{width:100%;background:#0f172a;border-color:#0f172a;color:#fff}.catalog-summary,.symbol-preview,.search-box{display:flex;align-items:center;gap:8px}.affiliation-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:10px 0}.affiliation-tabs button{min-width:0;padding:0 8px;font-size:12px;font-weight:800}.upload-actions{display:grid;grid-template-columns:1fr;gap:8px;margin:10px 0 12px}.upload-actions button{min-width:0;padding:0 8px;font-size:12px;font-weight:800}.collapse-gallery-button{width:100%;justify-content:center;gap:8px;margin:4px 0 10px;font-weight:800}.symbol-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0}.symbol-card{position:relative;min-width:0;height:118px;display:block;padding:0;background:#f8fafc;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.symbol-card:active{cursor:grabbing}.symbol-main{width:100%;height:100%;min-height:0;display:grid;grid-template-rows:72px 1fr;justify-items:center;align-items:center;padding:8px;gap:6px;border:0;border-radius:0;background:transparent;cursor:grab}.symbol-main img{width:72px;height:72px;object-fit:contain;border:1px solid #e2e8f0;border-radius:6px;background:#fff}.symbol-main span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:800}.symbol-delete{position:absolute;top:6px;right:6px;width:28px;height:28px;min-height:28px;padding:0;border-color:#fecaca;background:#fffffff0;color:#b91c1c}.symbol-delete:hover{background:#b91c1c;border-color:#b91c1c;color:#fff}.empty-gallery{min-height:96px;display:grid;place-items:center;padding:14px;border:1px dashed #cbd5e1;border-radius:6px;background:#f8fafc;color:#64748b;font-size:13px;text-align:center}.catalog-summary{min-height:34px;padding:8px 10px;border:1px solid #dbe3ef;border-radius:6px;background:#f8fafc;font-size:12px;font-weight:750;color:#334155}.search-box{border:1px solid #cbd5e1;border-radius:6px;background:#fff;padding-left:9px}.size-controls{display:grid;grid-template-columns:1fr 72px;gap:8px;align-items:center}.search-box input{border:0;padding-left:0}.symbol-preview{align-items:flex-start;padding:10px;border:1px solid #dbe3ef;border-radius:6px;background:#f8fafc;cursor:grab;-webkit-user-select:none;user-select:none}.symbol-preview:active{cursor:grabbing}.symbol-preview img{width:58px;height:58px;object-fit:contain;background:#fff;border:1px solid #e2e8f0;border-radius:6px}.symbol-preview div{min-width:0;display:grid;gap:3px;font-size:12px;color:#475569}.symbol-preview b,.symbol-preview span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.properties p,.muted{font-size:13px;color:#475569;margin:7px 0}.property-header{display:flex;align-items:center;justify-content:space-between;min-height:36px;padding:8px 10px;border:1px solid #dbe3ef;border-radius:6px;background:#f8fafc;font-size:12px;font-weight:800;color:#334155}.lock-toggle{width:28px;height:28px;min-height:28px;padding:0}.button-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.statusbar{border-top:1px solid #dbe3ef;border-bottom:0;justify-content:space-between;font-size:12px;color:#334155;min-height:32px;flex-wrap:wrap;padding-block:6px}.hidden{display:none}.ol-scale-bar{left:18px;bottom:18px}@media(max-width:1180px){.app-shell{grid-template-rows:auto 1fr auto}.topbar{align-items:flex-start}.brand{flex:1 1 260px}.topbar nav{order:3;flex:1 1 100%;flex-wrap:nowrap;max-width:100%;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin}.topbar nav button{flex:0 0 auto;min-width:0;padding:0 8px;white-space:nowrap}.admin-page{padding:12px}.admin-page-header,.admin-layout{display:grid}.admin-layout{grid-template-columns:1fr}.users-table{overflow-x:auto}.users-table-row{min-width:780px}.user-chip{min-width:170px}.workspace{display:grid;grid-template-columns:1fr}.side-panel,.admin-panel{position:absolute;top:12px;max-height:calc(100% - 24px);z-index:8;border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 18px 44px #0f172a33}.side-panel{width:min(340px,calc(100vw - 32px))}.left-panel{left:12px}.right-panel{right:12px}.map-stage{width:100%;height:100%;grid-column:1;grid-row:1}.toolbar{top:12px;left:74px;right:auto;width:calc(100vw - 86px);transform:none;max-width:none;flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;scrollbar-width:thin}.pen-panel{top:112px;grid-template-columns:auto 1fr auto}.tool-options-panel{top:112px;left:12px;right:12px;width:auto;transform:none}.pen-panel label{grid-column:span 1}}@media(max-width:820px){.topbar{gap:8px}.brand{min-width:0;flex-basis:100%}.user-chip{order:2;margin-left:0;flex:1 1 100%}.topbar nav button{font-size:12px}.toolbar{top:12px;left:12px;right:auto;width:calc(100vw - 88px)}.panel-toggles{right:12px;left:auto}.pen-panel{top:66px;grid-template-columns:1fr}.tool-options-panel{top:66px}.pen-modes,.color-row,.pen-actions{justify-content:center}.north-arrow{top:auto;right:12px;bottom:54px}.statusbar{justify-content:flex-start}}
