:root{--green: #0f5132;--green-dark: #0a3a24;--gold: #e0a32e;--cream: #fdf6e3;--paper: #ffffff;--ink: #1c1a17;--ink-soft: #5b554c;--line: #e6ddc8;--warn: #b4452f;--shadow: 0 2px 10px rgba(0, 0, 0, .08);--radius: 16px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--cream);color:var(--ink);font-size:19px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}.app{max-width:560px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--cream)}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:8px;padding:max(env(safe-area-inset-top),10px) 12px 10px;background:var(--green);color:var(--cream);box-shadow:var(--shadow)}.brand{flex:1;text-align:center;background:none;border:none;color:var(--cream);font-weight:700;font-size:18px}.back-btn,.icon-btn{background:#ffffff26;border:none;color:var(--cream);font-size:17px;font-weight:600;padding:10px 14px;border-radius:12px;min-height:44px}.icon-btn{font-size:20px}.topbar-spacer{width:72px}.content{flex:1;padding:20px 16px 140px}h1{font-size:30px;line-height:1.15;margin:0 0 12px}h2{font-size:21px;margin:28px 0 10px}.lede{font-size:19px;color:var(--ink-soft);margin:0 0 22px}.hint{color:var(--ink-soft);font-size:16px;margin:6px 0}.hint.warn{color:var(--warn);font-weight:600}.kicker{text-transform:uppercase;letter-spacing:.08em;font-size:14px;color:var(--gold);font-weight:700;margin:0 0 4px}.big-btn{display:block;width:100%;background:var(--green);color:var(--cream);border:none;border-radius:var(--radius);padding:20px;font-size:22px;font-weight:700;box-shadow:var(--shadow);min-height:64px}.big-btn:disabled{opacity:.6}.big-btn.ghost{background:var(--paper);color:var(--green);border:2px solid var(--green)}.hero{text-align:center;padding:12px 0 8px}.card-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}.place-card{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;text-align:left;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);min-height:70px}.place-card-main{display:flex;flex-direction:column;gap:2px}.place-name{font-size:19px;font-weight:700;color:var(--ink)}.place-dist{font-size:15px;color:var(--gold);font-weight:700}.chev{font-size:28px;color:var(--ink-soft)}.mini-play{flex:0 0 auto;width:52px;height:52px;display:grid;place-items:center;background:var(--green);color:var(--cream);border-radius:50%;font-size:20px}.field-label{display:block;font-weight:700;margin:8px 0 6px}.select{width:100%;font-size:19px;padding:16px;border-radius:var(--radius);border:2px solid var(--green);background:var(--paper);color:var(--ink);min-height:60px}.stop-title{font-size:28px}.big-actions{display:flex;flex-direction:column;gap:14px;margin:18px 0 8px}.action-btn{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:14px;align-items:center;text-align:left;background:var(--paper);border:2px solid var(--green);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);min-height:78px}.action-btn.deep{background:var(--green);border-color:var(--green);color:var(--cream)}.action-btn.active{outline:4px solid var(--gold)}.action-icon{grid-row:1 / 3;font-size:32px}.action-label{font-size:21px;font-weight:800}.action-sub{font-size:15px;opacity:.85}.action-btn.full{width:100%}.action-group{display:flex;flex-direction:column}.read-toggle{align-self:flex-start;background:none;border:none;color:var(--green);font-size:16px;font-weight:700;padding:10px 4px;margin-top:4px}.reading-text{background:var(--paper);border:1px solid var(--line);border-left:5px solid var(--gold);border-radius:12px;padding:18px 20px;margin:4px 0 6px;font-size:19px;line-height:1.7;color:var(--ink);animation:note-open .3s ease-out}.reading-text p{margin:0 0 14px}.reading-text p:last-child{margin-bottom:0}.chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.chip{background:var(--gold);color:var(--green-dark);border:none;border-radius:999px;padding:12px 18px;font-size:16px;font-weight:800;min-height:48px}.wifi-note{padding:14px;border-radius:var(--radius);font-weight:700;margin:16px 0}.wifi-note.good{background:#e6f4ea;color:var(--green)}.wifi-note.warn{background:#fbeae6;color:var(--warn)}.progress-wrap{margin-top:18px}.progress-bar{height:18px;background:var(--line);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--green);transition:width .2s}.ready-box{text-align:center;background:#e6f4ea;border-radius:var(--radius);padding:28px 20px;margin-top:18px}.ready-check{font-size:56px;color:var(--green);line-height:1}.fineprint{font-size:14px;color:var(--ink-soft);margin-top:22px}.miniplayer{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:100%;max-width:560px;background:var(--green-dark);color:var(--cream);padding:12px 14px max(env(safe-area-inset-bottom),12px);box-shadow:0 -2px 14px #00000038;z-index:30}.miniplayer-row{display:flex;align-items:center;gap:12px}.miniplayer-meta{flex:1;min-width:0}.miniplayer-title{font-weight:800;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.miniplayer-sub{font-size:14px;opacity:.8}.play-btn{flex:0 0 auto;width:56px;height:56px;border-radius:50%;border:none;background:var(--gold);color:var(--green-dark);font-size:20px;font-weight:900}.rate-btn{flex:0 0 auto;background:#ffffff29;border:none;color:var(--cream);border-radius:12px;padding:12px 14px;font-size:16px;font-weight:800;min-height:48px}.scrubber-row{display:flex;align-items:center;gap:10px;margin-top:8px}.time{font-size:13px;opacity:.85;font-variant-numeric:tabular-nums;min-width:38px}.scrubber{flex:1;accent-color:var(--gold);height:28px}.miniplayer-error{margin-top:8px;font-size:14px;color:#ffd9cf}.brand{display:inline-flex;align-items:center;gap:8px}.brand-flower{font-size:20px;touch-action:none;user-select:none;-webkit-user-select:none}.brand-text{font-weight:700}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0a2318b3;display:grid;place-items:center;padding:24px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.overlay-card{background:var(--cream);border-radius:22px;padding:28px 24px;max-width:420px;width:100%;text-align:center;box-shadow:0 10px 40px #00000059;border:2px solid var(--gold)}.overlay-card.secret{border-color:var(--green)}.overlay-flower{font-size:44px;line-height:1}.overlay-flower.big{font-size:64px;text-align:center;display:block}.overlay-msg{font-size:19px;color:var(--ink);margin:14px 0 22px;white-space:pre-line}.overlay-card .big-btn{margin-top:10px}.note-reveal{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:#fff7e8;border:2px solid var(--gold);border-radius:var(--radius);padding:14px 16px;margin:4px 0 10px;animation:note-pulse 1.4s ease-in-out infinite}.note-reveal-icon{font-size:26px;animation:note-wiggle 1.4s ease-in-out infinite}.note-reveal-text{font-size:17px;font-weight:700;color:var(--green-dark)}@keyframes note-pulse{0%,to{box-shadow:0 0 #e0a32e8c}50%{box-shadow:0 0 0 10px #e0a32e00}}@keyframes note-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-9deg)}75%{transform:rotate(9deg)}}@media(prefers-reduced-motion:reduce){.note-reveal,.note-reveal-icon,.love-note.open{animation:none}}.love-note{display:flex;gap:12px;align-items:flex-start;background:#fff7e8;border:2px dashed var(--gold);border-radius:var(--radius);padding:16px;margin:4px 0 10px}.love-note.open{animation:note-open .4s ease-out}@keyframes note-open{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:none}}.love-note-flower{font-size:24px}.love-note p{margin:0;font-size:18px;color:var(--ink)}.photo-tip{display:flex;gap:12px;align-items:flex-start;background:#eef4f0;border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin:14px 0 4px}.photo-tip-icon{font-size:24px}.photo-tip-label{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--green);margin-bottom:2px}.photo-tip p{margin:0;font-size:17px;color:var(--ink)}.letter-card{display:flex;align-items:center;gap:14px;width:100%;text-align:left;margin-top:26px;background:linear-gradient(135deg,#f6c453,#e0a32e);color:var(--green-dark);border:none;border-radius:var(--radius);padding:20px;min-height:72px;box-shadow:var(--shadow)}.letter-card-flower{font-size:30px}.letter-card-label{font-size:19px;font-weight:800}.stop-title.center{text-align:center}.letter-paper{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-top:18px;box-shadow:var(--shadow);font-size:19px;line-height:1.65}.letter-paper p{margin:0 0 12px;white-space:pre-line}.share-card{display:flex;align-items:center;gap:12px;width:100%;text-align:left;margin:16px 0 4px;background:#eaf3ff;border:2px solid #2f7dd1;border-radius:var(--radius);padding:18px;min-height:64px;box-shadow:var(--shadow)}.share-icon{font-size:26px}.share-label{font-size:18px;font-weight:800;color:#1a4f8a}.share-link{display:inline-flex;align-items:center;gap:8px;background:none;border:none;color:#1a4f8a;font-size:17px;font-weight:700;padding:10px 0;margin-top:6px}.share-sheet{text-align:left}.share-sheet h2{margin-top:0}.share-preview{width:100%;max-height:240px;object-fit:cover;border-radius:12px;margin:6px 0}.share-filechip{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:16px;margin:6px 0;font-weight:700}.share-change{background:none;border:none;color:#1a4f8a;font-weight:700;font-size:15px;padding:6px 0 10px}.share-caption{width:100%;font-family:inherit;font-size:18px;padding:14px;border-radius:12px;border:2px solid var(--line);resize:vertical;margin-bottom:12px}.share-done{text-align:center}@media(prefers-contrast:more){:root{--ink-soft: #3a352e;--line: #b9ad90}}
