:root{color:#142025;font-synthesis:none;text-rendering:optimizelegibility;background:#eef1f3;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}button,input,select{font:inherit}.app-frame{background:#edf1f4;grid-template-rows:56px minmax(0,1fr);width:100%;height:100%;display:grid;overflow:hidden}.toolbar{background:#f9faf9;border-bottom:1px solid #c9d2d7;grid-template-columns:minmax(220px,280px) minmax(180px,360px) auto minmax(270px,1fr) auto;align-items:center;gap:14px;padding:8px 14px;display:grid}.brand-block{align-items:center;gap:10px;min-width:0;display:flex}.brand-mark{background:linear-gradient(135deg,#2f6172f2,#368469d1),repeating-linear-gradient(0deg,#0000 0 5px,#ffffff38 5px 6px);border:1px solid #2f6172;border-radius:8px;flex:none;width:30px;height:30px}.brand-title{color:#15262d;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:680;line-height:18px;overflow:hidden}.brand-subtitle{color:#5b6d75;font-size:11px;line-height:14px}.slide-select{color:#18282e;background:#fff;border:1px solid #b8c5ca;border-radius:6px;width:100%;min-width:0;height:36px;padding:0 12px}.tool-group{align-items:center;gap:6px;display:flex}.icon-button{color:#1d343b;cursor:pointer;background:#fff;border:1px solid #b7c5ca;border-radius:6px;place-items:center;width:36px;height:36px;display:inline-grid}.icon-button:hover{background:#eef7f6;border-color:#548094}.icon-button:active{background:#dceeed}.session-actions{justify-content:flex-end;align-items:center;gap:8px;min-width:0;display:flex}.session-user{color:#44565e;text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:12px;overflow:hidden}.status-strip{color:#4d5e65;justify-content:flex-end;gap:8px;min-width:0;font-size:12px;line-height:1;display:flex}.status-strip span{white-space:nowrap;background:#fff;border:1px solid #cdd6da;border-radius:999px;min-width:0;padding:6px 8px}.viewer-area{min-width:0;min-height:0;position:relative;overflow:hidden}.viewer-shell{cursor:grab;touch-action:none;background-color:#eef1f3;background-image:linear-gradient(90deg,#17242a0d 1px,#0000 1px),linear-gradient(0deg,#17242a0d 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:32px 32px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;position:absolute;inset:0;overflow:hidden}.viewer-shell:active{cursor:grabbing}.viewer-shell:focus{outline:none}.viewer-shell:focus-visible{outline-offset:-2px;outline:2px solid #39738657}.viewer-canvas{width:100%;height:100%;display:block}.overview-map{cursor:crosshair;background:#fff;border:1px solid #324b5485;border-radius:6px;width:min(220px,24vw);max-height:180px;padding:0;display:block;position:absolute;bottom:14px;right:14px;overflow:hidden;box-shadow:0 12px 24px #1420252e}.overview-map:focus{outline:none}.overview-map:focus-visible{outline-offset:2px;outline:2px solid #ffbf47d1}.overview-map img{object-fit:fill;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:block}.overview-viewport{pointer-events:none;background:#ffbf4724;border:2px solid #ffbf47;min-width:6px;min-height:6px;position:absolute;box-shadow:0 0 0 1px #1420257a}.error-banner{color:#4b1518;background:#fff4f4;border:1px solid #e1a6ad;border-radius:6px;max-width:min(520px,100% - 28px);padding:10px 12px;font-size:13px;position:absolute;bottom:14px;left:14px;box-shadow:0 12px 24px #1420251f}.empty-state{background:#eef1f3;position:absolute;inset:0}.auth-frame{grid-template-rows:minmax(0,1fr)}.auth-screen{background-color:#eef1f3;background-image:linear-gradient(90deg,#17242a0d 1px,#0000 1px),linear-gradient(0deg,#17242a0d 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:32px 32px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;place-items:center;min-width:0;min-height:0;padding:24px;display:grid;position:relative}.auth-panel{background:#f9faf9;border:1px solid #c4ced3;border-radius:8px;gap:14px;width:min(360px,100%);padding:20px;display:grid;box-shadow:0 16px 36px #14202524}.auth-brand{margin-bottom:4px}.field-label{color:#44565e;gap:6px;font-size:12px;font-weight:620;display:grid}.field-label input{color:#18282e;background:#fff;border:1px solid #b8c5ca;border-radius:6px;width:100%;height:38px;padding:0 11px}.field-label input:focus{outline-offset:0;border-color:#397386;outline:2px solid #3973862e}.primary-button{color:#fff;cursor:pointer;background:#2f6172;border:1px solid #2f6172;border-radius:6px;justify-content:center;align-items:center;gap:8px;height:38px;font-weight:650;display:inline-flex}.primary-button:hover{background:#285464}.primary-button:disabled{cursor:wait;opacity:.72}.auth-error{bottom:24px;left:50%;right:auto;transform:translate(-50%)}@media (width<=900px){.toolbar{grid-template-rows:36px 36px;grid-template-columns:minmax(120px,1fr) auto auto;height:auto}.app-frame{grid-template-rows:96px minmax(0,1fr)}.slide-select{grid-area:2/1/auto/-1}.tool-group{grid-area:1/2;gap:4px}.session-actions{grid-area:1/3}.status-strip,.session-user{display:none}.overview-map{width:min(160px,38vw);max-height:132px;bottom:10px;right:10px}}
