:root{--bg: #1a1a2e;--surface: #16213e;--surface2: #0f3460;--accent: #53d769;--accent2: #4db8ff;--text: #e8e8e8;--text-muted: #aaa;--danger: #ff4757;--border: #2a2a4a;--input-bg: #0d1b2a;--card-bg: #1b2838;font-size:14px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%}body{margin:0;-webkit-text-size-adjust:100%;font-family:Segoe UI,Hiragino Sans,Meiryo,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}#root{width:100%}.app{display:flex;flex-direction:column;height:min(90vh,820px);min-height:560px;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:8px 16px;display:flex;align-items:center;gap:12px;flex-shrink:0}.app-header h1{font-size:16px;font-weight:700;color:var(--accent);white-space:nowrap}.app-body{display:flex;flex:1;overflow:hidden}.input-panel{width:320px;min-width:280px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.tab-bar{display:flex;border-bottom:1px solid var(--border);background:var(--surface2)}.tab-btn{flex:1;padding:8px 4px;background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-btn:hover{color:var(--text);background:#ffffff08}.tab-content{flex:1;overflow-y:auto;padding:12px}.result-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.kpi-row{display:flex;gap:8px;padding:10px 12px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0}.kpi-card{background:var(--card-bg);border-radius:6px;padding:6px 12px;min-width:90px;text-align:center}.kpi-label{font-size:10px;color:var(--text-muted);margin-bottom:2px}.kpi-value{font-size:18px;font-weight:700;color:var(--accent)}.kpi-unit{font-size:10px;color:var(--text-muted);margin-left:2px}.charts-area{flex:1;display:flex;flex-direction:column;overflow:auto;gap:0}.chart-container{position:relative;min-height:200px;border-bottom:1px solid var(--border);background:var(--input-bg)}.chart-container canvas{display:block;width:100%;height:100%}.chart-title{position:absolute;top:4px;left:8px;font-size:11px;color:var(--text-muted);pointer-events:none}.course-container{min-height:200px;background:var(--input-bg)}.course-container canvas{display:block;width:100%;height:100%}.field-group{margin-bottom:12px}.field-group-title{font-size:11px;font-weight:600;color:var(--accent2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.field-row{display:flex;align-items:center;margin-bottom:6px;gap:8px}.field-label{font-size:12px;color:var(--text-muted);min-width:80px;flex-shrink:0}.field-input{flex:1;min-width:0}.field-input input[type=number],.field-input input[type=text],.field-input select{width:100%;padding:4px 8px;background:var(--input-bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:13px;outline:none;transition:border-color .15s}.field-input input:focus,.field-input select:focus{border-color:var(--accent)}.field-input input[type=range]{width:100%;accent-color:var(--accent)}.field-value{font-size:12px;color:var(--text);min-width:45px;text-align:right;font-variant-numeric:tabular-nums}.btn{padding:6px 14px;border:none;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover{filter:brightness(1.1)}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-sm{padding:4px 10px;font-size:11px}.btn-row{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.toggle-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.toggle-row input[type=checkbox]{accent-color:var(--accent)}.toggle-label{font-size:12px;color:var(--text-muted)}.club-preset-row{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}.club-chip{padding:3px 8px;border-radius:12px;font-size:11px;border:1px solid var(--border);background:var(--input-bg);color:var(--text-muted);cursor:pointer;transition:all .15s}.club-chip.active{background:var(--accent);color:#000;border-color:var(--accent)}.club-chip:hover{border-color:var(--accent)}.surface-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.surface-fairway{background:#6db86b;color:#000}.surface-rough{background:#4a8c3f;color:#fff}.surface-bunker{background:#e8d8a0;color:#000}.surface-green{background:#5cc85c;color:#000}.surface-water{background:#3d7bb8;color:#fff}.surface-ob{background:#ff4757;color:#fff}.surface-tee{background:#8c8;color:#000}.export-btn{margin-left:auto}.putt-action-bar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.putt-btn{padding:8px 28px!important;font-size:15px!important;font-weight:700!important;border-radius:8px!important;letter-spacing:1px;box-shadow:0 2px 8px #53d76940;transition:all .2s}.putt-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 14px #53d76959}.putt-btn:disabled{opacity:.5;cursor:not-allowed}.putt-status{font-size:12px;color:var(--accent);animation:puttPulse .8s ease-in-out infinite alternate}@keyframes puttPulse{0%{opacity:.5}to{opacity:1}}.putt-result{text-align:center;padding:12px}.putt-result .holed{font-size:24px;font-weight:700;color:var(--accent)}.putt-result .missed{font-size:16px;color:var(--danger)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:768px){.app-body{flex-direction:column}.input-panel{width:100%;min-width:100%;max-height:45vh;border-right:none;border-bottom:1px solid var(--border)}.kpi-row{overflow-x:auto;flex-wrap:nowrap}.kpi-card{min-width:80px;flex-shrink:0}.charts-area{min-height:0}}.scenario-bar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface2);border-bottom:1px solid var(--border);flex-shrink:0;overflow:hidden}.scenario-bar-title{font-size:11px;color:var(--text-muted);font-weight:600;letter-spacing:.5px;white-space:nowrap}.scenario-bar-list{display:flex;gap:8px;overflow-x:auto;scrollbar-width:thin;padding-bottom:2px}.scenario-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);cursor:pointer;white-space:nowrap;transition:all .15s;min-height:40px}.scenario-chip:hover{border-color:var(--accent)}.scenario-chip.active{background:var(--accent);color:#062b14;border-color:var(--accent);font-weight:700}.scenario-chip-emoji{font-size:16px}.scenario-chip-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.scenario-chip-label{font-size:12px;font-weight:700}.scenario-chip-desc{font-size:10px;color:var(--text-muted);font-weight:400;max-width:240px;overflow:hidden;text-overflow:ellipsis}.scenario-chip.active .scenario-chip-desc{color:#062b14b3}.header-spacer{flex:1}.share-card-btns{display:inline-flex;gap:6px}:root{--hero-bg: #f7fbff;--hero-bg2: #f5faf6;--hero-text: #1f2933;--hero-text-soft: #4b5563;--hero-green: #16834a;--hero-blue: #2f80ed;--hero-grass: #7ac143;--hero-border: #dbe7e2;--hero-card: #ffffff}.golf-hero{background:linear-gradient(180deg,var(--hero-bg) 0%,var(--hero-bg2) 100%);color:var(--hero-text);padding:36px 20px 28px;text-align:center;border-bottom:1px solid var(--hero-border);position:relative;overflow:hidden}.golf-hero-inner{max-width:980px;margin:0 auto;position:relative;z-index:1}.golf-hero h1{font-size:clamp(22px,3.4vw,34px);margin:0 0 10px;color:var(--hero-green);font-weight:800;letter-spacing:.02em;display:inline-flex;align-items:center;justify-content:center;gap:.55em;flex-wrap:wrap;line-height:1.2}.golf-hero-ball{width:clamp(32px,4.6vw,48px);height:clamp(32px,4.6vw,48px);flex-shrink:0;border-radius:50%;filter:drop-shadow(0 1px 1px rgba(40,60,50,.18)) drop-shadow(0 3px 6px rgba(20,60,40,.22));transform:translateY(-.06em);background:transparent;image-rendering:-webkit-optimize-contrast;position:relative;isolation:isolate;animation:golf-hero-ball-float 4.2s ease-in-out infinite;transform-origin:center}.golf-hero-ball:after{content:none}.golf-hero h1 .golf-hero-ball{box-shadow:inset 0 0 0 .5px #0000000f,0 0 0 .5px #fff9}@keyframes golf-hero-ball-float{0%,to{transform:translateY(-.06em)}50%{transform:translateY(calc(-.06em - 1.5px))}}@media(prefers-reduced-motion:reduce){.golf-hero-ball{animation:none}}.golf-hero-flag{display:inline-block;width:2px;height:1.15em;background:linear-gradient(180deg,transparent 0%,rgba(14,116,75,.15) 12%,rgba(14,116,75,.55) 50%,rgba(14,116,75,.15) 88%,transparent 100%);border-radius:1px;position:relative;flex-shrink:0;transform:translateY(.05em)}.golf-hero-flag:before{content:"";position:absolute;top:.06em;left:100%;width:.55em;height:.35em;background:linear-gradient(135deg,#ef4444,#b91c1c);clip-path:polygon(0 0,100% 50%,0 100%);opacity:.85}.golf-hero h1 .golf-hero-flag:last-child:before{left:auto;right:100%;clip-path:polygon(100% 0,0 50%,100% 100%)}.golf-hero-deco-ball{position:absolute;top:-28px;right:-34px;width:clamp(120px,18vw,200px);height:auto;opacity:.1;filter:drop-shadow(0 6px 14px rgba(0,0,0,.18));pointer-events:none;-webkit-user-select:none;user-select:none;transform:rotate(-12deg);z-index:0}.golf-hero p.lead{font-size:clamp(13px,1.4vw,16px);margin:0 0 4px;color:var(--hero-text)}.golf-hero p.sub{font-size:clamp(11px,1.2vw,13px);margin:0 auto 18px;color:var(--hero-text-soft);max-width:720px;line-height:1.7}.golf-hero-ctas{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}.hero-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:700;text-decoration:none;border:1px solid transparent;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.hero-btn-primary{background:var(--hero-green);color:#fff}.hero-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #16834a47}.hero-btn-secondary{background:#fff;color:var(--hero-green);border-color:var(--hero-green)}.hero-btn-secondary:hover{background:#ecfdf5}.hero-btn-ghost{background:transparent;color:var(--hero-text-soft);border-color:var(--hero-border)}.hero-btn-ghost:hover{background:#fff;color:var(--hero-text)}.golf-hero-cards-wrap{max-width:900px;margin:0 auto}.golf-hero-cards-caption{font-size:12px;color:var(--hero-text-soft);line-height:1.65;margin:0 0 10px;text-align:left;padding:8px 12px;background:#0e744b0a;border-left:3px solid rgba(14,116,75,.35);border-radius:4px}.golf-hero-cards-caption .caption-badge{display:inline-block;background:var(--hero-green);color:#fff;font-size:10px;font-weight:800;padding:1px 7px;border-radius:99px;margin-right:6px;letter-spacing:.08em;vertical-align:1px}.golf-hero-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;max-width:900px;margin:0 auto}.golf-hero-card{background:var(--hero-card);border:1px solid var(--hero-border);border-radius:10px;padding:10px 6px 8px;text-align:center}.golf-hero-card .label{display:block;font-size:11px;color:var(--hero-text-soft);margin-bottom:2px}.golf-hero-card .value{display:block;font-size:18px;font-weight:800;color:var(--hero-green)}.golf-hero-card .hint{display:block;font-size:10px;color:var(--hero-text-soft);margin-top:2px;opacity:.85}@media(max-width:640px){.golf-hero-cards{grid-template-columns:repeat(2,1fr)}.golf-hero-cards-caption{font-size:11px;text-align:left}}.golf-seo{background:#fff;color:var(--hero-text);padding:36px 20px 28px;border-bottom:1px solid var(--hero-border)}.golf-seo-inner{max-width:880px;margin:0 auto}.golf-seo h2{color:var(--hero-green);font-size:clamp(18px,2.2vw,24px);margin:28px 0 10px;border-bottom:2px solid var(--hero-border);padding-bottom:6px}.golf-seo h2:first-of-type{margin-top:0}.golf-seo h3{font-size:15px;margin:16px 0 6px;color:var(--hero-text)}.golf-seo p{font-size:14px;line-height:1.85;color:var(--hero-text-soft);margin:0 0 12px}.golf-seo ul{padding-left:1.2em;margin:0 0 12px;color:var(--hero-text-soft);font-size:14px;line-height:1.85}.golf-seo .note{background:#fff8e1;border-left:4px solid #f59e0b;padding:10px 14px;font-size:13px;color:#5a4500;border-radius:4px;margin:12px 0}.golf-faq details{border:1px solid var(--hero-border);border-radius:8px;padding:10px 14px;margin-bottom:8px;background:#fafbfc}.golf-faq summary{font-weight:700;cursor:pointer;color:var(--hero-text);font-size:14px}.golf-faq details[open]{background:#fff}.golf-faq details p{margin-top:8px;font-size:13px;color:var(--hero-text-soft);line-height:1.8}.golf-related{background:#f5faf6;padding:24px 20px;border-bottom:1px solid var(--hero-border)}.golf-related-inner{max-width:880px;margin:0 auto}.golf-related h2{color:var(--hero-green);font-size:18px;margin:0 0 10px}.golf-related ul{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}.golf-related li a{display:block;padding:10px 14px;background:#fff;border:1px solid var(--hero-border);border-radius:8px;text-decoration:none;color:var(--hero-text);font-size:13px;font-weight:600;transition:border-color .12s}.golf-related li a:hover{border-color:var(--hero-green);color:var(--hero-green)}.golf-related-emoji{display:inline-block;margin-right:8px;font-size:1.15em;line-height:1;vertical-align:-2px;filter:saturate(.95)}.golf-footer{text-align:center;padding:18px 12px 28px;font-size:12px;color:var(--hero-text-soft);background:#fff}.golf-footer a{color:var(--hero-green);text-decoration:none;font-weight:600}.golf-footer a:hover{text-decoration:underline}@media(max-width:720px){.app{height:min(85vh,720px)}.input-panel{width:240px;min-width:220px}.scenario-chip-desc{display:none}.scenario-chip{padding:8px 12px}.golf-hero{padding:24px 14px 20px}.golf-hero h1{gap:.4em}.golf-hero-ball{width:32px;height:32px}.golf-hero-deco-ball{top:-18px;right:-24px;width:110px;opacity:.08}.golf-hero-flag{display:none}}@media(max-width:520px){.app-body{flex-direction:column}.input-panel{width:100%;min-width:0;border-right:none;border-bottom:1px solid var(--border);max-height:50%}}
