:root{color:#25303b;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#b8eff6;font-family:Hiragino Sans,Yu Gothic,Meiryo,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:linear-gradient(160deg,#b8eff6 0%,#fff8d5 50%,#ffd7ca 100%)}button,input{font:inherit}button{cursor:pointer}.app-shell{background:#fffaf1;width:min(100%,480px);min-height:100vh;margin:0 auto;position:relative;overflow-x:hidden;box-shadow:0 18px 60px #283f5038}.home-only-screen{min-height:100vh;padding:18px 16px 26px}h1,h2,h3,p{letter-spacing:0}h1,h2,h3{margin:0;line-height:1.2}h1{font-size:1.22rem}h2{font-size:1.38rem}p{line-height:1.55}.recommendation-stage{gap:10px;display:grid}.start-panel{align-content:start;gap:6px;display:grid}.start-action-row{gap:8px;display:grid}.start-action-row.with-alternate{grid-template-columns:minmax(0,4.5fr) minmax(72px,1fr);align-items:stretch}.start-recommendation-button{color:#fff;text-align:center;background:linear-gradient(135deg,#ff6f61 0%,#ffb23f 58%,#00a6a6 100%);border:0;border-radius:8px;justify-content:center;align-items:center;width:100%;min-height:62px;padding:10px 16px;font-size:1.38rem;font-weight:950;line-height:1.15;display:flex;box-shadow:0 10px 22px #ff6f613d}.alternate-candidate-button{color:#17614f;text-align:center;background:#e9faef;border:0;border-radius:8px;min-height:62px;padding:8px 10px;font-size:.92rem;font-weight:950;box-shadow:0 8px 18px #4152631a}.start-recommendation-button:disabled{cursor:default;opacity:.72}.alternate-candidate-button:disabled{cursor:default;opacity:.56}.start-panel p{color:#65707b;text-align:center;margin:0;font-size:.82rem;font-weight:900}.loading-panel,.location-fallback-card{text-align:center;background:#fff;border-radius:8px;place-items:center;gap:14px;min-height:176px;padding:18px;display:grid;box-shadow:0 10px 26px #41526321}.loading-panel p{color:#17614f;margin:0;font-size:1.08rem;font-weight:950}.loading-spinner{border:4px solid #d8f4f5;border-top-color:#00a6a6;border-radius:999px;width:36px;height:36px;animation:.8s linear infinite spin}.location-fallback-card h2{max-width:320px;font-size:1.24rem}.location-fallback-actions{gap:10px;width:100%;display:grid}.post-card-actions{margin-top:8px}@keyframes spin{to{transform:rotate(360deg)}}.next-plan-strip{color:#25303b;text-align:left;background:#fff;border:2px solid #ffe18b;border-radius:8px;gap:3px;width:100%;min-height:62px;margin-top:12px;margin-bottom:12px;padding:12px;display:grid;box-shadow:0 8px 20px #4152631a}.next-plan-strip span{color:#17614f;font-size:.92rem;font-weight:900}.next-plan-strip strong{font-size:1.08rem}.recommend-card,.condition-entry,.condition-summary,.daily-footer,.empty-card{background:#fff;border-radius:8px;box-shadow:0 10px 26px #41526321}.recommend-card{touch-action:pan-y;border:3px solid #ffb23f;min-height:548px;padding:18px}.sheet-back-button,.sheet-cancel-button{color:#25303b;text-align:center;background:#edf7fb;border:0;border-radius:8px;justify-content:center;align-items:center;gap:4px;min-height:46px;font-size:.86rem;font-weight:950;display:inline-flex}.recommend-kicker{color:#ff6f61;margin:0 0 8px;font-size:1.02rem;font-weight:950}.recommend-label{color:#604600;background:#fff174;border-radius:999px;align-items:center;min-height:32px;margin-bottom:10px;padding:6px 10px;font-size:.86rem;font-weight:950;display:inline-flex}.recommend-card h2{margin-bottom:16px;font-size:1.62rem}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.metric-grid span{background:#f0fbff;border-radius:8px;gap:5px;min-height:72px;padding:11px;font-size:.9rem;font-weight:850;display:grid}.metric-grid strong{font-size:1.22rem}.metric-grid .wide-metric{color:#17614f;background:#e9faef;grid-column:1/-1;justify-content:center;align-items:center;min-height:48px;font-size:1.05rem;font-weight:950;display:flex}.recommend-reason{background:#f1fffb;border-left:5px solid #00a6a6;border-radius:8px;margin:14px 0 16px;padding:13px;font-size:1rem;font-weight:850}.main-actions{justify-content:center;display:flex}.go-button,.second-button,.primary-button,.outline-button{text-align:center;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:52px;font-size:1.06rem;font-weight:950;display:inline-flex}.go-button{color:#fff;background:linear-gradient(135deg,#ff6f61,#ffb23f);border:0;width:min(72%,280px);box-shadow:0 10px 24px #ff6f614d}.second-button,.outline-button{color:#25303b;background:#fff;border:2px solid #82dce6}.primary-button{color:#fff;background:#00a6a6;border:0}.primary-button.full,.outline-button.full{width:100%}.support-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px;display:grid}.support-actions button{color:#59616d;background:#f0f1f4;border:0;border-radius:8px;min-height:42px;font-size:.86rem;font-weight:900}.swipe-hint{color:#7b6570;text-align:center;margin:10px 0 0;font-size:.78rem;font-weight:850}.not-these-button{color:#59616d;text-underline-offset:3px;background:#ffffffb8;border:0;border-radius:999px;width:max-content;max-width:100%;min-height:42px;margin:10px auto 0;padding:0 14px;font-size:.92rem;font-weight:900;text-decoration:underline;display:block}.condition-entry,.daily-footer,.empty-card{margin-top:14px;padding:14px}.condition-entry h2{margin-bottom:12px;font-size:1.12rem}.condition-button-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;display:grid}.condition-button-grid button,.condition-summary button,.daily-footer button,.sheet-options button{color:#25303b;text-align:center;background:#edf7fb;border:0;border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:46px;font-size:.92rem;font-weight:900;display:inline-flex}.condition-summary{flex-wrap:wrap;gap:8px;margin-top:12px;padding:10px;display:flex}.condition-summary button{min-height:38px;padding:0 10px}.condition-summary .clear-chip{color:#a74736;background:#ffe6e0}.daily-footer{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.daily-footer div{text-align:center;background:#f7f2ff;border-radius:8px;gap:4px;min-height:64px;padding:10px;display:grid}.daily-footer strong{font-size:1.32rem}.daily-footer span{font-size:.82rem;font-weight:900}.daily-footer button{background:#fff;border:2px solid #edf1f5;grid-column:span 1}.daily-footer .danger-link{color:#a74736;background:#fff7f4;border-color:#ffe6e0}.sheet-backdrop,.map-backdrop{z-index:40;background:#1f2b374d;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.bottom-sheet{width:min(100%,480px);max-height:min(78vh,680px);padding:14px 16px calc(18px + env(safe-area-inset-bottom));background:#fffaf1;border-radius:16px 16px 0 0;overflow-y:auto;box-shadow:0 -16px 32px #1f2b372e}.bottom-sheet header,.map-modal header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.bottom-sheet header button,.map-modal header button{color:#25303b;background:#fff;border:0;border-radius:8px;justify-content:center;align-items:center;gap:6px;min-height:42px;font-weight:900;display:inline-flex}.sheet-options{gap:8px;display:grid}.sheet-options.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.sheet-options button{text-align:left;justify-content:flex-start;min-height:48px;padding:0 12px}.sheet-options button.is-selected{color:#fff;background:#ff6f61}.sheet-stack{gap:12px;display:grid}.sheet-subheader{justify-content:space-between;align-items:center;gap:10px;display:flex}.sheet-back-button{background:#fff;padding:0 12px}.sheet-cancel-button{color:#65707b;background:#f0f1f4;padding:0 12px}.time-input{color:#374250;gap:8px;font-weight:900;display:grid}.time-input input{color:#25303b;background:#f0fbff;border:0;border-radius:8px;width:100%;min-height:48px;padding:8px 10px;font-size:1.08rem;font-weight:900}.small-note{color:#65707b;background:#fff;border-radius:8px;padding:10px;font-size:.86rem;font-weight:850}.map-backdrop{align-items:center;padding:16px}.map-modal{background:#fffaf1;border-radius:8px;width:min(100%,448px);padding:14px;box-shadow:0 16px 36px #1f2b3738}.simple-map{aspect-ratio:1;background:#e8fbff;border-radius:8px;width:100%;display:block}.park-area{fill:#dcf6cf;stroke:#fff;stroke-width:3px}.map-zone{stroke:#ffffffd9;stroke-width:1.2px}.zone-left{fill:#ffd38e}.zone-right{fill:#ffc0df}.zone-front{fill:#f8c7a4}.route-line{stroke:#2477ff;stroke-width:1.8px;stroke-linecap:round;stroke-dasharray:3 3}.destination-marker circle{fill:#ff6f61;stroke:#fff;stroke-width:1.2px}.destination-marker text{fill:#fff;text-anchor:middle;font-size:5px;font-weight:950}.current-dot circle:first-child{fill:#2477ff38}.current-dot circle:last-child{fill:#2477ff;stroke:#fff;stroke-width:1px}.map-info{color:#17614f;background:#e9faef;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:46px;margin-top:12px;font-weight:950;display:flex}.toast{z-index:60;color:#fff;text-align:center;background:#25303b;border-radius:8px;justify-content:center;align-items:center;gap:12px;width:min(100% - 32px,420px);padding:13px 16px;font-weight:950;display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 10px 24px #25303b40}.toast button{color:#25303b;white-space:nowrap;background:#fff;border:0;border-radius:8px;min-height:32px;font-size:.86rem;font-weight:950}.empty-card p{font-weight:850}@media (width<=370px){.home-only-screen{padding-left:12px;padding-right:12px}.metric-grid,.condition-button-grid,.daily-footer,.sheet-options.compact{grid-template-columns:1fr}.start-action-row.with-alternate{grid-template-columns:minmax(0,4fr) minmax(68px,1fr);gap:6px}.start-recommendation-button,.alternate-candidate-button{min-height:58px}.start-recommendation-button{font-size:1.22rem}.alternate-candidate-button{font-size:.82rem}.support-actions{grid-template-columns:1fr}}
