:root{--trackman-orange: #ec691a;--trackman-orange-hover: #d35a15;--trackman-orange-active: #ba4b11;--trackman-orange-light: rgba(236, 105, 26, .1);--trackman-orange-shadow: rgba(236, 105, 26, .55);--color-success: #10b981;--color-error: #ef4444;--color-warning: #f59e0b;--color-info: #3b82f6;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--text-primary: #1f2937;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--text-inverse: #ffffff;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--border-light: #e5e7eb;--border-medium: #d1d5db;--border-dark: #9ca3af}body{margin:0;font-family:sans-serif;background:#f8f8f8}h1{text-align:center;margin-top:24px}.doc-viewer-layout{display:flex;height:100%}.doc-toc{width:250px;border-right:1px solid #ccc;padding:20px;background-color:#f5f5f5}.doc-toc ul{list-style:none;padding:0;margin:0}.doc-toc button{border:none;padding:8px 12px;cursor:pointer;width:100%;text-align:left;border-radius:4px}.doc-toc button.active{background:var(--trackman-orange);color:#fff}.doc-content-area{flex:1;padding:20px;overflow:auto}.doc-markdown-box{background-color:#fff;padding:20px;border-radius:4px;border:1px solid #ddd;line-height:1.6}.doc-markdown-box a,.markdown-content a{color:var(--trackman-orange);text-decoration:none;font-weight:500;transition:color .2s ease}.doc-markdown-box a:hover,.markdown-content a:hover{color:var(--trackman-orange-hover);text-decoration:underline}.doc-markdown-box a:visited,.markdown-content a:visited{color:var(--trackman-orange)}.topbar-avatar-wrapper{display:inline-block;position:relative}.topbar-user-menu-absolute{position:absolute;right:0;top:56px;z-index:1000}.logout-center{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f5f5f5;font-family:system-ui,-apple-system,sans-serif}.logout-box{padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;text-align:center;max-width:400px}.logout-spinner-wrap{margin-top:1rem;padding:.5rem;background-color:#f8f9fa;border-radius:4px;font-size:.9em;color:#666}.logout-spinner{display:inline-block;width:16px;height:16px;border:2px solid #ddd;border-top:2px solid var(--trackman-orange);border-radius:50%;animation:spin 1s linear infinite;margin-right:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.logout-emoji{font-size:48px;margin-bottom:1rem}.logout-heading{margin:0 0 1rem;color:#333}.logout-text{margin:0;color:#666}.top-bar-user-menu-row{display:flex;align-items:center;gap:12px}.top-bar-user-menu-link{text-decoration:none;background:none;border:none;width:100%;text-align:left;color:inherit;padding:0}.top-bar-app-icon{height:32px;width:32px;display:inline-block;margin-right:8px}.top-bar-user-menu{position:absolute;top:56px;right:0;margin-top:-16px;background-color:#fff;color:#000000de;box-shadow:#0003 0 5px 5px -3px,#00000024 0 8px 10px 1px,#0000001f 0 3px 14px 2px;overflow:visible;min-width:240px;max-width:320px;border-radius:18px;z-index:2000;display:flex;flex-direction:column;align-items:center;border:none}.top-bar-user-menu-title{margin:0;--base: 1rem;font-size:calc(var(--base) * .8125);font-weight:700;line-height:1.4;padding:10px;font-size:14px;text-align:left}.top-bar-user-menu-divider{display:block;margin-block-start:.5em;margin-block-end:.5em;margin-inline-start:auto;margin-inline-end:auto;color:gray;unicode-bidi:isolate;overflow:hidden;border-style:inset;border-width:1px;width:-webkit-fill-available}.top-bar-user-menu-item{margin:0;color:#414141;--base: 1rem;font-size:calc(var(--base) * .8125);font-weight:400;line-height:1.4;background:none;border:none;text-align:left;padding:10px;cursor:pointer;border-radius:6px;transition:background .15s;display:flex;align-items:center}.top-bar-user-menu-item:hover{background:#f8f8f8}.top-bar-user-image img{width:100%;height:100%;object-fit:cover}.top-bar-user-image{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.25rem;line-height:1;border-radius:50%;overflow:hidden;width:32px;height:32px;-webkit-user-select:none;user-select:none}.top-bar-user-menu{overflow:visible}.top-bar-user-image-clickable{cursor:pointer;width:32px;height:32px;background-color:#fff;margin-left:12px}.top-bar-user{margin-left:16px;font-weight:500;color:var(--trackman-orange)}.node-editor{display:flex;flex-direction:column;height:100%}.tab-panel{flex:1;overflow-y:auto;padding:10px}.tab-panel{padding:10px}html,body,#root{height:100%;font-family:system-ui,Segoe UI,Roboto,Oxygen,sans-serif;background:#f5f7fa;color:#2d3a45;margin:0;padding:0;overflow:hidden}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.tree-flex{display:flex;flex:1;background:linear-gradient(135deg,#fff,#f5f7fa 60%,#edf1f5);min-height:0}.top-bar{background:#2a2a2a;color:#fff;height:48px;min-height:48px;max-height:48px;display:flex;align-items:center;padding:0 20px;box-shadow:0 2px 4px #0000001a;z-index:1000;flex-shrink:0}.top-bar-content{display:flex;align-items:center;justify-content:space-between;width:100%}.top-bar-left{display:flex;align-items:center;gap:20px;flex:1}.top-bar-right{display:flex;align-items:center;gap:12px;position:relative;overflow:visible}.top-bar-auth{display:flex;align-items:center}.top-bar-auth .auth-button{padding:6px 12px;border:1px solid rgba(255,255,255,.3);border-radius:4px;background:#ffffff1a;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:4px}.top-bar-auth .auth-button:hover{background:#fff3;border-color:#ffffff80}.top-bar-auth .auth-button.login{background:var(--trackman-orange);border-color:var(--trackman-orange)}.top-bar-auth .auth-button.login:hover{background:var(--trackman-orange-hover);border-color:var(--trackman-orange-hover)}.top-bar-auth .auth-button.logout{background:#ef4444;border-color:#ef4444}.top-bar-auth .auth-button.logout:hover{background:#dc2626;border-color:#dc2626}.top-bar-auth .auth-loading{color:#fff;font-size:14px;opacity:.8}.top-bar-logo{display:flex;align-items:center}.top-bar-title{font-size:16px;font-weight:600;letter-spacing:.5px;color:#fff}.top-bar-facility-selector{margin-left:8px}.tree-sidebar{width:340px;display:flex;flex-direction:column;background:#fff;border-right:1px solid #e2e8ef;box-shadow:2px 0 6px -2px #0000000f;position:relative;min-height:0}.sidebar-content{flex:1;overflow-y:auto;min-height:0;padding:4px}.tree-container{padding:0 0 40px}.sidebar-content::-webkit-scrollbar{width:10px}.sidebar-content::-webkit-scrollbar-track{background:#fff}.sidebar-content::-webkit-scrollbar-thumb{background:#d4dde4;border-radius:6px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#c2ccd5}.file-operations-section,.bay-operations-section,.edit-operations-section{margin-bottom:20px;width:100%;box-sizing:border-box}.file-operations-section{margin-top:24px}.section-title{margin:16px 16px 8px;font-size:13px;font-weight:600;color:#6a7782;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8ef;padding-bottom:4px}.file-buttons,.bay-buttons,.edit-buttons{display:flex;flex-direction:column;gap:8px;padding:0 16px;width:100%;box-sizing:border-box}.tree-btn{margin:0;background:var(--trackman-orange);color:#fff;border:none;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:600;letter-spacing:.3px;cursor:pointer;transition:.15s background,.15s transform,.15s box-shadow;display:flex;align-items:center;gap:8px;box-shadow:0 4px 10px -4px var(--trackman-orange-shadow);justify-content:flex-start}.tree-btn svg{flex-shrink:0;opacity:.9}.tree-btn:hover:not(:disabled){background:#ff8d26;box-shadow:0 6px 14px -4px var(--trackman-orange-shadow)}.tree-btn:hover:not(:disabled) svg{opacity:1}.tree-btn:active:not(:disabled){transform:translateY(2px);background:#f06f00}.tree-btn:disabled{background:#e1e6ea;color:#94a3af;cursor:not-allowed;box-shadow:none;border:1px solid #d0d7dd}.tree-btn:disabled svg{opacity:.5}.bay-selector{position:relative;width:100%}.bay-selector-button{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f8fafc;border:1px solid #e2e8ef;border-radius:8px;color:#374151;font-size:14px;cursor:pointer;transition:all .2s ease;justify-content:space-between;font-weight:500;width:100%;max-width:none;min-width:0;box-sizing:border-box}.bay-selector-button:hover:not(.disabled):not(.loading):not(.error){background:#f1f5f9;border-color:#cbd5e1}.bay-selector-button.disabled{background:#f1f5f9;color:#9ca3af;cursor:not-allowed;opacity:.7}.bay-selector-button.loading{background:#f8fafc;color:#6b7280;cursor:wait}.bay-selector-button.error{background:#fef2f2;border-color:#fecaca;color:#dc2626}.bay-selector-button.open{background:#fff;border-color:var(--trackman-orange);box-shadow:0 0 0 3px var(--trackman-orange-light)}.bay-selector-arrow{transition:transform .2s ease;flex-shrink:0}.bay-selector-arrow.open{transform:rotate(180deg)}.bay-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:4px;max-height:300px;overflow-y:auto}.bay-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;cursor:pointer;transition:background-color .15s ease;border-bottom:1px solid #f3f4f6}.bay-item:last-child{border-bottom:none}.bay-item:hover{background-color:#f8fafc}.bay-item.selected{background-color:#fff7ed;border-color:#fed7aa}.bay-item.clear-selection{color:#6b7280;font-style:italic;border-bottom:1px solid #e5e7eb!important}.bay-item.clear-selection:hover{background-color:#f9fafb;color:#374151}.bay-item.no-bays{color:#9ca3af;cursor:default;font-style:italic}.bay-item.no-bays:hover{background-color:transparent}.bay-info{flex:1;min-width:0}.bay-name{font-weight:500;color:#111827;font-size:14px;line-height:1.4}.bay-location{color:#6b7280;font-size:12px;margin-top:2px}.bay-item .checkmark{color:var(--trackman-orange);flex-shrink:0}.mini-btn{margin-left:auto;cursor:pointer;background:#f0f3f6;color:#6a7782;border:1px solid #d3dde5;border-radius:4px;padding:2px 6px;font-size:11px;line-height:1;transition:.15s background,.15s color,.15s border;flex-shrink:0}.tree-item-container{display:flex;align-items:flex-start;gap:4px;width:100%}.mini-btn:hover{background:#ffe5cc;border-color:#ffb374;color:#8a4a00}.mini-btn:active{background:#ffd2a8}ul{list-style:none;margin:0;padding:0}.tree-container h2{margin:0 0 10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.1px;color:#7b8a96;padding:0 16px}.tree-section-header{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#8a949e;margin:8px 0 4px;padding:0 20px}.message-editor{margin-bottom:16px;background:#fff;border:1px solid #e2e8ef;border-radius:8px;padding:12px}.message-title{font-size:11px;font-weight:600;color:#6a7782;text-transform:uppercase;letter-spacing:.7px;margin:0 0 12px;padding:0 0 6px;border-bottom:1px solid #d3dde5}.setup-editor{margin-bottom:16px}.setup-type-switch{display:flex;gap:8px}.setup-type-btn{padding:8px 16px;border:1px solid #d3dde5;border-radius:6px;background:#f8fafc;color:#2d3a45;font-size:13px;cursor:pointer;transition:all .15s ease;font-weight:500}.setup-type-btn:hover{background:#f1f5f9;border-color:#cbd5e1}.setup-type-btn.active{background:var(--trackman-orange);color:#fff;border-color:var(--trackman-orange)}.setup-type-btn.active:hover{background:var(--trackman-orange-hover);border-color:#ff8d26}.tree-activity,.tree-step{position:relative;display:flex;flex-direction:column;align-items:flex-start;padding:6px 10px 6px 12px;margin:2px;border-radius:6px;font-size:13px;line-height:1.2;cursor:pointer;transition:.12s background,.12s color,.12s box-shadow;flex:1;min-width:0}.tree-activity{font-weight:600;color:#1d3647;background:#eef3f7}.tree-step{margin-left:22px;color:#374c59;background:#f5f8fa}.tree-node-id{font-weight:700;font-size:13px;line-height:1.1;margin-bottom:2px}.tree-node-type{font-weight:400;font-size:11px;line-height:1.1;opacity:.8;font-style:italic}.tree-activity:hover{background:#ffefe3;color:#5a2d00}.tree-step:hover{background:#fff5ec;color:#6d3a00}li{position:relative}li ul{margin-left:14px;padding-left:14px;border-left:1px solid #d9e2ea}.tree-step:before{content:"└";position:absolute;left:-16px;color:#c4cfd7}.tree-selected{outline:2px solid #ff9a40;outline-offset:-1px;background:#ffecdd!important;color:#5a2d00!important;box-shadow:0 0 0 2px #ff9a4059}.tree-main{flex:1;padding:0;overflow-y:auto;background:linear-gradient(160deg,#fff,#f5f7fa 70%,#eef2f6);min-height:0}.tree-main h2{margin-top:0;font-weight:600;font-size:22px;letter-spacing:.4px;color:#1d2f3a}.edit-panel{border:1px solid #d8e1e8;padding:18px 20px 10px;margin-bottom:24px;background:#fff;border-radius:12px;box-shadow:0 3px 10px -4px #00000026}.edit-panel h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#2d3a45;letter-spacing:.3px}.edit-field{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}.edit-field label{font-size:12px;font-weight:600;color:#536471;display:flex;flex-direction:column;gap:6px;text-transform:uppercase;letter-spacing:.7px}.edit-field input,.modal input,.modal select,.cond-row input,.cond-select,.cond-input{background:#f8fafc;border:1px solid #d3dde5;color:#2d3a45;border-radius:8px;padding:8px 10px;font-size:13px;outline:none;transition:.15s border,.15s box-shadow,.15s background}.edit-field input:focus,.modal input:focus,.modal select:focus,.cond-row input:focus,.cond-select:focus,.cond-input:focus{border-color:#ff8d26;box-shadow:0 0 0 2px #ff8d2640;background:#fff}.modal-bg{position:fixed;inset:0;background:#00000040;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding-top:80px;z-index:200}.modal{width:440px;background:#fff;border:1px solid #d8e1e8;padding:26px 30px;border-radius:16px;box-shadow:0 10px 38px -8px #00000040}.modal h3{margin-top:0;font-size:19px;font-weight:600;letter-spacing:.4px;color:#1d2f3a}.modal button{background:var(--trackman-orange);border:none;color:#fff;padding:10px 16px;border-radius:8px;font-size:14px;cursor:pointer;margin-right:10px;box-shadow:0 4px 10px -4px var(--trackman-orange-shadow)}.modal button:hover{background:var(--trackman-orange-hover)}.modal button:active{transform:translateY(2px);background:var(--trackman-orange-active)}.cond-editor{border:1px solid #dce4ea;padding:14px 16px 12px;margin-bottom:18px;border-radius:12px;background:#fff;box-shadow:0 2px 6px -2px #00000014}.cond-title{margin-top:0;font-size:12px;font-weight:700;color:#7b8a96;letter-spacing:.8px;text-transform:uppercase}.cond-label{display:block;margin-bottom:8px;font-size:11px;font-weight:600;color:#5d6c76}.cond-input{flex:1}.cond-input-narrow{width:70px}.cond-select{margin-left:8px}.cond-conditions{margin-top:8px}.cond-empty{font-style:italic;font-size:12px;color:#99a6af;margin:4px 0}.cond-row{display:flex;gap:8px;align-items:center;margin:6px 0}.cond-remove{background:#f4f6f8;border:1px solid #d3dde5;cursor:pointer;padding:4px 8px;border-radius:6px;color:#6a7782}.cond-remove:hover{background:#ffe5cc;border-color:#ffb374;color:#8a4a00}.cond-add{margin-top:8px;background:var(--trackman-orange);color:#fff;border:1px solid var(--trackman-orange);padding:6px 12px;font-size:12px;border-radius:20px;cursor:pointer;font-weight:600}.cond-add:hover{background:var(--trackman-orange-hover)}.logic-block{margin-bottom:28px;padding:16px 20px 10px;border:1px solid #dce4ea;background:#fff;border-radius:14px;box-shadow:0 2px 8px -2px #00000014}.logic-block h3{margin:0 0 14px;font-size:16px;font-weight:600;color:#2d3a45}.logic-flags{display:flex;gap:32px;margin-bottom:14px;font-size:12px}.logic-flags label{color:#5a6872;font-weight:600;text-transform:uppercase;letter-spacing:.8px}.logic-flags input{transform:scale(1.15);margin-left:6px}.collapsible{position:relative}.collapsible-header{width:100%;text-align:left;background:transparent;border:none;padding:0;margin:0 0 14px;font-size:16px;font-weight:600;color:#2d3a45;cursor:pointer;display:flex;align-items:center;gap:6px}.collapsible-header:focus{outline:2px solid #ff8d26;outline-offset:2px;border-radius:6px}.collapsible .chevron{display:inline-block;transition:transform .15s ease;font-size:16px;line-height:1}.collapsible.closed .chevron{transform:rotate(-90deg)}.collapsible-body{animation:fadeSlide .18s ease}.collapsible-body.hidden{display:none}@keyframes fadeSlide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}pre{background:#fff;border:1px solid #d8e1e8;padding:18px 20px;border-radius:14px;font-size:12px;line-height:1.45;overflow:auto;box-shadow:0 2px 6px -2px #00000014}pre::-webkit-scrollbar{width:10px}pre::-webkit-scrollbar-thumb{background:#d4dde4;border-radius:6px}pre::-webkit-scrollbar-thumb:hover{background:#c2ccd5}.hidden{display:none}.validation-panel{margin:16px 16px 0;padding:10px 12px 12px;border:1px solid #d8e1e8;border-radius:10px;background:#fff;box-shadow:0 2px 6px -2px #0000000f;font-size:12px}.validation-panel.ok{border-color:#c6e7c6;box-shadow:0 2px 6px -2px #00800014}.validation-panel.fail{border-color:#f2c2c2;box-shadow:0 2px 6px -2px #c800001a}.validation-panel-sidebar-bottom{margin-top:auto;padding:12px 16px 14px;border-top:1px solid #d8e1e8;background:#fff;font-size:12px;border-bottom-left-radius:0;border-bottom-right-radius:0}.validation-panel-sidebar-bottom.ok{border-top-color:#c6e7c6;background:#f0fff0}.validation-panel-sidebar-bottom.fail{border-top-color:#f2c2c2;background:#fff5f5}.validation-status{font-weight:700;margin-bottom:6px;letter-spacing:.6px;text-transform:uppercase;color:#34434d}.validation-panel.ok .validation-status,.validation-panel-sidebar-bottom.ok .validation-status{color:#1e6b1e}.validation-panel.fail .validation-status,.validation-panel-sidebar-bottom.fail .validation-status{color:#a32121}.validation-errors{margin:0;padding-left:18px;max-height:120px;overflow:auto}.validation-errors li{margin:2px 0;line-height:1.3;color:#5d2c2c}.validation-errors::-webkit-scrollbar{width:8px}.validation-errors::-webkit-scrollbar-thumb{background:#e2e8ed;border-radius:6px}.validation-errors::-webkit-scrollbar-thumb:hover{background:#d3dae0}.validation-hint-empty{font-size:11px;margin-bottom:6px;color:#5a646b}.dialog{position:relative}.dialog-title{margin:0 0 12px;font-size:20px;font-weight:600;letter-spacing:.4px;color:#13232d}.dialog-body{display:flex;flex-direction:column;gap:18px;margin-top:4px}.dialog-footer{margin-top:26px;display:flex;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field.two-col{display:grid;grid-template-columns:1fr 1fr;gap:26px}.field-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:#41515c}.field-input{width:100%;box-sizing:border-box}.field-textarea{resize:vertical;min-height:90px;line-height:1.4}.field-hint{font-size:11px;line-height:1.35;color:#6b7a83;padding:2px 0 0;font-weight:400;display:flex;align-items:flex-start;gap:6px;opacity:.85}.field-hint:before{content:"ℹ";font-size:11px;line-height:1.1;color:#ff9a40;background:transparent;border-radius:2px;position:relative;top:1px}.modal button.secondary{background:#eef2f5;color:#38454f;box-shadow:none;border:1px solid #d0d9e0}.modal button.secondary:hover{background:#e3e9ed}.modal button.secondary:active{background:#d7dde2}.tab-bar{background:#fff;border-bottom:1px solid #e5e7eb;height:50px;display:flex;align-items:flex-end;padding:0 20px;flex-shrink:0}.tab-container{display:flex;gap:0}.tab{background:transparent;border:none;padding:12px 24px;font-size:14px;font-weight:500;cursor:pointer;color:#6b7280;border-bottom:3px solid transparent;transition:all .2s ease;position:relative}.tab:hover{color:#374151;background:#f9fafb}.tab.active{color:#1f2937;border-bottom-color:#f97316;background:transparent}.tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:#fff}.documentation-flex{display:flex;flex:1;background:#fff;min-height:0}.documentation-viewer{display:flex;width:100%;height:100%}.doc-sidebar{width:250px;background:#f8fafc;border-right:1px solid #e5e7eb;padding:20px;flex-shrink:0}.doc-sidebar h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#1f2937}.doc-nav{list-style:none;margin:0;padding:0}.doc-nav li{margin-bottom:4px}.doc-nav-item{display:block;width:100%;padding:8px 12px;text-align:left;background:transparent;border:none;border-radius:6px;color:#6b7280;font-size:14px;cursor:pointer;transition:all .2s ease}.doc-nav-item:hover{background:#e2e8f0;color:#374151}.doc-nav-item.active{background:#f97316;color:#fff}.doc-content{flex:1;padding:20px 40px;overflow-y:auto}.doc-loading{display:flex;align-items:center;justify-content:center;height:200px;color:#6b7280;font-size:14px}.doc-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:6px;margin-bottom:20px}.doc-markdown{max-width:800px;line-height:1.6;color:#374151}.doc-markdown h1{font-size:28px;font-weight:700;margin:0 0 24px;color:#1f2937;border-bottom:1px solid #e5e7eb;padding-bottom:12px}.doc-markdown h2{font-size:22px;font-weight:600;margin:32px 0 16px;color:#1f2937}.doc-markdown h3{font-size:18px;font-weight:600;margin:24px 0 12px;color:#1f2937}.doc-markdown p{margin:0 0 16px}.doc-markdown code{background:#f1f5f9;color:#e11d48;padding:2px 6px;border-radius:4px;font-family:JetBrains Mono,SF Mono,Consolas,monospace;font-size:13px}.doc-markdown pre{background:#1e293b;color:#e2e8f0;padding:16px;border-radius:8px;overflow-x:auto;margin:16px 0}.doc-markdown pre code{background:transparent;color:inherit;padding:0;font-size:14px}.doc-markdown strong{font-weight:600;color:#1f2937}.doc-markdown em{font-style:italic;color:#4b5563}.doc-markdown a{color:var(--trackman-orange);text-decoration:none;font-weight:500;transition:color .2s ease}.doc-markdown a:hover{color:var(--trackman-orange-hover);text-decoration:underline}.doc-markdown a:visited{color:var(--trackman-orange)}.doc-markdown ul,.doc-markdown ol{margin:0 0 16px;padding-left:24px}.doc-markdown li{margin-bottom:8px;line-height:1.6}.auth-status{padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin:16px 0;display:flex;flex-direction:column;gap:8px}.auth-status.loading{justify-content:center;align-items:center;padding:20px;color:#6b7280}.auth-info{display:flex;flex-wrap:wrap;gap:16px;align-items:center;font-size:14px}.status-indicator{font-weight:600;padding:4px 8px;border-radius:4px}.status-indicator.authenticated{color:#065f46;background:#d1fae5}.status-indicator.unauthenticated{color:#92400e;background:#fef3c7}.token-expiry,.token-scope{color:#6b7280;font-size:12px}.auth-actions{display:flex;gap:8px;flex-wrap:wrap}.auth-button{padding:6px 12px;border:1px solid #d1d5db;border-radius:4px;background:#fff;color:#374151;font-size:12px;cursor:pointer;transition:all .2s ease}.auth-button:hover{background:#f9fafb;border-color:#9ca3af}.auth-button.login{background:var(--trackman-orange);color:#fff;border-color:var(--trackman-orange)}.auth-button.login:hover{background:var(--trackman-orange-hover);border-color:var(--trackman-orange-hover)}.auth-button.refresh{background:#f59e0b;color:#fff;border-color:#f59e0b}.auth-button.refresh:hover{background:#d97706;border-color:#d97706}.auth-button.logout{background:#ef4444;color:#fff;border-color:#ef4444}.auth-button.logout:hover{background:#dc2626;border-color:#dc2626}.auth-error{color:#dc2626;background:#fef2f2;padding:8px 12px;border-radius:4px;border:1px solid #fecaca;font-size:13px}.facility-dropdown{position:relative;display:inline-block}.facility-dropdown-button{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:14px;cursor:pointer;transition:all .2s ease;min-width:200px;justify-content:space-between}.facility-dropdown-button:hover{background:#ffffff26;border-color:#ffffff4d}.facility-dropdown-button:disabled{opacity:.6;cursor:not-allowed}.dropdown-arrow{transition:transform .2s ease;flex-shrink:0}.dropdown-arrow.open{transform:rotate(180deg)}.facility-dropdown-menu{position:absolute;top:100%;right:0;z-index:1000;background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:4px;min-width:300px;max-height:400px;overflow:hidden}.facility-search{padding:12px;border-bottom:1px solid #e5e7eb}.facility-search-input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;outline:none;transition:border-color .2s ease}.facility-search-input:focus{border-color:var(--trackman-orange);box-shadow:0 0 0 3px var(--trackman-orange-light)}.facility-list{max-height:300px;overflow-y:auto}.facility-item{display:block;width:100%;padding:12px;text-align:left;background:transparent;border:none;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f3f4f6}.facility-item:hover{background:#f9fafb}.facility-item:last-child{border-bottom:none}.facility-name{font-size:14px;font-weight:500;color:#1f2937;margin-bottom:2px}.facility-details{display:flex;gap:8px;align-items:center}.facility-kind{font-size:12px;color:#6b7280;background:#f3f4f6;padding:2px 6px;border-radius:3px}.facility-error{padding:12px;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;margin:8px;border-radius:6px;font-size:13px;line-height:1.4}.facility-error .error-header{font-weight:600;margin-bottom:8px;font-size:14px}.facility-error .error-message{background:#fee2e2;padding:8px;border-radius:4px;margin-bottom:12px;font-family:monospace;font-size:12px}.facility-error .error-help{margin-top:12px}.facility-error .error-help p{margin:8px 0 4px}.facility-error .error-help ul{margin:4px 0 8px 16px;padding:0}.facility-error .error-help li{margin:2px 0;font-size:12px}.facility-error .error-help em{color:#7f1d1d;font-style:italic}.facility-error .error-debug{margin-top:12px;border-top:1px solid #fecaca;padding-top:8px}.facility-error .error-debug summary{cursor:pointer;font-size:12px;color:#991b1b;margin-bottom:8px}.facility-error .error-debug summary:hover{color:#7f1d1d}.facility-error .debug-info{background:#450a0a;color:#fecaca;padding:8px;border-radius:4px;font-family:monospace;font-size:11px;margin-top:4px;max-height:200px;overflow-y:auto}.facility-error .debug-info p{margin:4px 0;word-break:break-all}.no-facilities{padding:12px;text-align:center;color:#6b7280;font-size:14px}.build-version{font-size:11px;color:#999;font-family:Courier New,Consolas,monospace;-webkit-user-select:none;user-select:none;cursor:default;opacity:.8;padding:3px 8px;border-radius:3px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);transition:opacity .2s ease}.build-version:hover{opacity:1}.env-debug{margin:8px 0;font-size:12px}.env-debug summary{cursor:pointer;padding:4px 8px;background:#fef3ed;border:1px solid #f8d4bd;border-radius:4px;color:var(--trackman-orange);font-weight:500}.env-debug summary:hover{background:#fde9d9}.env-debug-content{border:1px solid #f8d4bd;border-top:none;border-radius:0 0 4px 4px;padding:12px;background:#fafbfc}.env-section{margin-bottom:16px}.env-section:last-child{margin-bottom:0}.env-section h4{margin:0 0 8px;color:var(--trackman-orange);font-size:13px;font-weight:600}.env-table{width:100%;border-collapse:collapse;font-family:Consolas,Monaco,Courier New,monospace;font-size:11px}.env-table td{padding:2px 8px 2px 0;vertical-align:top}.env-table td:first-child{color:#666;font-weight:500;white-space:nowrap;width:200px}.env-ok{color:green}.env-missing{color:#c00;font-weight:600}.env-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;padding:12px;margin-top:12px}.env-warning p{margin:0 0 8px}.env-warning p:last-child{margin-bottom:0}.env-warning ul{margin:8px 0 0;padding-left:20px}.env-warning code{background:#0000001a;padding:1px 4px;border-radius:2px;font-family:Consolas,Monaco,Courier New,monospace}.facility-selector-portal{position:relative;display:inline-block}.facility-selector-button{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#5a5a5a;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;min-width:140px;justify-content:space-between}.facility-selector-button:hover:not(:disabled){background:#6a6a6a}.facility-selector-button:disabled{opacity:.6;cursor:not-allowed}.facility-selector-text{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.facility-selector-arrow{transition:transform .2s ease;flex-shrink:0}.facility-selector-arrow.open{transform:rotate(180deg)}.facility-selector-dropdown{position:absolute;top:100%;left:0;background:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 4px 12px #00000026;z-index:1000;width:400px;max-width:400px;overflow:hidden;overflow-x:hidden!important}.facility-tabs{display:flex;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.facility-tab{flex:1;padding:12px 16px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:14px;font-weight:500;color:#666;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:4px}.facility-tab:hover{color:#333;background:#f0f0f0}.facility-tab.active{color:var(--trackman-orange);border-bottom-color:var(--trackman-orange);background:#fff}.facility-tab-count{font-size:12px;color:#999}.facility-tab.active .facility-tab-count{color:var(--trackman-orange)}.facility-list-container{max-height:400px;overflow-y:auto;overflow-x:hidden}.facility-selector-dropdown{scrollbar-width:none;-ms-overflow-style:none}.facility-selector-dropdown::-webkit-scrollbar{display:none}.facility-list-container{scrollbar-width:thin;-ms-overflow-style:none}.facility-list-container::-webkit-scrollbar-horizontal{display:none!important}.facility-list{padding:8px 0}.facility-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;border:none;background:none;width:100%;max-width:100%;text-align:left;transition:background-color .2s ease;overflow:hidden;box-sizing:border-box}.facility-item:hover{background:#f8f9fa}.facility-item.selected{background:#fff3e6}.facility-content{flex:1;min-width:0}.facility-name{font-size:14px;font-weight:500;color:#333;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.facility-kind{font-size:12px;color:#666;text-transform:uppercase;letter-spacing:.5px}.facility-checkmark{color:var(--trackman-orange);flex-shrink:0;margin-left:12px;display:flex;align-items:center}.facility-error{padding:16px;color:#d32f2f;text-align:center;font-size:14px}.facility-loading{padding:16px;text-align:center;color:#666;font-size:14px}.no-facilities{padding:16px;text-align:center;color:#999;font-size:14px;font-style:italic}.facility-list-container::-webkit-scrollbar{width:6px}.facility-list-container::-webkit-scrollbar-track{background:#f1f1f1}.facility-list-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.facility-list-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.webhook-events{margin-top:16px}.webhook-events-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.webhook-events-status{color:gray}.webhook-events-list{max-height:360px;overflow:auto;border:1px solid #eee;padding:8px}.webhook-event-item{padding:6px 8px;border-bottom:1px solid #f1f1f1}.webhook-event-meta{font-size:12px;color:#666}.webhook-event-type{font-weight:600}.webhook-event-pre{margin-top:8px;white-space:pre-wrap;background:#fafafa;padding:8px;border-radius:4px}.webhook-events-ul{list-style:none;padding:0;margin:0}.webhook-event-header{display:flex;justify-content:space-between;align-items:center}.webhook-inspector{display:flex;height:100%;width:100%}.webhook-inspector{box-sizing:border-box}.webhook-inspector-list{width:280px;flex:0 0 280px;border-right:1px solid #ddd;display:flex;flex-direction:column}.webhook-events-header{padding:8px 12px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;z-index:2;border-bottom:1px solid #f0f0f0}.webhook-events-status{font-size:12px;color:#999}.webhook-events-status.live{color:green}.webhook-events-ul{list-style:none;margin:0;padding:0;overflow:auto;flex:1}.webhook-event-item{padding:10px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .2s}.webhook-event-item.selected{background:#f7fbff}.webhook-event-item.new-event{animation:eventGlow .5s ease-out;box-shadow:0 0 0 2px var(--trackman-orange)}@keyframes eventGlow{0%{box-shadow:0 0 8px 4px #ec691a99,0 0 0 2px var(--trackman-orange)}to{box-shadow:0 0 #ec691a00,0 0 0 2px var(--trackman-orange)}}.event-type{font-size:13px;color:#333;cursor:help;position:relative}.event-type.unknown-event{color:#666;font-style:italic}.event-meta{font-size:12px;color:#777}.event-session-indicators{display:flex;gap:6px;margin-top:6px;align-items:center}.session-dot{width:10px;height:10px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.no-events{padding:12px;color:#666}.webhook-inspector-preview{flex:1;padding:12px;overflow:hidden;min-width:0;display:flex;flex-direction:column}.webhook-inspector-preview>div{display:flex;flex-direction:column;flex:1;min-height:0}.preview-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px}.preview-title{margin:0;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:help}.preview-time{color:#999;font-size:11px;flex-shrink:0}.preview-json{background:#fafafa;padding:12px;border-radius:6px;overflow:auto}.preview-empty{color:#666}.webhook-inspector-list:focus{outline:none;box-shadow:none}.webhook-inspector-list:focus-visible{outline:none;box-shadow:0 0 0 3px #0078d426}.event-type-filter{position:relative;margin-left:8px}.event-type-filter-button{background:#f0f0f0;border:1px solid #ddd;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:4px;position:relative;transition:background .2s}.event-type-filter-button:hover{background:#e8e8e8}.filter-icon{color:#555;transition:color .2s}.event-type-filter-button:hover .filter-icon{color:#333}.event-type-filter-badge{background:var(--trackman-orange);color:#fff;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:700;min-width:18px;text-align:center}.event-type-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:280px;max-width:400px;z-index:1000}.event-type-dropdown-header{padding:12px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.event-type-dropdown-header strong{font-size:14px}.event-type-dropdown-actions{display:flex;gap:6px}.event-type-dropdown-actions button{background:#f0f0f0;border:1px solid #ddd;border-radius:4px;padding:4px 10px;font-size:12px;cursor:pointer;transition:background .2s}.event-type-dropdown-actions button:hover{background:#e0e0e0}.event-type-dropdown-list{max-height:400px;overflow-y:auto;padding:8px}.event-type-option{display:flex;align-items:center;padding:6px 8px;cursor:pointer;border-radius:4px;transition:background .2s}.event-type-option:hover{background:#f7fbff}.event-type-option input[type=checkbox]{margin-right:8px;cursor:pointer}.event-type-label{font-size:13px;color:#333;-webkit-user-select:none;user-select:none}.loading-spinner{display:inline-flex;align-items:center;gap:6px;color:#999}.loading-spinner-icon{width:14px;height:14px;border:2px solid #ddd;border-top-color:#4a90e2;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{animation:loadingPulse 1.5s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:.6}50%{opacity:1}}.loading-events-message{padding:20px;text-align:center;color:#666;display:flex;flex-direction:column;align-items:center;gap:12px}.loading-events-spinner{width:32px;height:32px;border:3px solid #e8e8e8;border-top-color:#4a90e2;border-radius:50%;animation:spin .8s linear infinite}.measurement-tiles-container{padding:12px;background:#f8f9fa;border-radius:8px;flex:1;overflow-y:auto;min-height:0}.measurement-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px;flex-wrap:wrap}.measurement-player-info{padding:12px;background:#fff;border-radius:6px;border-left:4px solid var(--trackman-orange);font-size:14px;flex:1;min-width:200px}.unit-system-toggle{display:flex;background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.unit-toggle-btn{padding:10px 20px;border:none;background:#fff;color:#6b7280;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;position:relative}.unit-toggle-btn:first-child{border-right:1px solid #e5e7eb}.unit-toggle-btn:hover{background:#f3f4f6}.unit-toggle-btn.active{background:var(--trackman-orange);color:#fff}.unit-toggle-btn.active:hover{background:#ff8d26}.measurement-tiles-empty{padding:40px;text-align:center;color:#666}.measurement-category{margin-bottom:24px}.measurement-category-title{margin:0 0 12px;padding-bottom:8px;color:#333;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb}.measurement-tiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.measurement-tile{background:#fff;border-radius:8px;padding:16px 12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;align-items:center;justify-content:space-between;min-height:110px;transition:transform .2s,box-shadow .2s}.measurement-tile:hover{transform:translateY(-2px);box-shadow:0 4px 6px #00000026}.tile-title{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;text-align:center;letter-spacing:.3px;margin-bottom:8px;line-height:1.3}.tile-value{font-size:32px;font-weight:700;color:#1f2937;text-align:center;line-height:1;margin:auto 0}.tile-unit{font-size:12px;font-weight:500;color:#9ca3af;text-align:center;margin-top:8px}@media(max-width:1200px){.measurement-tiles-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.tile-value{font-size:28px}}@media(max-width:768px){.measurement-tiles-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.measurement-tile{padding:12px 8px;min-height:90px}.tile-value{font-size:24px}.tile-title{font-size:10px}}.shot-trajectory-container{position:relative;width:400px;height:396px;max-height:396px;display:flex;align-items:center;justify-content:center;overflow:hidden}.shot-trajectory-container>.rotation-wrapper{position:relative;transform:rotate(-90deg);transform-origin:center center;width:400px;height:auto}.shot-trajectory-container .hole-image{width:100%;height:auto;display:block}.trajectory-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.trajectory-status{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;color:#fff;padding:8px 16px;border-radius:4px;font-size:12px;pointer-events:none}.trajectory-error{position:absolute;bottom:8px;left:50%;transform:translate(-50%);background:#f00c;color:#fff;padding:6px 12px;border-radius:4px;font-size:11px;pointer-events:none}.course-info-banner{background:#f8f9fa;color:#1f2937;padding:12px 16px;border-radius:8px;margin-bottom:16px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;align-items:flex-start;min-height:420px;max-height:420px;overflow:hidden}.course-info-banner.loading{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#6b7280}.course-info-content{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0;padding-top:8px}.course-info-details{flex:1;display:flex;flex-direction:column;gap:4px}.course-info-name{font-size:18px;font-weight:700;line-height:1.2}.course-info-difficulty{font-size:13px;font-weight:500;opacity:.9}.difficulty-value{font-weight:700;text-transform:uppercase}.course-info-description{font-size:13px;opacity:.85;line-height:1.4;margin-top:2px}.course-info-holes{font-size:12px;opacity:.8;font-weight:600}.course-info-progress{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.1)}.progress-hole,.progress-shot{color:#1f2937}.progress-player{color:#1f2937;opacity:.8;font-weight:600}.progress-separator{color:#1f2937;opacity:.5;font-weight:400}.course-info-loading{font-size:14px;font-weight:500;display:inline-block;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.hole-image-container{display:flex;align-items:center;justify-content:flex-end;flex-shrink:0;height:100%;max-height:396px}.hole-image{max-width:100%;object-fit:contain}.webhook-view{padding:24px;width:100%;box-sizing:border-box}.webhook-title{margin:0 0 8px}.webhook-loading{color:#666}.webhook-error{color:#c92a2a}.webhook-url-row{display:flex;gap:8px;align-items:center;max-width:600px}.webhook-url-input{flex:1;padding:8px;border:1px solid #ddd;border-radius:4px}.webhook-copy-button{padding:8px 12px;background:#0078d4;color:#fff;border:none;border-radius:4px;cursor:pointer}.webhook-topbar{display:flex;gap:8px;align-items:center}.webhook-url-input{flex:1;padding:6px 8px;border:1px solid #ccc;border-radius:4px}.webhook-inspector-wrap{margin-top:8px;height:calc(100vh - 160px)}.webhook-copy-button,.webhook-clear-button{padding:6px 10px;border-radius:4px;border:1px solid #888;background:#f2f2f2;cursor:pointer}:root{--background-black-70: rgba(34, 34, 34, .7);--backgroundbackground-inverse-hover: rgba(238, 238, 238, 1);--borderborder-interactive: var(--trackman-orange);--grayscalebackground-black: rgba(34, 34, 34, 1);--grayscalegray: rgba(160, 160, 160, 1);--grayscaletext-element: rgba(65, 65, 65, 1);--grayscalewhite: rgba(255, 255, 255, 1);--heading-sm-font-family: "Lato", Helvetica;--heading-sm-font-size: 24px;--heading-sm-font-style: normal;--heading-sm-font-weight: 700;--heading-sm-letter-spacing: 0px;--heading-sm-line-height: 32px;--label-01-md-font-family: "Lato", Helvetica;--label-01-md-font-size: 20px;--label-01-md-font-style: normal;--label-01-md-font-weight: 600;--label-01-md-letter-spacing: 0px;--label-01-md-line-height: 28px;--label-01-sm-font-family: "Lato", Helvetica;--label-01-sm-font-size: 16px;--label-01-sm-font-style: normal;--label-01-sm-font-weight: 600;--label-01-sm-letter-spacing: 0px;--label-01-sm-line-height: 20px;--lato-15-regular-font-family: "Lato", Helvetica;--lato-15-regular-font-size: 15px;--lato-15-regular-font-style: normal;--lato-15-regular-font-weight: 400;--lato-15-regular-letter-spacing: 0px;--lato-15-regular-line-height: 21px;--lato-20-bold-font-family: "Lato", Helvetica;--lato-20-bold-font-size: 20px;--lato-20-bold-font-style: normal;--lato-20-bold-font-weight: 700;--lato-20-bold-letter-spacing: 0px;--lato-20-bold-line-height: 28px;--TM-text-shadow-22-32pt: 0px 1px 2px 0px rgba(0, 0, 0, .5);--tpsaction-grey: rgba(49, 49, 49, 1);--uitrackman-orange: var(--trackman-orange)}.hole-selector{align-items:center;background-color:#fff;border-radius:24px;display:flex;flex-direction:column;gap:16px;padding:16px 8px 8px;position:relative;width:100%;max-width:900px;border:1px solid #e0e0e0}.hole-selector .header{align-items:center;align-self:stretch;display:flex;flex:0 0 auto;justify-content:center;padding:0 8px;position:relative;width:100%}.hole-selector .title{align-items:center;color:#333;display:flex;font-family:var(--label-01-md-font-family);font-size:var(--label-01-md-font-size);font-style:var(--label-01-md-font-style);font-weight:var(--label-01-md-font-weight);justify-content:center;letter-spacing:var(--label-01-md-letter-spacing);line-height:var(--label-01-md-line-height);position:relative;white-space:nowrap;width:fit-content}.hole-selector-content{display:flex;gap:24px;align-items:flex-start}.hole-layout{flex:0 0 auto;width:auto}.hole-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:8px;width:420px}.hole-card{background-color:var(--tpsaction-grey);border-radius:12px;border:3px solid transparent;cursor:pointer;transition:all .3s ease;position:relative;aspect-ratio:2/3;overflow:hidden}.hole-card:hover{border-color:var(--grayscalegray)}.hole-card.selected{border-color:var(--borderborder-interactive)}.hole-card.disabled{opacity:.5;cursor:not-allowed}.hole-image{width:100%;height:calc(100% - 40px);position:relative;overflow:hidden}.hole-image img{width:100%;height:100%;object-fit:cover;object-position:center}.hidden{display:none!important}.hole-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#8b7355,#a0926b);display:flex;align-items:center;justify-content:center;position:relative}.hole-number{position:absolute;top:8px;left:8px;color:var(--grayscalewhite);font-family:var(--lato-20-bold-font-family);font-size:var(--lato-20-bold-font-size);font-weight:var(--lato-20-bold-font-weight);text-shadow:var(--TM-text-shadow-22-32pt);background-color:var(--background-black-70);border-radius:8px;padding:4px 8px;min-width:24px;text-align:center}.hole-distance{position:absolute;bottom:0;left:0;right:0;color:var(--grayscalewhite);font-family:var(--lato-20-bold-font-family);font-size:var(--lato-20-bold-font-size);font-weight:var(--lato-20-bold-font-weight);text-shadow:var(--TM-text-shadow-22-32pt);text-align:center;padding:8px;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);height:40px;display:flex;align-items:center;justify-content:center}.hole-preview{flex:1;display:flex;flex-direction:column;min-height:400px;position:relative}.hole-preview-header{position:absolute;top:8px;left:8px;z-index:2;display:flex;gap:8px;align-items:center}.hole-preview-number{color:var(--grayscalewhite);font-family:var(--lato-20-bold-font-family);font-size:var(--lato-20-bold-font-size);font-weight:var(--lato-20-bold-font-weight);text-shadow:var(--TM-text-shadow-22-32pt);background-color:var(--background-black-70);border-radius:8px;padding:4px 8px;min-width:24px;text-align:center}.hole-preview-distance{color:var(--grayscalewhite);font-family:var(--lato-20-bold-font-family);font-size:var(--lato-20-bold-font-size);font-weight:var(--lato-20-bold-font-weight);text-shadow:var(--TM-text-shadow-22-32pt);background-color:var(--background-black-70);border-radius:8px;padding:4px 8px;text-align:center}.hole-preview-image{display:inline-block;border:2px solid #e0e0e0;border-radius:8px;background-color:#f8f8f8;overflow:hidden;position:relative}.hole-preview-image img{height:622px;width:auto;object-fit:contain;border-radius:6px;display:block}.hole-preview-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--grayscalegray, #999);font-size:16px;text-align:center;background-color:#f8f8f8;border-radius:6px}.hole-preview-placeholder-text{color:var(--grayscalegray, #999);font-size:16px}@media(max-width:768px){.hole-selector-content{flex-direction:column;gap:16px}.hole-grid{grid-template-columns:repeat(3,1fr);gap:6px;width:100%}.hole-selector .title{font-size:18px}.hole-preview{min-height:250px}}.ui-editor{padding:1rem;border:1px solid #e0e0e0;border-radius:4px;margin-bottom:1rem}.ui-basic-settings{margin-bottom:1.5rem}.ui-basic-settings label{display:flex;align-items:center;gap:.5rem;font-weight:500}.ui-data-settings{margin-bottom:1.5rem}.ui-data-settings>div{margin-bottom:1rem}.single-select label{display:block;font-weight:500;margin-bottom:.25rem}.single-select select{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:.9rem}.help-text{display:block;color:#666;font-size:.8rem;margin-top:.25rem}.ui-frame-actions{border-top:1px solid #e0e0e0;padding-top:1rem}.ui-frame-actions h3{margin:0 0 1rem;font-size:1.1rem;color:#333}.ui-frame-action{margin-bottom:1.5rem;padding:1rem;background-color:#f8f9fa;border-radius:4px}.ui-frame-action h4{margin:0 0 1rem;font-size:1rem;color:#495057}.multi-select-dropdown{margin-bottom:.75rem}.multi-select-dropdown label{display:block;font-weight:500;margin-bottom:.25rem;color:#333}.dropdown-container{position:relative}.dropdown-toggle{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;background-color:#fff;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.dropdown-toggle:hover{border-color:#999}.dropdown-arrow{font-size:.7rem;color:#666}.dropdown-menu{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:1px solid #ccc;border-top:none;border-radius:0 0 4px 4px;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 2px 4px #0000001a}.dropdown-option{display:flex;align-items:center;padding:.5rem;cursor:pointer;font-size:.9rem;gap:.5rem}.dropdown-option:hover{background-color:#f0f0f0}.dropdown-option input[type=checkbox]{margin:0}.dropdown-option:has(input:disabled){opacity:.5;cursor:not-allowed}.selected-values{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.25rem}.selected-tag{display:inline-flex;align-items:center;background-color:var(--trackman-orange);color:#fff;padding:.2rem .5rem;border-radius:3px;font-size:.8rem;gap:.25rem}.remove-tag{background:none;border:none;color:#fff;cursor:pointer;font-size:1rem;line-height:1;padding:0;margin-left:.25rem}.remove-tag:hover{background-color:#fff3;border-radius:2px}@media(max-width:768px){.ui-editor,.ui-frame-action{padding:.75rem}.dropdown-menu{max-height:150px}}
