:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;height:100%;overflow:hidden;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}#app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.vanilla:hover{filter:drop-shadow(0 0 2em #f7df1eaa)}.card{padding:2em}.read-the-docs{color:#888}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.view-select-wrapper{position:relative;display:inline-block;margin-right:1.5rem;border-radius:20px;background:rgba(100,100,100,.6);height:40px;padding:.15rem .75rem}.view-select{font-size:1.5rem;color:#fff;background-color:transparent;border:none;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:1.5em;background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg width='14' height='8' viewBox='0 0 14 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L7 7L13 1' stroke='white' stroke-width='2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .25em center;background-size:.65em}.view-select option{background-color:#282828f2;color:#fff;padding:.5rem}.view-select option:checked,.view-select option:focus{background-color:#646464cc;color:#fff}.view-select option:hover{background-color:#787878e6;color:#fff}.hole-select{font-size:1.5rem;color:#fff;background-color:transparent;border:none;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:1.5em;background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg width='14' height='10' viewBox='0 0 14 10' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1H13M1 5H13M1 9H13' stroke='white' stroke-width='2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .25em center;background-size:.65em}#topRightControls{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}#currentHole{height:40px;width:50px;padding:0 1rem;display:flex;justify-content:center;align-items:center;background-color:#64646499;border-radius:20px;color:#fff;font-size:2rem;z-index:300;-webkit-user-select:none;user-select:none}.icon-stack{display:flex;flex-direction:column;gap:.25rem;background-color:#3c3c3ccc;border-radius:8px;padding:.5rem;z-index:300}.icon-btn{width:36px;height:36px;display:flex;justify-content:center;align-items:center;background-color:transparent;border:none;border-radius:6px;cursor:pointer;padding:0;transition:background-color .2s;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.icon-btn img{width:20px;height:20px;display:block;filter:invert(1)}.icon-btn:hover{background-color:#78787899}.icon-btn:active{background-color:#8c8c8cb3}.icon-btn svg{display:block;width:20px;height:20px}.hole-info-panel{position:fixed;left:50%;top:1rem;transform:translate(-50%);width:min(560px,90vw);background:#f4f4f0;color:#111;border-radius:12px;padding:14px 16px;box-shadow:0 10px 24px #00000059;z-index:350;display:none}.hole-info-panel.is-open{display:block}.hole-info-close{position:absolute;top:6px;right:6px;width:28px;height:28px;border:none;border-radius:0;background:transparent;color:#111;font-size:26px;line-height:1;cursor:pointer}.hole-info-close:hover{color:#000}.hole-info-header{font-size:.95rem;font-weight:700;margin-bottom:8px}.hole-info-body{font-size:.9rem;line-height:1.4;color:#111111e6}.nav-pad{position:fixed;right:1rem;bottom:1rem;display:grid;grid-template-columns:repeat(4,40px);grid-auto-rows:40px;gap:8px;padding:.5rem;background-color:#3c3c3ccc;border-radius:8px;z-index:300}.nav-pad .icon-btn{width:40px;height:40px;padding:0}#distanceControls{position:fixed;bottom:1rem;right:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:300}.measure-btn{height:40px;width:40px;display:flex;justify-content:center;align-items:center;background-color:#64646499;border:none;border-radius:20px;cursor:pointer;padding:0;transition:background-color .2s}.measure-btn:hover{background-color:#787878b3}.measure-btn:active{background-color:#8c8c8ccc}.measure-btn svg{display:block}@media (max-width: 768px){#distanceControls{bottom:.5rem;right:.5rem}}#togglePanel{position:fixed;top:1rem;left:1rem;height:40px;width:40px;padding:0 1rem;display:flex;justify-content:center;align-items:center;background-color:#64646499;border-radius:20px;color:#fff;font-size:2rem;cursor:pointer;-webkit-user-select:none;user-select:none;z-index:300}#sidePanel{position:fixed;top:1rem;left:1rem;width:300px;height:100%;padding:1rem;border-radius:20px;background-color:#646464cc;box-shadow:2px 0 10px #00000026;transform:translate(calc(-100% - 30px));transition:transform .3s ease-in-out;z-index:1000;display:flex;flex-direction:column;-webkit-user-select:none;user-select:none}#sidePanel.active{transform:translate(0)}#closePanel{position:fixed;top:1rem;left:1rem;height:50px;padding:0 1rem;font-size:2rem;color:#fff;background:transparent;border:none;cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;justify-content:center;align-items:center;line-height:1;z-index:1100;transform:translate(-16px,-16px)}@media (min-width: 769px){#sidePanel{transform:translate(0)}#togglePanel,#closePanel{display:none}}#viewer{position:fixed;top:0;bottom:0;left:0;right:0;background:#222;overflow:hidden}.hole-slider{position:fixed;left:50%;bottom:16px;transform:translate(-50%);width:min(560px,94vw);padding:8px 16px;border-radius:999px;background-color:#646464cc;color:#f0f0f0;z-index:320;box-shadow:2px 0 10px #00000026;pointer-events:auto;overflow:hidden;display:flex;align-items:center;gap:10px}.hole-slider-track{flex:1;overflow:hidden}.hole-slider-inner{display:flex;align-items:center;gap:14px;transition:transform .35s ease;will-change:transform}.hole-slider-btn{border:none;background:transparent;color:inherit;font-size:1rem;font-weight:500;padding:4px 8px;min-width:90px;white-space:nowrap;opacity:.55;cursor:pointer}.hole-slider-btn.is-active{font-weight:700;background:rgba(255,255,255,.2);border-radius:999px;box-shadow:0 6px 16px #00000040;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 14px;opacity:1}.hole-slider-btn:focus-visible{outline:2px solid rgba(255,255,255,.7);outline-offset:2px;border-radius:8px}.hole-menu-btn{width:36px;height:36px;border:none;border-radius:10px;background:rgba(255,255,255,.15);color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.hole-menu-btn:hover{background:rgba(255,255,255,.25)}.hole-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.35);z-index:1001}.hole-menu-overlay.is-open{display:flex}.hole-menu-panel{width:min(520px,92vw);max-height:70vh;background:rgba(100,100,100,.9);border-radius:18px;padding:20px;color:#fff;overflow:auto}.hole-menu-header{font-size:1.1rem;font-weight:600;margin-bottom:12px;text-align:center}.hole-menu-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}@media (max-width: 768px){.hole-menu-grid{grid-template-columns:1fr}}.hole-menu-item{border:none;border-radius:999px;padding:10px 14px;background:rgba(255,255,255,.15);color:#fff;font-weight:600;cursor:pointer}.hole-menu-item:hover{background:rgba(255,255,255,.25)}.panel-content{flex:1;display:flex;flex-direction:column;justify-content:center;height:100%;overflow:hidden}.object-fit-contain{object-fit:contain}.carousel-wrapper,#holeCarousel{flex:1;display:flex;flex-direction:column}.carousel-inner{flex:1}.carousel-item{display:none;position:relative;transition:transform .6s ease}.carousel-item.active,.carousel-item-next,.carousel-item-prev{display:flex;flex-direction:column;justify-content:space-between;flex:1}.carousel-item img{border-radius:1rem!important;object-fit:contain;width:100%;height:100%;background:transparent;display:block;z-index:1}.tee-circle{width:14px;height:14px;border-radius:50%;display:inline-block}#view-buttons{position:absolute;top:1rem;right:1rem;z-index:10;display:flex;flex-direction:row;gap:.5rem}.view-icon-panel{position:absolute;right:80px;top:0;transform:none;display:none;flex-direction:column;gap:.5rem;padding:.75rem;background-color:#3c3c3cd9;border-radius:18px;z-index:300}.view-icon-panel.is-open{display:flex}.view-icon-btn{width:88px;height:88px;border-radius:16px;background:rgba(30,30,30,.7);border:1px solid rgba(255,255,255,.1);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;padding:.5rem;text-align:center;cursor:pointer}.view-icon-btn img{width:28px;height:28px}.view-icon-btn span{font-size:.85rem;line-height:1}.view-icon-btn.is-active{background:rgba(120,120,120,.75);border-color:#ffffff40}.hole-info{text-shadow:0 0 5px rgba(0,0,0,.7);margin-top:2rem;margin-bottom:0}.hole-number{min-width:4rem}.stroke-index,.tee{color:#fff}#imagePanel{flex:1.4 1 0;max-height:calc(100vh - 20px);margin-bottom:20px;overflow:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center;width:260px;padding:1rem;border-radius:20px;position:relative}#imagePanel:has(img){background-color:#fff9;box-shadow:2px 0 10px #00000026}#imagePanel:has(.mini-cesium-viewer){background-color:transparent;box-shadow:none;padding:0;aspect-ratio:13 / 25;height:auto}#imagePanel img{max-width:100%;max-height:100%;height:auto;width:auto;object-fit:contain}.mini-cesium-viewer{width:100%;height:100%;min-height:unset;max-height:unset;border-radius:15px;border:2px solid rgba(255,255,255,.8);overflow:hidden;position:relative;display:block}.mini-cesium-viewer canvas{width:100%!important;height:100%!important;display:block}.mini-viewer-container{min-height:unset;display:flex;flex-direction:column}.view-select-btn{font-size:1.5rem;color:#fff;background-color:#64646499;border:none;border-radius:20px;padding:.25rem .75rem;height:40px}.view-select-btn:hover,.view-select-btn:focus{background-color:#787878b3;color:#fff}.dropdown-menu{background-color:#282828f2;border-radius:12px;border:none}.dropdown-item{color:#fff;font-size:1.2rem}.dropdown-item:hover,.dropdown-item:focus{background-color:#64646499;color:#fff}
