:root{color-scheme:light;font-family:Avenir Next,Gill Sans,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;--paper: oklch(94% .035 84);--paper-deep: oklch(88% .055 80);--ink: oklch(23% .035 218);--muted: oklch(45% .035 216);--sea: oklch(58% .095 190);--sea-deep: oklch(34% .07 196);--coral: oklch(62% .13 38);--butter: oklch(91% .1 93);--green: oklch(58% .09 145);--line: oklch(80% .045 78);--surface: oklch(98% .026 88);--shadow: 0 24px 80px oklch(28% .04 215 / 18%);background:var(--paper);color:var(--ink);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}button,a{-webkit-tap-highlight-color:transparent}button{border:0;font:inherit}.app-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#faeec9,#b0e4db),var(--paper)}.phone-frame{width:min(100%,430px);height:min(860px,calc(100dvh - 48px));min-height:0;position:relative;display:grid;grid-template-rows:auto 1fr auto;overflow:hidden;border:1px solid oklch(72% .05 76);border-radius:30px;background:radial-gradient(circle at 12% 0%,oklch(96% .09 93),transparent 28%),linear-gradient(180deg,var(--surface),var(--paper));box-shadow:var(--shadow)}.status-strip{display:flex;justify-content:space-between;gap:16px;padding:max(16px,env(safe-area-inset-top)) 22px 12px;color:var(--muted);font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.screen{min-height:0;overflow-y:auto;padding:0 18px 96px}.view{display:grid;gap:18px;animation:rise .46s cubic-bezier(.22,1,.36,1)}.city-header,.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding-top:8px}.section-header{display:block}.eyebrow{margin:0 0 6px;color:var(--sea-deep);font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-family:Georgia,Times New Roman,serif;font-size:2.65rem;line-height:.95;letter-spacing:0}h2{margin-bottom:0;font-family:Georgia,Times New Roman,serif;font-size:1.52rem;line-height:1.08;letter-spacing:0}p{color:var(--muted);line-height:1.5}.ship-chip{min-width:86px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 12px;border-radius:999px;background:var(--butter);color:var(--ink);font-weight:800}.hero-card,.next-panel,.story-card,.ship-panel,.map-panel,.route-links-panel{border:1px solid var(--line);border-radius:8px;background:color-mix(in oklch,var(--surface),white 16%)}.hero-card{position:relative;overflow:hidden;padding:22px;min-height:230px;display:grid;align-content:end;gap:14px;background:linear-gradient(165deg,#fceabe,#93d2ca),var(--surface)}.route-line{position:absolute;inset:20px 20px auto auto;width:102px;height:120px;border-right:2px dashed oklch(50% .08 190);border-top:2px dashed oklch(50% .08 190);transform:rotate(-8deg)}.route-line span{position:absolute;width:13px;height:13px;border-radius:99px;background:var(--coral);box-shadow:0 0 0 5px #ffe3c4;box-shadow:0 0 0 5px oklch(93% .06 69)}.route-line span:nth-child(1){right:-7px;top:-7px}.route-line span:nth-child(2){right:-7px;top:52px;background:var(--sea)}.route-line span:nth-child(3){right:45px;top:-7px;background:var(--green)}.quick-stats,.panel-kicker,.distance-row,.return-banner,.button-row,.fact-block,.order-hint,.tip-grid p,.ship-grid span{display:flex;align-items:center;gap:9px}.quick-stats{flex-wrap:wrap}.quick-stats span,.panel-kicker span,.return-banner,.distance-row{color:var(--sea-deep);font-size:.88rem;font-weight:800}.quick-stats span{padding:7px 10px;border-radius:999px;background:#fff5d8;background:oklch(97% .042 91)}.primary-action,.secondary-action,.ghost-action,.text-action{min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:9px;border-radius:999px;cursor:pointer;font-weight:850;transition:transform .18s ease,background-color .18s ease}.primary-action{padding:0 18px;background:var(--ink);color:var(--paper)}.secondary-action,.ghost-action{padding:0 16px;background:#aee4df;color:var(--sea-deep)}.ghost-action{background:transparent;border:1px solid var(--line)}.text-action{padding:0 12px;background:transparent;color:var(--sea-deep)}.primary-action:active,.secondary-action:active,.ghost-action:active,.text-action:active,.tab-button:active,.stop-row:active{transform:translateY(1px) scale(.99)}.start-button{width:100%}.next-panel,.story-card,.ship-panel,.route-links-panel{padding:18px}.crawl-scoreboard{display:grid;grid-template-columns:.9fr 1.1fr;gap:10px}.crawl-scoreboard div{min-height:104px;display:grid;align-content:end;padding:14px;border:1px solid var(--line);border-radius:8px;background:linear-gradient(160deg,#fff1cf,#fccbbb),var(--surface);background:linear-gradient(160deg,color(xyz 0.839 0.885 0.628),#fccbbb),var(--surface)}.crawl-scoreboard span{font-family:Georgia,Times New Roman,serif;font-size:2.35rem;font-weight:900;line-height:1}.crawl-scoreboard p{margin:4px 0 0;color:var(--sea-deep);font-size:.86rem;font-weight:850}.bakery-list{display:grid;gap:14px}.bakery-card{padding:16px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.bakery-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:10px}.bun-badge{width:48px;height:48px;display:grid;place-items:center;flex:0 0 auto;border-radius:999px;background:var(--coral);color:var(--surface);font-family:Georgia,Times New Roman,serif;font-size:1.35rem;font-weight:900;box-shadow:0 0 0 6px #ffe6cf;box-shadow:0 0 0 6px oklch(94% .065 66)}.bun-badge.empty{background:var(--butter);color:var(--ink)}.order-hint{align-items:flex-start;margin:12px 0;padding:10px 12px;border-radius:8px;background:#fbeac2;color:var(--sea-deep);font-size:.9rem;font-weight:750}.order-hint svg{flex:0 0 auto;margin-top:2px;color:var(--coral)}.rating-strip{display:grid;grid-template-columns:repeat(11,minmax(0,1fr));gap:4px;margin:14px 0}.rating-dot{min-width:0;height:34px;border:1px solid var(--line);border-radius:999px;background:#faf1dc;color:var(--muted);cursor:pointer;font-size:.78rem;font-weight:900;transition:transform .16s ease,background-color .16s ease,color .16s ease}.rating-dot.active{background:var(--ink);color:var(--paper);transform:translateY(-2px)}.review-field{display:grid;gap:7px}.review-field span{color:var(--sea-deep);font-size:.78rem;font-weight:850;letter-spacing:.04em;text-transform:uppercase}.review-field textarea{width:100%;resize:vertical;border:1px solid var(--line);border-radius:8px;padding:12px;background:#fcf5e3;color:var(--ink);font:inherit;line-height:1.4}.review-field textarea:focus{outline:3px solid oklch(82% .08 88);border-color:var(--coral)}.panel-kicker{justify-content:space-between;margin-bottom:12px}.next-panel h2{margin-bottom:10px}.return-banner{margin-top:14px;padding:12px 14px;border-radius:8px;background:var(--butter)}.button-row{margin-top:16px}.button-row .primary-action{flex:1}.image-poster{height:150px;display:flex;align-items:flex-end;padding:14px;border-radius:7px;background:linear-gradient(150deg,oklch(65% .1 190),transparent 45%),linear-gradient(25deg,#9b462c,#ebd69b)}.image-poster span{padding:8px 10px;border-radius:999px;background:#fdf1d4;color:var(--ink);font-size:.8rem;font-weight:800}.fact-block{align-items:flex-start;margin-top:16px}.fact-block svg{color:var(--coral);flex:0 0 auto;margin-top:2px}.fact-block p:last-child{margin-bottom:0;color:var(--ink);font-weight:600}.tip-grid{display:grid;gap:10px;margin-top:14px}.tip-grid p{align-items:flex-start;margin:0;padding-top:10px;border-top:1px solid var(--line);font-size:.92rem}.tip-grid svg{flex:0 0 auto;color:var(--sea);margin-top:3px}.stop-list{display:grid;gap:10px}.stop-row{width:100%;min-height:72px;display:grid;grid-template-columns:42px 1fr 22px;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink);text-align:left}.stop-row.active{border-color:var(--coral);background:#ffead8;background:oklch(95% .055 65)}.stop-row small{display:block;margin-top:4px;color:var(--muted);line-height:1.35}.stop-number{width:38px;height:38px;display:grid;place-items:center;border-radius:999px;background:var(--paper-deep);color:var(--sea-deep);font-weight:900}.map-panel{overflow:hidden;padding:12px}.map-panel svg{width:100%;display:block;border-radius:7px;background:#f9eac6}.water-shape{fill:#8ac4c5}.route-path{fill:none;stroke:var(--ink);stroke-width:5;stroke-linecap:round;stroke-dasharray:1 12}.ship-dot{fill:var(--sea-deep)}.poi-dot{fill:var(--coral);stroke:var(--surface);stroke-width:4}.poi-dot.active{fill:var(--green)}.you-dot{fill:var(--ink);stroke:var(--butter);stroke-width:5}text{fill:var(--ink);font-size:16px;font-weight:900}.map-note,.location-note{margin:0;font-size:.92rem}.route-links-panel{display:grid;gap:12px}.route-link-list{display:grid;gap:9px}.route-link{min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fcf1d8;color:var(--ink);text-decoration:none;font-weight:850}.route-link small{display:block;margin-top:3px;color:var(--muted);font-weight:700}.route-link svg{flex:0 0 auto;color:var(--coral)}.ship-panel{display:grid;gap:18px;background:linear-gradient(180deg,#fdf1d0,#abe5dd),var(--surface)}.big-time span{display:block;color:var(--muted);font-weight:800}.big-time strong{display:block;margin-top:2px;font-family:Georgia,Times New Roman,serif;font-size:3rem;line-height:1}.ship-grid{display:grid;gap:10px}.ship-grid span{align-items:flex-start;color:var(--sea-deep);font-weight:800}.link-action{text-decoration:none}.tab-bar{position:absolute;left:12px;right:12px;bottom:max(12px,env(safe-area-inset-bottom));display:grid;grid-template-columns:repeat(5,1fr);gap:6px;padding:8px;border:1px solid var(--line);border-radius:999px;background:#fff8e7f0;background:oklch(98% .026 88 / 94%);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.tab-button{min-height:54px;display:grid;place-items:center;gap:2px;border-radius:999px;background:transparent;color:var(--muted);cursor:pointer;font-size:.68rem;font-weight:800}.tab-button svg{width:19px;height:19px}.tab-button.active{background:var(--ink);color:var(--paper)}.permission-sheet{position:absolute;left:14px;right:14px;bottom:92px;display:grid;gap:18px;padding:20px;border:1px solid var(--line);border-radius:12px;background:var(--surface);box-shadow:0 18px 50px #08232b33;animation:sheet .28s cubic-bezier(.22,1,.36,1)}.permission-sheet h2{margin-bottom:10px}.permission-sheet p:last-child{margin-bottom:0}.sheet-actions{display:grid;grid-template-columns:1fr;gap:8px}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes sheet{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.city-switcher{display:inline-flex;align-items:center;gap:5px;padding:0;background:transparent;color:var(--muted);cursor:pointer;font:inherit;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.city-switcher svg{opacity:.6}.day-picker-sheet{bottom:92px;max-height:70vh;overflow-y:auto}.day-picker-list{display:grid;gap:8px}.day-picker-row{width:100%;min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink);text-align:left;cursor:pointer}.day-picker-row.active{border-color:var(--coral);background:#ffead8;background:oklch(95% .055 65)}.day-picker-info{flex:1}.day-picker-info strong{display:block}.day-picker-info small{display:block;margin-top:3px;color:var(--muted);font-weight:700}.today-badge{padding:4px 10px;border-radius:999px;background:var(--butter);color:var(--ink);font-size:.74rem;font-weight:850;text-transform:uppercase;letter-spacing:.04em}.back-button{display:inline-flex;align-items:center;gap:6px;padding:8px 0;background:transparent;color:var(--sea-deep);cursor:pointer;font-weight:800;font-size:.88rem}.stop-detail-poster{position:relative;height:180px;display:flex;align-items:flex-end;justify-content:space-between;padding:16px;border-radius:8px;background:linear-gradient(155deg,oklch(65% .1 190),transparent 50%),linear-gradient(25deg,#9b462c,#ebd69b);overflow:hidden}.stop-detail-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.stop-detail-poster .stop-detail-number,.stop-detail-poster .stop-detail-category{position:relative;z-index:1}.stop-detail-poster:has(.stop-detail-img):after{content:"";position:absolute;inset:0;background:linear-gradient(to top,oklch(20% .02 220 / 60%),transparent 60%)}.stop-detail-number{width:44px;height:44px;display:grid;place-items:center;border-radius:999px;background:#fef8eae5;color:var(--ink);font-family:Georgia,Times New Roman,serif;font-size:1.3rem;font-weight:900}.stop-detail-category{padding:8px 12px;border-radius:999px;background:#fdf1d4e5;color:var(--ink);font-size:.8rem;font-weight:800}.stop-detail-header h1{font-size:2.1rem;margin-bottom:10px}.stop-detail-chips{display:flex;flex-wrap:wrap;gap:8px}.detail-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:#f0e4c7;color:var(--sea-deep);font-size:.84rem;font-weight:800}.detail-chip.scheduled{background:var(--butter);color:var(--ink)}.detail-chip.done{background:#bbe4bc;color:#18361a}.detail-chip.skipped{background:#f3d8c4;color:var(--muted)}.stop-detail-card{border:1px solid var(--line);border-radius:8px;padding:16px;background:color-mix(in oklch,var(--surface),white 16%)}.stop-detail-card .fact-block{margin-top:0}.stop-detail-card .fact-block .eyebrow{margin-bottom:4px}.stop-detail-card .fact-block p:last-child{margin-bottom:0}.stop-detail-actions{display:grid;gap:10px}.stop-detail-actions .primary-action,.stop-detail-actions .ghost-action{width:100%}.welcome-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:40px 24px;text-align:center}.welcome-header{margin-bottom:32px}.welcome-header svg{color:var(--sea);margin-bottom:16px}.welcome-header h1{font-family:Georgia,Times New Roman,serif;font-size:2rem;margin:0 0 8px}.welcome-header p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.5;max-width:260px;margin-inline:auto}.crew-list{display:grid;gap:10px;width:100%;max-width:280px}.crew-button{padding:16px;border-radius:10px;background:var(--surface);border:1.5px solid var(--line);color:var(--ink);font-size:1.1rem;font-weight:700;cursor:pointer;transition:border-color .15s,background .15s}.crew-button:active{background:var(--butter);border-color:var(--sea)}.bun-radar{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:8px;background:var(--butter);color:var(--sea-deep);font-size:.9rem}.bun-radar p{margin:0;line-height:1.35}.bun-radar.found{background:linear-gradient(135deg,#f8e093,#ffcba9);background:linear-gradient(135deg,#f8e093,color(xyz 0.711 0.667 0.417))}.custom-bakery-card{border-style:dashed;border-color:var(--coral);background:#fff5f1;background:oklch(98% .02 38)}.remove-bakery{display:flex;align-items:center;gap:6px;margin-top:10px;padding:0;background:none;color:var(--muted);font-size:.82rem;cursor:pointer}.remove-bakery:active{color:var(--coral)}.add-bakery-form{padding:16px;border:1px dashed var(--line);border-radius:8px;background:var(--surface)}.add-bakery-form .review-field{margin-bottom:12px}.bakery-name-input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:6px;background:var(--paper);color:var(--ink);font:inherit;font-size:.95rem}.bakery-name-input:focus{outline:2px solid var(--sea);outline-offset:-1px;border-color:var(--sea)}.add-bakery-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border:2px dashed var(--line);border-radius:8px;background:none;color:var(--sea-deep);font-weight:700;font-size:.95rem;cursor:pointer}.add-bakery-button:active{background:var(--surface);border-color:var(--sea)}@media(max-width:520px){.app-shell{padding:0}.phone-frame{height:100dvh;width:100%;border-radius:0;border:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;scroll-behavior:auto!important;transition-duration:1ms!important}}
