:root{--bg:#0e1116;--surface:#161a21;--surface-2:#1e232c;--inset:#0b0e13;--border:#283039;--border-strong:#3a434f;--text:#e8ebf0;--text-dim:#9aa3b2;--text-faint:#6b7480;--accent:#2dd4bf;--accent-2:#5b9df9;--good:#36c26e;--warn:#f5a524;--danger:#f4504e;--bg-2:var(--surface);--bg-3:var(--surface-2);--bg-inset:var(--inset);--ink:var(--text);--ink-dim:var(--text-dim);--ink-faint:var(--text-faint);--cyan:var(--accent);--blue:var(--accent-2);--green:var(--good);--amber:var(--warn);--red:var(--danger);--purple:#a78bfa;--ok:var(--good);--line:var(--border);--line-strong:var(--border-strong);--font-body:"Noto Sans TC",system-ui,-apple-system,"PingFang TC",sans-serif;--font-display:"Noto Sans TC",system-ui,-apple-system,sans-serif;--font-pixel:"Noto Sans TC",system-ui,sans-serif;--radius:14px;--radius-sm:8px;--maxw:880px;--ease-emphasized:cubic-bezier(0.16,1,0.3,1);--dur-base:260ms}*,:after,:before{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.6;letter-spacing:.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}img{display:block;max-width:100%}img.pixel{image-rendering:pixelated}h1,h2,h3{font-family:var(--font-display);line-height:1.3;margin:0;font-weight:700}.num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.container{max-width:var(--maxw);margin:0 auto;padding:0 16px}.stack>*+*{margin-top:16px}.muted{color:var(--text-dim)}.faint{color:var(--text-faint)}.pixel-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 1px 2px rgba(0,0,0,.4);padding:18px 20px}.pixel-card--inset{background:var(--inset);border-color:var(--border);box-shadow:none}.pixel-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-body);font-size:12px;font-weight:500;letter-spacing:.02em;padding:3px 9px;border-radius:6px;border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text-dim);white-space:nowrap}.pixel-badge--ok{border-color:rgba(54,194,110,.45);color:var(--good);background:rgba(54,194,110,.08)}.pixel-badge--warn{border-color:rgba(245,165,36,.45);color:var(--warn);background:rgba(245,165,36,.08)}.pixel-badge--danger{border-color:rgba(244,80,78,.45);color:var(--danger);background:rgba(244,80,78,.08)}.pixel-badge--cyan{border-color:rgba(45,212,191,.45);color:var(--accent);background:rgba(45,212,191,.08)}.pixel-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;padding:11px 20px;border-radius:10px;border:none;background:var(--accent);color:#07120f;cursor:pointer;transition:opacity .15s ease,transform .1s ease;text-decoration:none}.pixel-btn:hover{opacity:.88;transform:translateY(-1px);text-decoration:none}.pixel-btn:active{transform:none;opacity:.75}.pixel-btn--ghost{background:var(--surface-2);color:var(--text);border:1px solid var(--border-strong)}.pixel-btn--ghost:hover{background:var(--surface)}.pixel-bar{height:8px;background:var(--inset);border-radius:4px;border:1px solid var(--border);position:relative;overflow:hidden}.pixel-bar>i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),#1aaa9b);border-radius:4px}.section-h{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:18px;font-weight:600;margin-bottom:10px;color:var(--text)}.section-h .ic{width:20px;height:20px}.coming-soon{font-family:var(--font-body);font-size:13px;color:var(--text-faint);border:1px dashed var(--border-strong);border-radius:var(--radius-sm);padding:10px 14px;background:var(--inset)}.row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}@media (max-width:560px){.grid-2{grid-template-columns:1fr}}.reveal{opacity:0;transform:translateY(12px);animation:revealIn var(--dur-base) var(--ease-emphasized) forwards}@keyframes revealIn{to{opacity:1;transform:none}}.lift{transition:transform .15s var(--ease-emphasized),box-shadow .15s ease}.lift:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.35)}.lock-card{position:relative;overflow:hidden;border:1px dashed var(--border-strong);border-radius:var(--radius-sm);background:var(--inset);padding:16px;text-align:center}.lock-card:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(45,212,191,.07) 50%,transparent 60%);transform:translateX(-100%);animation:shimmer 3.6s ease-in-out infinite}@keyframes shimmer{0%{transform:translateX(-100%)}60%,to{transform:translateX(100%)}}.lock-blur{filter:blur(4px);opacity:.45;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none}.tabs{display:flex;gap:6px;flex-wrap:wrap}.tab{font-family:var(--font-body);font-size:13px;font-weight:500;padding:6px 12px;cursor:pointer;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);transition:border-color .15s,color .15s,background .15s}.tab[aria-selected=true]{border-color:var(--accent);color:var(--accent);background:rgba(45,212,191,.08)}.tide-row{display:grid;grid-template-columns:56px 1fr auto;grid-gap:10px;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.tide-row:last-child{border-bottom:none}.tide-dot{width:10px;height:10px}.hscroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;scrollbar-width:thin;scrollbar-color:var(--border-strong) var(--inset)}.hour-cell{flex:0 0 auto;min-width:80px;text-align:center;padding:10px 8px;border-radius:10px;border:1px solid var(--border);background:var(--inset);line-height:1.5;transition:border-color .15s}.hour-cell--now{border-color:var(--accent);background:rgba(45,212,191,.07)}.book-inner,.book-stage{position:relative}.book-inner{z-index:1}.book-cover{position:absolute;inset:0;z-index:3;transform-origin:center top;transform:none;opacity:1;transition:opacity var(--dur-base) ease,transform var(--dur-base) var(--ease-emphasized);will-change:opacity,transform;cursor:pointer}.book-stage[data-open=true] .book-cover{opacity:0;transform:scale(.97) translateY(-6px);pointer-events:none}.book-cover-face{height:100%;min-height:320px;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:40px 20px;text-align:center}.book-cover-hint{font-family:var(--font-body);font-size:12px;color:var(--text-faint);animation:hintPulse 1.8s ease-in-out infinite}@keyframes hintPulse{0%,to{opacity:.35}50%{opacity:.9}}.pixel-title{font-family:var(--font-display);font-weight:700}.wx-detail-toggle{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text-dim);cursor:pointer;font-family:var(--font-body);font-size:13px;transition:border-color .15s,color .15s}.wx-detail-toggle:hover,.wx-detail-toggle[aria-expanded=true]{border-color:var(--accent);color:var(--accent)}.wx-pressure-hint{font-size:13px;color:var(--text-dim);background:rgba(245,165,36,.07);border:1px solid rgba(245,165,36,.25);border-radius:var(--radius-sm);padding:8px 14px;margin-bottom:10px;font-family:var(--font-body)}.wx-table-wrap{width:100%}.wx-table-scroll{overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--border-strong) var(--inset);border-radius:var(--radius-sm)}.wx-table{border-collapse:collapse;min-width:max-content;background:var(--inset);font-size:13px}.wx-th-label{min-width:76px;width:76px}.wx-th{min-width:56px;padding:7px 8px;border:1px solid var(--border);background:var(--surface);text-align:center;white-space:nowrap;font-weight:500;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.wx-th--now{background:rgba(45,212,191,.1);border-color:var(--accent)}.wx-label-col{position:-webkit-sticky;position:sticky;left:0;z-index:2;background:var(--surface);border-right:1px solid var(--border-strong);border:1px solid var(--border-strong);border-right-width:2px;padding:7px 10px;min-width:76px;width:76px;white-space:nowrap;text-align:left;box-shadow:2px 0 8px rgba(0,0,0,.4)}.wx-label-text{color:var(--text-dim);font-size:12px;line-height:1.3}.wx-label-text,.wx-label-unit{display:block;font-family:var(--font-body)}.wx-label-unit{font-size:10px;color:var(--text-faint);margin-top:1px}.wx-cell{padding:7px 10px;border:1px solid var(--border);text-align:center;background:var(--inset);vertical-align:middle;white-space:nowrap;min-width:56px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.wx-cell--now{background:rgba(45,212,191,.06);border-color:rgba(45,212,191,.3)}.wx-table tbody tr:nth-child(2n) .wx-cell{background:hsla(0,0%,100%,.02)}.wx-table tbody tr:nth-child(2n) .wx-cell.wx-cell--now{background:rgba(45,212,191,.09)}.wx-table-note{font-size:12px;margin-top:8px;line-height:1.5}@media (max-width:480px){.wx-label-col{min-width:62px;width:62px;padding:5px 6px}.wx-label-text{font-size:11px}.wx-cell{min-width:48px;padding:6px;font-size:12px}.wx-th{min-width:48px;padding:5px 6px;font-size:11px}}@media (prefers-reduced-motion:reduce){.book-cover,.book-cover-hint,.lock-card:after,.reveal{animation:none!important;transition:none!important}.book-stage[data-open=true] .book-cover{opacity:0;transform:none}.reveal{opacity:1;transform:none}}.spot-search{position:relative}.spot-search-input{width:100%;box-sizing:border-box;padding:12px 14px;font-size:16px;color:var(--text);background:var(--inset);border:1px solid var(--border-strong);border-radius:12px;outline:none;font-family:inherit}.spot-search-input:focus{border-color:var(--accent)}.spot-search-input::placeholder{color:var(--text-faint)}.spot-search-results{margin-top:8px;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.spot-search-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;text-decoration:none;color:var(--text);border-bottom:1px solid var(--border)}.spot-search-item:last-child{border-bottom:none}.spot-search-item:hover{background:var(--surface-2)}