:root{--primary: #0e5fa8;--primary-dark: #0a4880;--primary-light: #e8f1fa;--accent: #e8704c;--accent-dark: #c95a39;--accent-light: #fdebe2;--surface: #f4f7fb;--card: #ffffff;--text: #1a2532;--text-soft: #3d4a5b;--muted: #5a6573;--border: #d8dee5;--border-soft: #e7ecf1;--success-bg: #d8f0e0;--success-text: #186b32;--warn-bg: #fff4d8;--warn-text: #6a4f00;--danger-bg: #fbe2e2;--danger-text: #a32525;--bg-gradient-top: rgba(14, 95, 168, .08);--bg-base-from: #e8eef7;--field-bg: #ffffff;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 1px 2px rgba(15, 23, 42, .04), 0 4px 12px rgba(15, 23, 42, .05)}[data-theme=dark]{--primary: #4a9eea;--primary-dark: #3179c0;--primary-light: #15273d;--accent: #ff9168;--accent-dark: #d97048;--accent-light: #2c1d18;--surface: #0f1722;--card: #182434;--field-bg: #0a121c;--text: #ffffff;--text-soft: #d6dde6;--muted: #8a96a6;--border: #4a5e7a;--border-soft: #2a3a4f;--success-bg: #16382a;--success-text: #6fdd9b;--warn-bg: #3b2f15;--warn-text: #f0c97a;--danger-bg: #3c1d1d;--danger-text: #ff8a8a;--bg-gradient-top: rgba(74, 158, 234, .08);--bg-base-from: #0a1828;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 1px 2px rgba(0, 0, 0, .4), 0 4px 12px rgba(0, 0, 0, .3)}@media (prefers-color-scheme: dark){:root:not([data-theme]){--primary: #4a9eea;--primary-dark: #3179c0;--primary-light: #15273d;--accent: #ff9168;--accent-dark: #d97048;--accent-light: #2c1d18;--surface: #0f1722;--card: #182434;--field-bg: #0a121c;--text: #ffffff;--text-soft: #d6dde6;--muted: #8a96a6;--border: #4a5e7a;--border-soft: #2a3a4f;--success-bg: #16382a;--success-text: #6fdd9b;--warn-bg: #3b2f15;--warn-text: #f0c97a;--danger-bg: #3c1d1d;--danger-text: #ff8a8a;--bg-gradient-top: rgba(74, 158, 234, .08);--bg-base-from: #0a1828}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic UI,Meiryo,system-ui,sans-serif;font-size:16px;line-height:1.5;color:var(--text);background:var(--surface);background-image:radial-gradient(ellipse at top,var(--bg-gradient-top) 0%,transparent 50%),linear-gradient(180deg,var(--bg-base-from) 0%,var(--surface) 240px);background-attachment:fixed;min-height:100vh;-webkit-font-smoothing:antialiased}main{max-width:720px;margin:0 auto;padding:1.5rem 1rem 4rem}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-main{max-width:720px;width:100%;margin:0 auto;padding:1.25rem 1rem 6rem;flex:1}.view-content{display:flex;flex-direction:column}.view-title{font-size:1.3rem;font-weight:700;margin:0 0 .85rem;letter-spacing:-.01em}h1,h2,h3{letter-spacing:-.01em;margin:0}h1{font-size:1.6rem;font-weight:700}h2{font-size:1.05rem;font-weight:600}.app-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;margin:0 auto;max-width:720px;width:100%;padding:1.25rem 1rem 0}.app-title-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%}.app-title-main{font-size:1.5rem;font-weight:700}.app-title-actions{display:flex;align-items:center;gap:.4rem}.app-title-sub{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:6px;background:var(--primary-light);color:var(--primary)}.app-badges{display:flex;gap:.4rem;flex-wrap:wrap}.tabs{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;background:var(--card);padding:.4rem;border-radius:14px;border:1px solid var(--border-soft);box-shadow:var(--shadow-sm);margin-bottom:1rem}.tab{padding:.7rem 1rem;border:none;background:transparent;color:var(--muted);border-radius:10px;font-weight:600;font-size:.95rem;cursor:pointer;transition:background .15s,color .15s}.tab:hover:not(:disabled){background:var(--surface);color:var(--text)}.tab.active{background:var(--primary);color:#fff;box-shadow:0 2px 6px #0e5fa840}.tab.active.tip-run{background:var(--accent);box-shadow:0 2px 6px #e8704c4d}.tab:disabled{opacity:.4;cursor:not-allowed}.card{background:var(--card);border:1px solid var(--border-soft);border-radius:16px;padding:1.25rem;margin:.75rem 0;box-shadow:var(--shadow-md)}.form-card{padding:1.5rem;position:relative;overflow:hidden}.form-header{display:flex;align-items:center;gap:.6rem;padding-bottom:1rem;border-bottom:1px solid var(--border-soft);margin-bottom:1rem;position:relative}.form-title{font-size:1.15rem;font-weight:700;flex:1}.form-header-illust{display:none}.section{margin-top:1.5rem}.section:first-of-type{margin-top:0}.section-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.85rem}.section-num{display:inline-flex;align-items:center;justify-content:center;width:1.7rem;height:1.7rem;border-radius:50%;background:var(--primary);color:#fff;font-size:.8rem;font-weight:700;flex-shrink:0;box-shadow:0 1px 3px #0e5fa84d}.section-num.tip-run{background:var(--accent);box-shadow:0 1px 3px #e8704c4d}.section-title{font-size:1rem;font-weight:600;color:var(--text)}.section-hint{font-size:.7rem;color:var(--muted);background:var(--surface);padding:.15rem .5rem;border-radius:6px}.section-catch{background:linear-gradient(180deg,var(--surface) 0%,transparent 60%);margin:1.5rem -1.5rem -1.5rem;padding:1.25rem 1.5rem 1.5rem;border-radius:0 0 16px 16px}.row{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(150px,100%),1fr));gap:.7rem;margin:.5rem 0}.row>label{display:flex;flex-direction:column;font-size:.78rem;font-weight:600;color:var(--muted);gap:.3rem;text-transform:none;letter-spacing:.01em}input,select,textarea{font:inherit;padding:.6rem .75rem;border:1px solid var(--border);border-radius:9px;background:#fff;color:var(--text);transition:border-color .15s,box-shadow .15s}input:hover,select:hover,textarea:hover{border-color:var(--primary)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0e5fa82e}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236c7888' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7rem center;padding-right:2rem}button{font:inherit;cursor:pointer;padding:.65rem 1.1rem;border:1px solid var(--primary);border-radius:9px;background:var(--primary);color:#fff;font-weight:600;transition:background .15s,transform .05s,box-shadow .15s,border-color .15s,color .15s}button:hover{background:var(--primary-dark);border-color:var(--primary-dark)}button:active{transform:scale(.98)}button:disabled{background:#c0c8d2;border-color:#c0c8d2;color:#fff;cursor:not-allowed;transform:none}button.secondary{background:var(--card);color:var(--text-soft);border-color:var(--border)}button.secondary:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}button.tiny{padding:.2rem .55rem;font-size:.75rem;font-weight:500;border-radius:6px}.form-actions{display:flex;justify-content:flex-end;margin-top:1.5rem}.form-actions button{min-width:8rem;padding:.75rem 1.5rem;font-size:1rem}.catch-counter{display:flex;align-items:baseline;justify-content:center;gap:.35rem;padding:.75rem 0;margin:.5rem 0}.catch-num{font-size:2.6rem;font-weight:800;color:var(--primary);line-height:1}.section-num.tip-run~* .catch-num{color:var(--accent)}.catch-unit{font-size:1rem;color:var(--muted);font-weight:600}.catch-add{width:100%;padding:.75rem;font-size:1rem}.catch-add-row{grid-template-columns:1fr 1fr}.catch-input-row>label{font-size:.85rem}.catch-number-input{font-size:1.8rem!important;font-weight:700;color:var(--primary);text-align:center;padding:.5rem!important;letter-spacing:.04em}.section-num.tip-run~* .catch-number-input{color:var(--accent)}.stats-card{padding:1.25rem}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media (min-width: 540px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat{text-align:center;padding:.75rem .5rem;background:linear-gradient(180deg,var(--primary-light) 0%,var(--card) 100%);border-radius:12px;border:1px solid var(--border-soft)}.stat-num{font-size:1.9rem;font-weight:800;color:var(--primary);line-height:1}.stat-label{font-size:.75rem;font-weight:600;color:var(--muted);margin-top:.3rem}.stat-sub{font-size:.65rem;color:var(--muted);margin-top:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-toolbar{padding:.85rem 1rem}.toolbar-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:space-between}.filter-group{display:flex;gap:.3rem;flex-wrap:wrap}.chip{padding:.3rem .75rem;border:1px solid var(--border);border-radius:999px;background:var(--card);color:var(--text-soft);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.chip:hover{border-color:var(--primary);color:var(--primary)}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.chip.tip-run.active{background:var(--accent);border-color:var(--accent)}.sort-select{padding:.35rem 1.7rem .35rem .6rem;font-size:.8rem}.search-input{width:100%;margin-top:.5rem;padding:.45rem .7rem;font-size:.85rem}.toolbar-meta{margin-top:.45rem;font-size:.75rem}.catch-cards{display:flex;flex-direction:column;gap:.5rem;margin-top:.85rem}.catch-card{background:var(--card);border:1px solid var(--border-soft);border-radius:10px;padding:.6rem .75rem;display:flex;flex-direction:column;gap:.4rem}.catch-card-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.catch-card-num{display:inline-flex;align-items:center;justify-content:center;min-width:1.8rem;height:1.8rem;padding:0 .4rem;border-radius:999px;background:var(--primary-light);color:var(--primary-dark);font-weight:700;font-size:.8rem}.section-num.tip-run~* .catch-card-num{background:var(--accent-light);color:var(--accent-dark)}.catch-card-time,.catch-card-size{display:flex;flex-direction:column;font-size:.7rem;font-weight:600;color:var(--muted);gap:.2rem;flex:1;min-width:6rem}.catch-card-time input,.catch-card-size input{font-size:.9rem;padding:.3rem .5rem}.catch-card-remove{padding:.3rem .7rem}.catch-card-notes{font-size:.8rem;padding:.35rem .55rem}.photo-uploader{margin-top:.25rem}.photo-uploader-actions{display:flex;align-items:center;gap:.6rem}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:.5rem;margin-top:.7rem}.photo-thumb{position:relative;aspect-ratio:1 / 1;border-radius:12px;overflow:hidden;background:transparent;box-shadow:0 2px 8px #0000002e}[data-theme=dark] .photo-thumb{box-shadow:0 2px 10px #00000073}.photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}.photo-thumb-open{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;padding:0;border:none;background:transparent;cursor:pointer;display:block;border-radius:0}.photo-thumb-open img{width:100%;height:100%;object-fit:cover;display:block}.photo-thumb-remove{position:absolute;top:.25rem;right:.25rem;width:1.5rem;height:1.5rem;padding:0;display:inline-flex;align-items:center;justify-content:center;border:none;background:#141923b3;color:#fff;border-radius:50%;font-size:1rem;font-weight:700;line-height:1;cursor:pointer;transition:background .15s;z-index:2}.photo-thumb-remove:hover{background:#141923e6}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c12f0;z-index:1000;display:flex;align-items:center;justify-content:center;animation:lightbox-in .18s ease-out}@keyframes lightbox-in{0%{opacity:0}to{opacity:1}}.lightbox-stage{width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;padding:1rem;-webkit-user-select:none;user-select:none}.lightbox-image{max-width:95vw;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 40px #0009}.lightbox-caption{color:#fffc;font-size:.85rem;margin-top:.6rem;text-align:center;max-width:90vw}.lightbox-close{position:absolute;top:.85rem;right:.85rem;width:2.5rem;height:2.5rem;border-radius:50%;border:none;background:#ffffff26;color:#fff;font-size:1.6rem;font-weight:300;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;padding:0;z-index:2}.lightbox-close:hover{background:#ffffff4d}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:3rem;height:3rem;border-radius:50%;border:none;background:#ffffff26;color:#fff;font-size:2rem;cursor:pointer;z-index:2;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1}.lightbox-nav:hover:not(:disabled){background:#ffffff4d}.lightbox-nav:disabled{opacity:.3;cursor:default}.lightbox-nav.prev{left:.85rem}.lightbox-nav.next{right:.85rem}.trip-detail{margin-top:.75rem;display:flex;flex-direction:column;gap:1rem}.detail-section{padding:.75rem .85rem;background:var(--surface);border-radius:9px;border:1px solid var(--border-soft)}.detail-section-title{font-size:.78rem;font-weight:700;color:var(--text-soft);margin:0 0 .5rem;letter-spacing:.02em}.detail-catches{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem}.detail-catch{display:flex;align-items:center;gap:.5rem;padding:.4rem .55rem;background:var(--card);border-radius:7px;font-size:.85rem;flex-wrap:wrap}.detail-catch-num{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .35rem;border-radius:999px;background:var(--primary-light);color:var(--primary-dark);font-weight:700;font-size:.7rem}.detail-catch-time{font-variant-numeric:tabular-nums;color:var(--muted);font-weight:600}.detail-catch-notes{color:var(--text);flex:1;min-width:8rem}.detail-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.4rem}.detail-photo-thumb{position:relative;aspect-ratio:1 / 1;border-radius:10px;overflow:hidden;background:transparent;padding:0;cursor:pointer;transition:transform .1s,box-shadow .15s;box-shadow:0 2px 6px #0000002e}[data-theme=dark] .detail-photo-thumb{box-shadow:0 2px 8px #0006}.detail-photo-thumb:hover{transform:scale(1.04);box-shadow:0 2px 8px #0000001f}.detail-photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}.detail-template{margin:0;display:grid;grid-template-columns:1fr;gap:0}.detail-row{display:grid;grid-template-columns:8rem 1fr;gap:.5rem;padding:.3rem 0;border-bottom:1px dashed var(--border-soft);font-size:.85rem}.detail-row:last-child{border-bottom:none}.detail-row dt{margin:0;color:var(--muted);font-weight:500}.detail-row dd{margin:0;color:var(--text);font-weight:600}.detail-notes{white-space:pre-wrap;font-size:.85rem;color:var(--text);background:var(--card);padding:.5rem .7rem;border-radius:7px}.lightbox-counter{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);color:#ffffffd9;background:#0006;padding:.3rem .8rem;border-radius:999px;font-size:.8rem;font-weight:600;z-index:2}@media (max-width: 480px){.lightbox-nav{width:2.4rem;height:2.4rem;font-size:1.5rem}.lightbox-nav.prev{left:.4rem}.lightbox-nav.next{right:.4rem}.lightbox-close{width:2.2rem;height:2.2rem;top:.5rem;right:.5rem}}.trip-photo-thumb{position:relative;width:44px;height:44px;border-radius:10px;overflow:hidden;flex-shrink:0;background:transparent;padding:0;cursor:pointer;transition:transform .1s,box-shadow .15s;box-shadow:0 1px 4px #00000026}[data-theme=dark] .trip-photo-thumb{box-shadow:0 1px 6px #0006}.trip-photo-thumb:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.trip-photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}.trip-photo-count{position:absolute;bottom:0;right:0;background:#141923bf;color:#fff;font-size:.65rem;font-weight:700;padding:.05rem .3rem;border-radius:4px 0 0}.catch-list{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.4rem}.catch-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;background:#fff;border:1px solid var(--border-soft);border-radius:8px;font-size:.85rem}.catch-size{background:var(--accent-light);color:var(--accent-dark);font-weight:600;padding:.05rem .4rem;border-radius:4px;font-size:.75rem}.tag{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;background:var(--primary-light);color:var(--primary-dark);font-size:.72rem;font-weight:600;margin-right:.3rem;white-space:nowrap}.tag.tip-run{background:var(--accent-light);color:var(--accent-dark)}.tag.success{background:var(--success-bg);color:var(--success-text)}.tag.warn{background:var(--warn-bg);color:var(--warn-text)}.tag.danger{background:var(--danger-bg);color:var(--danger-text)}.autofill-banner{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem;background:var(--success-bg);color:var(--success-text);padding:.5rem .7rem;border-radius:9px;font-size:.8rem;margin-top:.5rem}.autofill-status{font-weight:600}.autofill-error{color:var(--danger-text)}.edit-banner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem .9rem;background:var(--primary-light);border:1px solid rgba(14,95,168,.2);border-radius:10px;font-size:.85rem;color:var(--primary-dark);margin-bottom:.75rem}.error{background:var(--danger-bg);color:var(--danger-text);padding:.6rem .85rem;border-radius:9px;font-size:.85rem;margin:.75rem 0 0;font-weight:500}.trip-card{position:relative;padding-left:1.5rem}.trip-card:before{content:"";position:absolute;left:0;top:1.25rem;bottom:1.25rem;width:4px;background:var(--primary);border-radius:4px}.trip-card.tip-run:before{background:var(--accent)}.trip-card.editing{box-shadow:0 0 0 3px #0e5fa840,var(--shadow-md)}.trip-card{overflow:hidden}.trip-card-watermark{position:absolute;right:-20px;bottom:-20px;width:110px;height:110px;object-fit:contain;opacity:.1;pointer-events:none;transform:rotate(-12deg);-webkit-user-select:none;user-select:none}.trip-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}.trip-summary{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.trip-actions{display:flex;gap:.3rem}.trip-meta{color:var(--muted);font-size:.85rem;margin-top:.4rem}.trip-meta strong{color:var(--text)}.trip-tags{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.25rem}.empty{text-align:center;padding:3rem 1rem;color:var(--muted);background:var(--card);border:1px dashed var(--border);border-radius:14px;font-size:.95rem}.empty-with-art{padding:2rem 1rem 2.5rem}.empty-art{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:1rem;opacity:.8}.empty-art img{width:90px;height:90px;object-fit:contain}.empty-art img:first-child{transform:rotate(-10deg)}.empty-art img:last-child{transform:rotate(10deg)}.muted{color:var(--muted);font-size:.85rem}pre{background:var(--surface);border:1px solid var(--border-soft);padding:.85rem;border-radius:8px;overflow-x:auto;font-size:.78rem;line-height:1.55}details summary{cursor:pointer;font-size:.8rem;color:var(--muted);-webkit-user-select:none;user-select:none}details summary:hover{color:var(--text)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--card);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-top:1px solid var(--border-soft);display:grid;grid-template-columns:repeat(4,1fr);z-index:90;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -2px 12px #0f172a0f}.nav-btn{background:transparent;border:none;padding:.55rem .4rem .4rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;color:var(--muted);cursor:pointer;transition:color .12s;border-radius:0}.nav-btn:hover{background:transparent;color:var(--text)}.nav-btn.active{color:var(--primary)}.nav-icon{display:inline-flex;align-items:center;justify-content:center}.nav-label{font-size:.7rem;font-weight:600;letter-spacing:.02em}.fab{position:fixed;right:1.1rem;bottom:calc(4.6rem + env(safe-area-inset-bottom,0));z-index:80;border:none;background:var(--primary);color:#fff;font-weight:700;font-size:.95rem;height:3rem;padding:0 1.25rem;border-radius:999px;box-shadow:0 6px 20px #0e5fa866,0 2px 6px #0000001a;cursor:pointer;transition:transform .1s,box-shadow .15s}.fab:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 8px 24px #0e5fa880}.fab:active{transform:scale(.97)}.toast-stack{position:fixed;top:1rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:.4rem;z-index:1100;pointer-events:none}.toast{background:#141e2df0;color:#fff;padding:.65rem 1.1rem;border-radius:999px;font-size:.85rem;font-weight:600;box-shadow:0 6px 20px #00000040;animation:toast-in .18s ease-out;pointer-events:auto}.toast-success{background:linear-gradient(180deg,#1f8c4a,#186b32)}.toast-error{background:linear-gradient(180deg,#c93333,#9b1f1f)}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.analytics-card{padding:1.1rem 1.1rem 1.25rem}.analytics-title{font-size:.95rem;font-weight:700;margin:0 0 .85rem}.bar-list{display:flex;flex-direction:column;gap:.5rem}.bar-row{display:grid;grid-template-columns:5.5rem 1fr 3rem;gap:.5rem;align-items:center}.bar-label{font-size:.78rem;font-weight:600;color:var(--text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{position:relative;height:1.7rem;background:var(--surface);border-radius:6px;overflow:hidden}.bar-fill{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,var(--primary) 0%,#3a8fd6 100%);border-radius:6px;transition:width .4s cubic-bezier(.2,.7,.3,1)}.bar-num{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;color:var(--text);font-weight:700;font-size:.78rem;text-shadow:0 0 4px rgba(255,255,255,.7)}.bar-meta{font-size:.72rem;color:var(--muted);text-align:right}.bar-empty{text-align:center;padding:1.5rem;color:var(--muted);font-size:.85rem}.color-rank{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.color-rank li{display:flex;align-items:center;gap:.6rem;padding:.5rem .7rem;background:var(--surface);border-radius:8px;font-size:.85rem}.color-rank-num{display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;border-radius:50%;background:var(--primary);color:#fff;font-weight:700;font-size:.78rem;flex-shrink:0}.color-rank li:nth-child(2) .color-rank-num{background:silver}.color-rank li:nth-child(3) .color-rank-num{background:#cd7f32}.color-rank-name{font-weight:600;flex:1}.color-rank-stat{color:var(--muted);font-size:.78rem}.map-wrap{padding:0;overflow:hidden}.map-canvas{height:60vh;min-height:400px;width:100%;border-radius:16px}.marker-pin{width:100%;height:100%;border-radius:50%;border:2px solid white;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.8rem;box-shadow:0 2px 6px #0000004d}.marker-pin.marker-empty{background:#6c788880;border-color:#ffffffb3}.map-popup strong{font-size:1rem}.map-popup-trips{list-style:none;padding:0;margin:.5rem 0 0;font-size:.8rem;display:flex;flex-direction:column;gap:.2rem}.map-popup-trips li{padding:.2rem 0;border-bottom:1px dashed var(--border-soft)}.map-popup-trips li:last-child{border-bottom:none}.today-conditions{padding:1rem 1.1rem .85rem}.today-header{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.7rem}.today-title{font-size:.95rem;font-weight:700}.today-port{padding:.3rem 1.5rem .3rem .55rem;font-size:.8rem;font-weight:600}.today-rank{padding:.2rem .65rem;border-radius:999px;font-size:.72rem;font-weight:700;margin-left:auto}.today-rank.rank-good{background:var(--success-bg);color:var(--success-text)}.today-rank.rank-caution{background:var(--warn-bg);color:var(--warn-text)}.today-rank.rank-avoid{background:var(--danger-bg);color:var(--danger-text)}.today-loading,.today-error{padding:.6rem 0;font-size:.85rem}.today-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:.4rem}@media (max-width: 480px){.today-strip{grid-template-columns:repeat(3,1fr)}}.today-slot{padding:.5rem .3rem;text-align:center;border-radius:9px;background:var(--surface);border:1px solid var(--border-soft);border-top:3px solid var(--muted);display:flex;flex-direction:column;gap:.2rem}.today-slot.rank-good{border-top-color:#2d8a4a}.today-slot.rank-caution{border-top-color:#d4a300}.today-slot.rank-avoid{border-top-color:#c93333}.today-slot-hour{font-size:.72rem;color:var(--muted);font-weight:600}.today-slot-weather{font-size:1.4rem;line-height:1}.today-slot-wind,.today-slot-wave{font-size:.7rem;color:var(--text-soft);font-weight:600}.today-slot .unit{color:var(--muted);font-weight:400;margin-left:1px}.today-footer{font-size:.7rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-soft)}.trip-card-hero{padding:0}.trip-card-hero .trip-card-body{padding:1rem 1.25rem 1.1rem}.trip-card-hero:before{display:none}.trip-hero{display:block;width:100%;height:200px;border-radius:16px 16px 0 0;overflow:hidden;position:relative;border:none;padding:0;background:transparent;cursor:pointer}.trip-hero img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.trip-hero:hover img{transform:scale(1.03)}.trip-hero-count{position:absolute;bottom:.6rem;right:.6rem;background:#0009;color:#fff;font-size:.72rem;font-weight:600;padding:.2rem .55rem;border-radius:999px}.catch-row{display:grid;grid-template-columns:auto auto auto 1fr auto;align-items:center;gap:.6rem;padding:.55rem .75rem;background:var(--card);border:1px solid var(--border-soft);border-radius:10px;font-size:.85rem;cursor:pointer;text-align:left;transition:border-color .12s,transform .05s;width:100%;font-family:inherit;color:inherit}.catch-row:hover{border-color:var(--primary)}.catch-row:active{transform:scale(.99)}.catch-row-num{display:inline-flex;align-items:center;justify-content:center;min-width:1.7rem;height:1.7rem;padding:0 .4rem;border-radius:999px;background:var(--primary-light);color:var(--primary-dark);font-weight:700;font-size:.78rem}.section-num.tip-run~* .catch-row-num{background:var(--accent-light);color:var(--accent-dark)}.catch-row-time{font-variant-numeric:tabular-nums;font-weight:600;color:var(--text)}.catch-row-size{background:var(--accent-light);color:var(--accent-dark);padding:.1rem .45rem;border-radius:4px;font-weight:600;font-size:.8rem}.catch-row-notes{color:var(--text-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.8rem}.catch-row-remove{width:1.5rem;height:1.5rem;border-radius:50%;background:var(--surface);color:var(--muted);font-size:1rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1;cursor:pointer}.catch-row-remove:hover{background:var(--danger-bg);color:var(--danger-text)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c128c;z-index:1050;display:flex;align-items:flex-end;justify-content:center;animation:sheet-fade .2s ease-out}.sheet{background:var(--card);width:100%;max-width:520px;border-radius:18px 18px 0 0;padding:.5rem 1.2rem 1.4rem;box-shadow:0 -8px 30px #00000040;animation:sheet-up .22s cubic-bezier(.2,.8,.3,1);padding-bottom:max(1.4rem,env(safe-area-inset-bottom))}@keyframes sheet-fade{0%{opacity:0}to{opacity:1}}@keyframes sheet-up{0%{transform:translateY(20%)}to{transform:translateY(0)}}.sheet-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:.4rem auto .6rem}.sheet-title{font-size:1rem;font-weight:700;margin:0 0 .6rem}.sheet-body{display:flex;flex-direction:column;gap:.7rem}.sheet-field{display:flex;flex-direction:column;gap:.3rem}.sheet-label{font-size:.78rem;font-weight:600;color:var(--muted)}.sheet-field input{padding:.7rem .85rem;font-size:1rem;border-radius:10px}.sheet-actions{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-top:1rem}.sheet-actions button{padding:.75rem;font-size:.95rem}.theme-toggle{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .6rem;background:var(--card);color:var(--text-soft);border:1px solid var(--border);border-radius:999px;font-size:.7rem;font-weight:600;cursor:pointer;transition:color .15s,border-color .15s}.theme-toggle:hover{border-color:var(--primary);color:var(--primary)}.theme-toggle-icon{display:inline-flex;align-items:center}.list-view-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.layout-toggle{display:inline-flex;background:var(--card);border:1px solid var(--border-soft);border-radius:999px;padding:.18rem;gap:.18rem}.layout-btn{background:transparent;border:none;padding:.3rem .85rem;font-size:.78rem;font-weight:600;border-radius:999px;color:var(--muted);cursor:pointer}.layout-btn:hover{background:transparent;color:var(--text)}.layout-btn.active{background:var(--primary);color:#fff}.calendar-wrap{display:flex;flex-direction:column;gap:.75rem}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem .85rem}.cal-title{font-size:1.1rem;font-weight:700;flex:1;text-align:center}.cal-nav{width:2.2rem;height:2.2rem;padding:0;border-radius:50%;background:var(--surface);color:var(--text);border:1px solid var(--border);font-size:1.4rem;line-height:1;cursor:pointer}.cal-nav:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.cal-summary{font-size:.85rem;padding:0 .4rem;margin:-.25rem 0 0}.calendar-grid{padding:.5rem}.cal-weekrow,.cal-row{display:grid;grid-template-columns:repeat(7,1fr);gap:.2rem}.cal-weekrow{margin-bottom:.25rem}.cal-weekday{text-align:center;font-size:.7rem;font-weight:700;color:var(--muted);padding:.25rem 0}.cal-weekday.sun{color:#c93333}.cal-weekday.sat{color:#2966b8}[data-theme=dark] .cal-weekday.sun{color:#ff8a8a}[data-theme=dark] .cal-weekday.sat{color:#6fb6ff}.cal-cell{position:relative;min-height:4.6rem;background:transparent;border:1px solid transparent;border-radius:8px;padding:.3rem .2rem .25rem;cursor:pointer;display:flex;flex-direction:column;align-items:stretch;font-family:inherit;color:inherit;text-align:center;transition:background .12s,border-color .12s;overflow:hidden}.cal-cell:hover:not(:disabled){background:var(--surface);border-color:var(--border-soft)}.cal-cell.empty{cursor:default;pointer-events:none}.cal-cell:disabled{opacity:.55;cursor:default}.cal-cell.has-trips:not(:disabled){background:var(--primary-light);border-color:#0e5fa833}.cal-cell.today{box-shadow:inset 0 0 0 2px var(--primary)}.cal-cell.selected{background:var(--primary);color:#fff}.cal-cell.selected .cal-day{color:#fff}.cal-day{font-size:.85rem;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.cal-cell.sun .cal-day{color:#c93333}.cal-cell.sat .cal-day{color:#2966b8}[data-theme=dark] .cal-cell.sun .cal-day{color:#ff8a8a}[data-theme=dark] .cal-cell.sat .cal-day{color:#6fb6ff}.cal-cell.selected.sun .cal-day,.cal-cell.selected.sat .cal-day{color:#fff}.cal-cell-trips{display:flex;flex-direction:column;gap:2px;margin-top:.2rem;width:100%;min-width:0}.cal-cell-trip{display:flex;align-items:center;gap:2px;font-size:.55rem;line-height:1.15;min-width:0;text-align:left}.cal-cell-trip-label{flex:1;min-width:0;padding:1px 3px;border-radius:3px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-cell-trip-count{flex-shrink:0;font-size:.62rem;font-weight:700;color:var(--primary-dark);font-variant-numeric:tabular-nums;padding-right:2px}.cal-cell-more{font-size:.55rem;font-weight:700;color:var(--muted);text-align:left}.cal-cell.selected .cal-cell-trip-count,.cal-cell.selected .cal-cell-more{color:#ffffffd9}.cal-cell.selected .cal-cell-trip-label{background:#ffffff2e!important;color:#fff!important;border-left-color:#fff9!important}.cal-day-detail{padding:.85rem 1rem}.cal-day-detail-title{font-size:.95rem;font-weight:700;margin:0 0 .6rem}.cal-day-trip-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.cal-day-trip-list li{display:flex;align-items:center;gap:.6rem;padding:.5rem;background:var(--surface);border-radius:9px}.cal-day-trip-meta{flex:1;min-width:0}.cal-day-trip-meta>div:first-child{font-size:.85rem}.photo-start-callout{display:flex;flex-direction:column;gap:.7rem;padding:.85rem 1rem;margin-bottom:1rem;background:linear-gradient(135deg,var(--primary-light) 0%,var(--card) 100%);border:1px solid rgba(14,95,168,.18);border-radius:14px}.photo-start-header{display:flex;align-items:center;gap:.7rem}.photo-start-text{flex:1;min-width:0}.photo-start-buttons{display:flex;gap:.5rem}.photo-start-buttons .photo-start-button{flex:1;min-width:0}.photo-start-icon{width:2.6rem;height:2.6rem;border-radius:50%;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.photo-start-text{display:flex;flex-direction:column;min-width:0}.photo-start-title{font-size:.95rem;font-weight:700;color:var(--text)}.photo-start-sub{font-size:.72rem;color:var(--muted);margin-top:.1rem}.photo-start-button{padding:.55rem .9rem;font-size:.85rem;border-radius:999px;white-space:nowrap}.photo-start-buttons{display:flex;gap:.4rem;flex-shrink:0}.photo-start-info{font-size:.78rem;margin-top:.4rem;padding:.4rem .6rem;border-radius:7px}.photo-start-info.ok{background:var(--success-bg);color:var(--success-text)}.photo-start-info.err{background:var(--danger-bg);color:var(--danger-text)}.photo-start-info.note{background:var(--surface);color:var(--muted)}:root{color-scheme:light}[data-theme=dark]{color-scheme:dark}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){color-scheme:dark}}input[type=text],input[type=number],input[type=time],input[type=date],input[type=search],input[type=email],select,textarea,.target-picker-select{color:var(--text)!important;background-color:var(--field-bg)!important;border:1px solid var(--border)!important;font-weight:600!important}select,.target-picker-select{font-weight:700!important;font-size:.95rem}select option,.target-picker-select option{color:var(--text)!important;background-color:var(--field-bg)!important;font-weight:600}.category-fields{margin-top:.7rem;padding:.75rem .9rem;background:var(--surface);border-radius:10px;border:1px dashed var(--border-soft)}.category-fields-label{font-size:.72rem;font-weight:700;margin-bottom:.5rem;letter-spacing:.02em;color:var(--text-soft)}.category-fields-list{display:flex;flex-direction:column;gap:.7rem}.category-fields-list>label{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;font-weight:600;color:var(--muted)}.chip-picker-label{display:flex;flex-direction:column;gap:.45rem;font-size:.78rem;font-weight:600;color:var(--muted)}.chip-picker{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.chip-picker-item{display:inline-flex;align-items:stretch;border:1px solid var(--border);border-radius:999px;background:var(--field-bg);overflow:hidden;transition:border-color .15s,background .15s}.chip-picker-item.selected{background:var(--primary);border-color:var(--primary)}.chip-picker-btn{background:transparent;border:none;color:var(--text);font-size:.85rem;font-weight:500;padding:.45rem .9rem;cursor:pointer;min-height:36px;line-height:1.2;white-space:nowrap}.chip-picker-item.selected .chip-picker-btn{color:#fff;font-weight:600}.chip-picker-del{border:none;background:transparent;color:var(--muted);font-size:.95rem;line-height:1;padding:0 .55rem;cursor:pointer;border-left:1px solid var(--border)}.chip-picker-item.selected .chip-picker-del{color:#ffffffd9;border-left-color:#ffffff59}.chip-picker-del:hover{color:var(--danger-text, #e44)}.chip-picker-add{border:1px dashed var(--border);background:transparent;color:var(--muted);border-radius:999px;padding:.45rem .9rem;font-size:.85rem;font-weight:600;cursor:pointer;min-height:36px;line-height:1.2}.chip-picker-add:hover{border-color:var(--primary);color:var(--primary)}.chip-picker-input-wrap{display:inline-flex;align-items:center;gap:.25rem;border:1px solid var(--primary);border-radius:999px;background:var(--field-bg);padding:0 .25rem 0 .7rem;min-height:36px}.chip-picker-input{border:none!important;background:transparent!important;outline:none;padding:0!important;width:7rem;font-size:.85rem;color:var(--text)!important;height:32px;min-width:0}.chip-picker-commit,.chip-picker-cancel{border:none;background:transparent;cursor:pointer;padding:0 .45rem;font-size:.8rem;height:28px;border-radius:999px}.chip-picker-commit{color:var(--primary);font-weight:700}.chip-picker-commit:disabled{color:var(--muted);cursor:not-allowed;opacity:.5}.chip-picker-cancel{color:var(--muted);font-size:1rem}.tackle-notes-block{margin-top:1rem;padding-top:.85rem;border-top:1px dashed var(--border-soft)}.tackle-notes-label{display:flex;flex-direction:column;gap:.4rem;font-size:.78rem;font-weight:600;color:var(--muted)}.tackle-notes-textarea{width:100%;min-height:6.5rem;padding:.75rem .9rem;border:1px solid var(--border);border-radius:10px;background:var(--field-bg);color:var(--text);font-family:inherit;font-size:.92rem;line-height:1.6;resize:vertical}.tackle-notes-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0e5fa82e}.timing-chart{display:flex;flex-direction:column;gap:.4rem}.timing-chart svg{width:100%;height:auto;background:var(--card);border-radius:8px;border:1px solid var(--border-soft);display:block}.timing-grid{stroke:var(--border-soft);stroke-dasharray:3 3}.timing-axis-label{fill:var(--muted);font-size:11px;font-family:inherit}.timing-line{stroke:var(--primary);stroke-width:2;stroke-linejoin:round;stroke-linecap:round}.section-num.tip-run~* .timing-line{stroke:var(--accent)}.timing-dot{fill:var(--primary);stroke:var(--card);stroke-width:1.5}.section-num.tip-run~* .timing-dot{fill:var(--accent)}.timing-chart-meta{font-size:.78rem}.timing-chart-empty{font-size:.85rem;padding:.85rem;text-align:center;background:var(--card);border-radius:8px;border:1px dashed var(--border-soft)}.catch-detail-toggle{margin-top:.85rem;padding-top:.6rem;border-top:1px dashed var(--border-soft)}.catch-detail-toggle>summary{font-size:.78rem;font-weight:600;color:var(--muted);cursor:pointer;list-style:none;padding:.3rem 0}.catch-detail-toggle>summary::-webkit-details-marker{display:none}.catch-detail-toggle>summary:before{content:"▸";display:inline-block;margin-right:.4rem;transition:transform .15s}.catch-detail-toggle[open]>summary:before{transform:rotate(90deg)}.catch-detail-toggle>summary:hover{color:var(--text)}.catch-detail-toggle:not([open])>*:not(summary){display:none!important}.tackle-details{margin-top:.85rem;padding-top:.6rem;border-top:1px dashed var(--border-soft)}.tackle-details summary{font-size:.78rem;font-weight:600;color:var(--muted);cursor:pointer;list-style:none;padding:.3rem 0}.tackle-details summary::-webkit-details-marker{display:none}.tackle-details summary:before{content:"▸";display:inline-block;margin-right:.4rem;transition:transform .15s}.tackle-details[open] summary:before{transform:rotate(90deg)}.tackle-details summary:hover{color:var(--text)}.share-modal{max-height:90vh;overflow-y:auto}.share-preview-wrap{display:flex;align-items:center;justify-content:center;padding:.5rem;background:var(--surface);border-radius:12px;margin:0 0 .8rem;min-height:220px}.share-preview{max-width:100%;max-height:50vh;width:auto;height:auto;border-radius:10px;box-shadow:0 4px 16px #0003}.share-preview-loading{color:var(--muted);font-size:.9rem}.share-privacy-group{display:flex;flex-direction:column;gap:.4rem}.share-privacy-row{display:flex;align-items:center;gap:.7rem;padding:.7rem .85rem;background:var(--surface);border:1px solid var(--border-soft);border-radius:10px;cursor:pointer;font-size:.9rem;transition:border-color .12s,background .12s}.share-privacy-row:hover{border-color:var(--primary)}.share-privacy-row.selected{background:var(--primary-light);border-color:var(--primary)}.share-privacy-row input{width:auto;padding:0;margin:0}.boat-info-details{margin-top:.85rem;padding-top:.6rem;border-top:1px dashed var(--border-soft)}.boat-info-details summary{font-size:.78rem;font-weight:600;color:var(--muted);cursor:pointer;list-style:none;padding:.3rem 0}.boat-info-details summary::-webkit-details-marker{display:none}.boat-info-details summary:before{content:"▸";display:inline-block;margin-right:.4rem;transition:transform .15s}.boat-info-details[open] summary:before{transform:rotate(90deg)}.boat-info-details summary:hover{color:var(--text)}.onboarding{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:linear-gradient(160deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;display:flex;flex-direction:column;padding:2rem 1.5rem 1.5rem;animation:onboarding-in .25s ease-out}@keyframes onboarding-in{0%{opacity:0}to{opacity:1}}.onboarding-skip{position:absolute;top:1.2rem;right:1.2rem;background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.25);padding:.4rem 1rem;font-size:.8rem;border-radius:999px;cursor:pointer}.onboarding-skip:hover{background:#ffffff38}.onboarding-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem 1rem}.onboarding-emoji{font-size:5rem;margin-bottom:1.5rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}.onboarding-title{font-size:1.7rem;font-weight:800;margin:0 0 1rem;color:#fff}.onboarding-body{font-size:1rem;line-height:1.7;color:#ffffffe0;white-space:pre-line;max-width:480px}.onboarding-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-bottom:max(.5rem,env(safe-area-inset-bottom))}.onboarding-dots{display:flex;gap:.5rem}.onboarding-dot{width:1.5rem;height:1.5rem;background:transparent;border:none;padding:0;cursor:pointer;position:relative;display:inline-flex;align-items:center;justify-content:center}.onboarding-dot:after{content:"";width:.65rem;height:.65rem;border-radius:50%;background:#ffffff4d;transition:background .15s,width .15s,border-radius .15s}.onboarding-dot.active:after{background:#fff;width:1.6rem;border-radius:4px}.onboarding-next{background:#fff;color:var(--primary);border:none;padding:.85rem 1.6rem;border-radius:999px;font-size:.95rem;font-weight:700;cursor:pointer;box-shadow:0 4px 16px #00000026;transition:transform .1s}.onboarding-next:hover{transform:translateY(-1px);background:#fff;color:var(--primary)}.onboarding-next:active{transform:scale(.98)}.pro-upsell{display:grid;grid-template-columns:auto 1fr auto;gap:.85rem;align-items:center;padding:1rem 1.1rem;background:linear-gradient(135deg,#fff8e7,#fff4d8);border:1px solid #f0d97a;text-align:left;cursor:pointer;transition:transform .1s,box-shadow .15s;font-family:inherit;color:inherit;margin-top:1rem}[data-theme=dark] .pro-upsell{background:linear-gradient(135deg,#3b2f15,#4a3a18);border-color:#6a5118}.pro-upsell:hover{transform:translateY(-1px);box-shadow:0 6px 20px #d6a9002e}.pro-upsell-badge{display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border-radius:8px;background:linear-gradient(135deg,#c9a32a,#f0c54a);color:#fff;font-weight:800;font-size:.7rem;letter-spacing:.05em;box-shadow:0 2px 6px #c9a32a66}.pro-upsell-title{font-size:.95rem;font-weight:700;color:var(--text)}.pro-upsell-sub{font-size:.75rem;color:var(--muted);margin-top:.15rem}.pro-upsell-cta{font-size:.85rem;font-weight:700;color:#8a6a18;white-space:nowrap}[data-theme=dark] .pro-upsell-cta{color:#f0c97a}.pro-modal{max-height:92vh;overflow-y:auto}.pro-hero{text-align:center;padding:.6rem 0 1rem;border-bottom:1px solid var(--border-soft);margin-bottom:1rem;position:relative}.pro-badge{display:inline-block;padding:.2rem .7rem;background:linear-gradient(135deg,#c9a32a,#f0c54a);color:#fff;font-weight:800;font-size:.75rem;letter-spacing:.08em;border-radius:6px;margin-bottom:.5rem}.pro-title{font-size:1.4rem;font-weight:800;margin:0 0 .4rem}.pro-price{display:flex;align-items:baseline;justify-content:center;gap:.2rem;margin:.5rem 0}.pro-price-num{font-size:2.4rem;font-weight:800;color:var(--primary)}.pro-price-unit{font-size:.95rem;color:var(--muted);font-weight:600}.pro-tagline{font-size:.85rem;color:var(--text-soft)}.pro-feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.pro-feature{display:flex;gap:.85rem;align-items:flex-start;padding:.7rem .85rem;background:var(--surface);border-radius:10px}.pro-feature-icon{font-size:1.6rem;line-height:1;flex-shrink:0}.pro-feature-title{font-size:.9rem;font-weight:700;color:var(--text)}.pro-feature-sub{font-size:.78rem;color:var(--muted);margin-top:.2rem;line-height:1.5}.pro-footnote{font-size:.72rem;color:var(--muted);text-align:center;margin-top:.85rem;padding:.6rem;background:var(--surface);border-radius:8px}.recommend-card{padding:1rem 1.1rem .85rem}.recommend-header{display:flex;align-items:baseline;gap:.6rem;margin-bottom:.7rem}.recommend-title{font-size:.95rem;font-weight:700}.recommend-port{font-size:.7rem}.recommend-list{display:flex;flex-direction:column;gap:.45rem}.recommend-row{display:grid;grid-template-columns:1.7rem auto auto 1fr;gap:.55rem;align-items:center;padding:.55rem .7rem;border-radius:10px;background:var(--surface);border-left:4px solid var(--muted)}.recommend-row.rank-good{border-left-color:#2d8a4a;background:linear-gradient(90deg,var(--success-bg) 0%,var(--surface) 80%)}.recommend-row.rank-caution{border-left-color:#d4a300;background:linear-gradient(90deg,var(--warn-bg) 0%,var(--surface) 80%)}.recommend-row.rank-avoid{border-left-color:#c93333;background:linear-gradient(90deg,var(--danger-bg) 0%,var(--surface) 80%)}.recommend-rank-num{display:inline-flex;align-items:center;justify-content:center;width:1.7rem;height:1.7rem;border-radius:50%;background:var(--card);color:var(--text);font-weight:700;font-size:.8rem;border:1px solid var(--border)}.recommend-date{display:flex;flex-direction:column}.recommend-date-main{font-size:.95rem;font-weight:700;font-variant-numeric:tabular-nums}.recommend-weekday{font-size:.78rem;color:var(--muted);margin-left:.2rem;font-weight:600}.recommend-date-sub{font-size:.7rem}.recommend-rank-badge{font-size:1.4rem;font-weight:800;line-height:1}.rank-good .recommend-rank-badge{color:var(--success-text)}.rank-caution .recommend-rank-badge{color:var(--warn-text)}.rank-avoid .recommend-rank-badge{color:var(--danger-text)}.recommend-reasons{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:flex-end}.recommend-reason{font-size:.68rem;font-weight:600;padding:.1rem .4rem;border-radius:4px;background:var(--card);color:var(--text-soft);border:1px solid var(--border-soft);white-space:nowrap}.recommend-footer{font-size:.7rem;margin-top:.6rem;padding-top:.5rem;border-top:1px solid var(--border-soft)}.recommend-loading,.recommend-error{font-size:.85rem;padding:.85rem 1rem}.view-loading{text-align:center;padding:3rem 1rem;font-size:.9rem}.trip-map-section{margin-top:1rem}.trip-map-toggle{width:100%;display:flex;align-items:center;gap:.5rem;padding:.65rem .9rem;background:var(--surface);border:1px dashed var(--border);color:var(--text);border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;text-align:left}.trip-map-toggle:hover{border-color:var(--primary);color:var(--primary)}.trip-map-toggle-arrow{display:inline-block;font-size:.7rem;color:var(--muted);transition:transform .15s}.trip-history-map{margin-top:.7rem}.forecast-map-card{padding:0;overflow:hidden}.forecast-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:.7rem .9rem;border-bottom:1px solid var(--border-soft)}.forecast-title{font-size:.95rem;font-weight:700}.forecast-layer-tabs{display:flex;gap:.3rem}.forecast-layer-btn{padding:.35rem .85rem;border:1px solid var(--border);background:transparent;color:var(--text);border-radius:999px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s}.forecast-layer-btn:hover{border-color:var(--primary);color:var(--primary)}.forecast-layer-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.forecast-map-wrap{position:relative;width:100%;aspect-ratio:16 / 11;max-height:70vh;background:#0a121c;overflow:hidden}.forecast-map-canvas{width:100%;height:100%}.forecast-map-canvas .leaflet-container{background:#0a121c}.particle-canvas{pointer-events:none;position:absolute;z-index:250}.leaflet-popup.forecast-popup .leaflet-popup-content-wrapper{background:#141c28f5;color:#fff;border-radius:10px;box-shadow:0 4px 14px #0006}.leaflet-popup.forecast-popup .leaflet-popup-tip{background:#141c28f5}.forecast-tooltip{font-size:.85rem;line-height:1.5;font-variant-numeric:tabular-nums;min-width:140px}.forecast-tooltip-coords{font-size:.7rem;margin-bottom:.3rem;color:#ffffffa6!important}.forecast-tooltip strong{display:inline-block;width:2.2em;color:#ffffffd9;font-weight:600}.forecast-legend{position:absolute;right:.6rem;bottom:.6rem;background:#141c28d9;color:#fff;padding:.4rem .55rem;border-radius:6px;display:flex;flex-direction:column;gap:.2rem;font-size:.65rem;z-index:500;box-shadow:0 2px 8px #00000040}.forecast-legend-canvas{display:block;border-radius:2px;width:100%;height:10px}.forecast-legend-ticks{display:flex;justify-content:space-between;align-items:baseline;gap:.4rem;font-variant-numeric:tabular-nums}.forecast-legend-unit{color:#ffffffb3!important;font-size:.6rem}.forecast-time-row{display:flex;align-items:center;gap:.6rem;padding:.6rem .8rem 0}.forecast-play-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--primary);color:#fff;font-size:1rem;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0}.forecast-play-btn:disabled{opacity:.4;cursor:default}.forecast-time-slider{flex:1;min-width:0;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(90deg,#3a8bc7,#3cc4a4,#a3c437,#e8b934,#d92e2e);border-radius:3px;outline:none;cursor:pointer}.forecast-time-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--primary);cursor:pointer;box-shadow:0 1px 4px #0000004d}.forecast-time-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--primary);cursor:pointer;box-shadow:0 1px 4px #0000004d}.forecast-time-display{display:flex;justify-content:space-between;align-items:baseline;padding:.45rem .85rem .6rem;font-size:.85rem;font-variant-numeric:tabular-nums}.forecast-time-step{font-size:.72rem}.forecast-info-btn{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;border-radius:50%;border:none;background:#141c28b3;color:#ffffffd9;font-size:.95rem;font-weight:700;cursor:pointer;z-index:600;box-shadow:0 2px 6px #0000004d;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.forecast-info-btn:hover{background:#141c28f2}.forecast-info-popup{position:absolute;top:2.4rem;right:.5rem;background:#141c28f5;color:#fff;padding:.7rem .85rem;border-radius:8px;z-index:700;font-size:.78rem;line-height:1.55;max-width:250px;box-shadow:0 4px 14px #0006}.forecast-info-close{position:absolute;top:.15rem;right:.3rem;width:22px;height:22px;border:none;background:transparent;color:#ffffffb3;font-size:1rem;cursor:pointer;padding:0}.forecast-info-close:hover{color:#fff}.forecast-info-title{font-weight:700;margin-bottom:.35rem;padding-right:1rem}.forecast-info-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.forecast-info-list a{color:#6fb6ff;text-decoration:underline}.forecast-port-marker{pointer-events:none!important}.forecast-port-pin{width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid #d92e2e;box-shadow:0 0 0 2px #ffffffb3,0 1px 4px #0006}.period-filter{display:flex;flex-wrap:wrap;gap:.4rem;margin:0 0 .7rem}.period-chip{padding:.35rem .85rem;border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:999px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;font-variant-numeric:tabular-nums}.period-chip:hover{border-color:var(--primary);color:var(--primary)}.period-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.map-purpose{font-size:.78rem;line-height:1.55;margin:.5rem 0 .7rem;padding:.65rem .85rem;background:var(--surface);border-radius:8px;border-left:3px solid var(--primary)}.map-purpose strong{color:var(--text)}.unknown-ports{padding:.85rem 1rem;margin-bottom:.7rem}.unknown-ports-title{font-size:.95rem;font-weight:700;margin-bottom:.5rem}.unknown-ports-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.unknown-port-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .7rem;background:var(--surface);border-radius:8px;font-size:.85rem}.map-pick-banner{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.6rem .85rem;margin-bottom:.5rem;border-radius:8px;background:#fff7ed;color:#92400e;border:1px solid #f59e0b;font-size:.85rem;font-weight:600}[data-theme=dark] .map-pick-banner{background:#f59e0b2e;color:#fbbf24;border-color:#f59e0b}.marker-empty-user{background:#d9770680!important}.account-button{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:999px;font-size:.78rem;font-weight:600;cursor:pointer;padding:.3rem .7rem;height:30px;display:inline-flex;align-items:center}.account-button.guest:hover{border-color:var(--primary);color:var(--primary)}.account-button.authed{padding:0;width:30px;justify-content:center}.account-avatar{width:26px;height:26px;border-radius:50%;background:var(--primary);color:#fff;font-weight:700;font-size:.78rem;display:inline-flex;align-items:center;justify-content:center}.account-button-loading{font-size:.85rem;padding:0 .4rem}.account-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;justify-content:flex-end;align-items:flex-start;padding:3.5rem 1rem 0}.account-menu-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:.5rem 0;min-width:200px;box-shadow:0 8px 24px #0000002e}.account-menu-email{padding:.5rem .9rem;font-size:.78rem;color:var(--muted);border-bottom:1px solid var(--border-soft);word-break:break-all}.account-menu-item{display:block;width:100%;text-align:left;background:transparent;border:none;color:var(--text);font-size:.88rem;padding:.65rem .9rem;cursor:pointer}.account-menu-item:hover{background:var(--surface)}.account-menu-item.danger{color:var(--danger-text, #c93333)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c128c;z-index:1080;display:flex;align-items:center;justify-content:center;padding:1rem;animation:sheet-fade .18s ease-out}.modal-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:440px;padding:1.6rem 1.3rem 1.3rem;box-shadow:0 12px 36px #00000040;animation:sheet-up .22s cubic-bezier(.2,.8,.3,1)}.modal-close{position:absolute;top:.5rem;right:.6rem;background:transparent;border:none;color:var(--muted);font-size:1.4rem;cursor:pointer;width:36px;height:36px;border-radius:50%}.modal-close:hover{background:var(--surface);color:var(--text)}.login-title{font-size:1.05rem;font-weight:700;margin:0 0 .4rem}.login-sub{font-size:.85rem;line-height:1.5;margin:0 0 1.1rem}.login-providers{display:flex;flex-direction:column;gap:.55rem}.login-provider{display:flex;align-items:center;gap:.7rem;padding:.85rem 1rem;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;text-align:left}.login-provider.primary{border-color:var(--primary);background:var(--primary);color:#fff}.login-provider.disabled{opacity:.55;cursor:not-allowed}.login-provider-icon{font-size:1.1rem;width:1.4rem;text-align:center}.login-provider-tag{margin-left:.5rem;font-size:.65rem;padding:.1rem .4rem;background:var(--border);color:var(--muted);border-radius:4px;font-weight:600}.login-form{display:flex;flex-direction:column;gap:.85rem}.login-field{display:flex;flex-direction:column;gap:.35rem;font-size:.78rem;font-weight:600;color:var(--muted)}.login-field input{font-size:.95rem}.login-actions{display:flex;justify-content:flex-end;gap:.55rem;margin-top:.4rem}
