@font-face{font-family:RuiZi;src:url(/assets/ShanHaiJiangNanLi75W-2-ChDM7iKu.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f8fafc;--color-surface: #ffffff;--color-surface-hover: #f1f5f9;--color-border: #e2e8f0;--color-text: #1e293b;--color-text-muted: #64748b;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-light: #dbeafe;--color-danger: #ef4444;--color-success: #22c55e;--color-warning: #f59e0b;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--spacing-xs: 4px;--spacing-sm: 6px;--spacing-md: 12px;--spacing-lg: 18px;--spacing-xl: 24px;--font-family: "RuiZi", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--max-width: 480px }html{font-size:15px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);line-height:1.45;min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;min-height:100dvh}.page-wrapper{width:100%;max-width:var(--max-width);margin:0 auto;padding:var(--spacing-md)}@media (min-width: 768px){.page-wrapper{padding:var(--spacing-lg) var(--spacing-xl)}}h1,h2,h3,h4,h5,h6{font-weight:400;line-height:1.3}h2{font-size:1.35rem;margin-bottom:var(--spacing-sm);color:var(--color-text)}p{margin-bottom:var(--spacing-sm)}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);font-family:var(--font-family);font-size:.88rem;padding:7px 12px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s,opacity .15s;line-height:1.25;min-height:34px}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-block{width:100%}input,textarea,select{font-family:var(--font-family);font-size:.92rem;padding:7px 10px;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color .15s;width:100%;min-height:34px}input:focus,textarea:focus,select:focus{border-color:var(--color-primary)}label{display:block;font-size:.85rem;color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-sm)}.list-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);gap:var(--spacing-md)}.list-item-content{flex:1;min-width:0}.list-item-title{font-size:1rem;color:var(--color-text)}.list-item-subtitle{font-size:.8rem;color:var(--color-text-muted);margin-top:2px}.menu-button{background-color:#0000;padding:0}.inline-meta{display:inline;font-size:.58rem;color:var(--color-text-muted)}.inline-meta+.inline-meta:before{content:" · ";color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-warning,.text-gold{color:var(--color-warning)}.icon{display:inline-block;width:1em;height:1em;vertical-align:-.125em;fill:currentColor}.icon-sm{width:16px;height:16px}.icon-md{width:20px;height:20px}.icon-lg{width:24px;height:24px}.progress-bar{width:100%;height:8px;background:var(--color-surface-hover);border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:999px;transition:width .3s ease}.progress-bar-fill--primary{background:var(--color-primary)}.progress-bar-fill--success{background:var(--color-success)}.progress-bar-fill--danger{background:var(--color-danger)}.progress-bar-fill--warning{background:var(--color-warning)}.alert{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);font-size:.82rem}.alert-error{background:#e74c5e1a;border:1px solid rgba(231,76,94,.3);color:var(--color-danger)}.alert-success{background:#34c77b1a;border:1px solid rgba(52,199,123,.3);color:var(--color-success)}.alert-warning{background:#f0b4291a;border:1px solid rgba(240,180,41,.3);color:var(--color-warning)}.nav-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:10}.nav-bar-title{flex:1;font-size:1.1rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.w-full{width:100%}.flex-1{flex:1}.items-start{align-items:flex-start}.nav-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}@media (min-width: 768px){.nav-grid{grid-template-columns:repeat(5,1fr)}}.nav-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-family:var(--font-family);font-size:.9rem;cursor:pointer;transition:all .15s ease;min-height:100px}.nav-card:hover{background:var(--color-surface-hover);border-color:var(--color-primary);transform:translateY(-2px)}.nav-card:active{transform:translateY(0)}.scroll-row{display:flex;gap:var(--spacing-sm);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.scroll-row::-webkit-scrollbar{display:none}.tab{padding:4px 10px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);font-family:var(--font-family);font-size:.78rem;white-space:nowrap;cursor:pointer;transition:all .15s ease}.tab-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.card-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.compact-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--spacing-sm)}.item-card{padding:var(--spacing-sm);border-radius:var(--radius-md);background-color:var(--color-bg);border:1.5px solid rgba(148,163,184,.35)}.square-item-card{position:relative;min-width:0;overflow:hidden;cursor:pointer}.square-item-card-content{height:100%;min-width:0;display:flex;flex-direction:column;justify-content:space-between}.inventory-square-item-card-content{font-size:.78rem}.inventory-square-item-card-content .item-icon{width:24px;height:24px;margin-bottom:2px}.inventory-square-item-card-content .item-name{font-size:.78rem;line-height:1.15}.inventory-square-item-card-content .item-quantity{font-size:.72rem}.square-card-checkbox{position:absolute;top:-5px;right:8px;width:12px;height:12px}.square-item-card .item-name{padding-right:18px}.item-icon{width:32px;height:32px;border-radius:var(--radius-md);background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.inventory-appearance-icon{width:100%;height:100%;object-fit:contain}.item-name{font-size:.88rem;color:var(--color-text);line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-name--multiline{white-space:normal;text-overflow:initial;overflow:visible;overflow-wrap:anywhere}.page-search-row{display:flex;align-items:center;gap:8px}.page-search-row svg{flex-shrink:0;color:var(--color-text-muted)}.page-search-input{flex:1;min-width:0;border:0;padding:0;background:transparent}.page-search-input:focus{box-shadow:none}.region-weather-row{display:flex;flex-wrap:wrap;gap:4px 10px;font-size:.72rem;color:var(--color-text-muted)}.region-weather-row span{display:inline-flex;align-items:center;gap:3px}.region-fish-card{text-align:left}.shop-grid-card{cursor:pointer}.shop-grid-card-owned{background:#effcf2;border-color:#4ade8073}.shop-card-meta{display:flex;flex-direction:column;gap:1px;font-size:.72rem;color:var(--color-text-muted)}.shop-card-meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shop-appearance-preview,.shop-appearance-detail-preview{display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid rgba(148,163,184,.35);border-radius:var(--radius-sm);background:#fff;color:var(--color-text-muted)}.shop-appearance-preview{width:42px;height:42px;margin-bottom:4px}.shop-appearance-detail-preview{width:min(100%,180px);aspect-ratio:1;margin:0 auto var(--spacing-sm)}.shop-appearance-preview img,.shop-appearance-detail-preview img{width:100%;height:100%;object-fit:contain}.item-quantity{font-size:.8rem;color:var(--color-text-muted);font-weight:500}.item-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);font-size:.6rem}.item-price{font-size:1rem;font-weight:500;color:var(--color-primary)}.fish-card{padding:var(--spacing-md)}.fish-card.locked{opacity:.6}.fish-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.fish-icon.locked{background:var(--color-surface-hover);color:var(--color-text-muted)}.fish-name{font-size:1rem;color:var(--color-text)}.license-card{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md)}.license-card.locked{opacity:.82}.license-card-main{display:flex;align-items:flex-start;gap:var(--spacing-md);min-width:0}.license-content{min-width:0;flex:1}.license-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm);min-width:0}.license-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.license-icon.unlocked{background:#22c55e26;color:var(--color-success)}.license-icon.available{background:var(--color-primary-light);color:var(--color-primary)}.license-icon.locked{background:var(--color-surface-hover);color:var(--color-text-muted)}.license-name{font-size:.98rem;font-weight:700;color:var(--color-text);overflow-wrap:anywhere}.license-desc{margin-top:2px;font-size:.82rem;line-height:1.35;color:var(--color-text-muted);overflow-wrap:anywhere}.license-owned{flex-shrink:0;font-size:.72rem;color:var(--color-success);background:#22c55e1f;border-radius:999px;padding:2px 8px}.license-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 10px;margin-top:var(--spacing-sm);font-size:.78rem;color:var(--color-text-muted)}.license-meta-grid span{min-width:0;overflow-wrap:anywhere}.license-region-list{display:grid;gap:2px;margin-top:var(--spacing-sm);font-size:.78rem;line-height:1.35;color:var(--color-text);overflow-wrap:anywhere}.license-buy-btn{min-width:84px}@media (max-width: 560px){.license-card{grid-template-columns:1fr}.license-buy-btn{width:100%}}.achievement-card{padding:var(--spacing-md)}.achievement-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.achievement-icon.completed{background:#f59e0b26;color:var(--color-warning)}.achievement-name{font-size:1rem;color:var(--color-text)}.avatar{width:48px;height:48px;border-radius:50%;background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.player-name{font-size:1.1rem;color:var(--color-text)}.status-dot{width:8px;height:8px;border-radius:50%}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 18px;text-align:center}.icon-muted{color:var(--color-text-muted);opacity:.5}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:all .15s ease}.btn-icon:hover{background:var(--color-surface-hover)}.section-title{font-size:1rem;color:var(--color-text);margin-bottom:var(--spacing-sm)}.app-layout{display:flex;min-height:100vh;min-height:100dvh}.sidebar{width:220px;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:width .2s ease;flex-shrink:0;position:sticky;top:0;height:100vh;height:100dvh;overflow:hidden;z-index:20}.sidebar.collapsed{width:40px}.sidebar-header{display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);border-bottom:1px solid var(--color-border);min-height:56px}.sidebar-title{font-size:1.1rem;font-weight:600;color:var(--color-primary);white-space:nowrap}.sidebar-nav{display:flex;flex-direction:column;align-items:center;overflow-y:auto;gap:5px;height:90%}.sidebar-item{display:flex;align-items:center;gap:var(--spacing-sm);width:70%;aspect-ratio:1;padding:5px;border:none;background:transparent;color:var(--color-text-muted);font-family:var(--font-family);font-size:.9rem;cursor:pointer;transition:all .15s ease;text-align:left;white-space:nowrap}.sidebar-item:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar-item.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:500}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border)}.sidebar-immersive-toggle{width:100%;margin-top:var(--spacing-sm);border:none;padding:0}.player-info{display:flex;flex-direction:column;gap:2px}.player-level{font-size:.8rem;color:var(--color-text-muted)}.main-content{flex:1;min-width:0;padding:var(--spacing-sm);overflow-y:auto;position:relative;background:linear-gradient(180deg,#eaf7ff,#f6fbff 58%,#eef8ff)}.main-content>*:not(.main-fish-background){position:relative}.main-fish-background{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.main-bg-fish{position:absolute;width:22px;height:22px;color:#ffffffb8;animation:swimDrift 16s ease-in-out infinite alternate}@keyframes swimDrift{0%{transform:translateZ(0) rotate(0)}50%{transform:translate3d(26px,-18px,0) rotate(8deg)}to{transform:translate3d(-18px,22px,0) rotate(-7deg)}}.fish-1{left:12%;top:14%;animation-duration:17s}.fish-2{left:34%;top:9%;animation-duration:21s;animation-delay:-4s}.fish-3{left:68%;top:16%;animation-duration:18s;animation-delay:-9s}.fish-4{left:88%;top:28%;animation-duration:24s;animation-delay:-2s}.fish-5{left:20%;top:38%;animation-duration:19s;animation-delay:-7s}.fish-6{left:53%;top:44%;animation-duration:23s;animation-delay:-12s}.fish-7{left:79%;top:52%;animation-duration:20s;animation-delay:-5s}.fish-8{left:8%;top:65%;animation-duration:26s;animation-delay:-10s}.fish-9{left:42%;top:72%;animation-duration:18s;animation-delay:-3s}.fish-10{left:71%;top:80%;animation-duration:22s;animation-delay:-14s}.fish-11{left:92%;top:88%;animation-duration:25s;animation-delay:-8s}.fish-12{left:27%;top:86%;animation-duration:20s;animation-delay:-15s}.fish-13{left:58%;top:25%;animation-duration:27s;animation-delay:-6s}.fish-14{left:4%;top:24%;animation-duration:21s;animation-delay:-11s}.app-status-banner{position:sticky;top:0;z-index:20;margin-bottom:var(--spacing-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@media (min-width: 768px){.main-content{padding:var(--spacing-lg) var(--spacing-xl);max-width:calc(100vw - 220px)}}@media (max-width: 767px){.sidebar{position:fixed;left:0;top:0;z-index:100;box-shadow:2px 0 12px #00000014}.sidebar.collapsed{width:40px}.main-content{width:100%;max-width:100%;padding-left:calc(35px + var(--spacing-sm))}}.loadout-summary{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.stat-row{display:flex;gap:var(--spacing-lg)}.stat-item{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:.8rem;color:var(--color-text-muted)}.stat-value{font-size:1.2rem;font-weight:500;color:var(--color-text)}.fish-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.fish-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.fish-stat{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--color-text-muted)}.fish-proficiency{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.8rem;color:var(--color-text-muted)}.fish-proficiency .progress-bar{flex:1}.fish-proficiency .progress-bar.small{height:6px}.dex-progress{margin-bottom:var(--spacing-md)}.dex-progress .progress-text{display:block;font-size:.8rem;color:var(--color-text-muted);margin-top:var(--spacing-xs);text-align:right}.profile-card{display:flex;align-items:center;gap:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.profile-info h3{margin:0 0 var(--spacing-xs);font-size:1.1rem}.profile-stats{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.settings-list{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-md)}.settings-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);border:none;border-bottom:1px solid var(--color-border);background:transparent;color:var(--color-text);font-family:var(--font-family);font-size:.95rem;cursor:pointer;text-align:left;min-height:48px}.settings-item:last-child{border-bottom:none}.settings-item:hover{background:var(--color-surface-hover)}.settings-form{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.ranking-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.ranking-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.ranking-item.rank-1{border-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.ranking-item.rank-2{border-color:#94a3b8;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.ranking-item.rank-3{border-color:#d97706;background:linear-gradient(135deg,#fff7ed,#ffedd5)}.ranking-item-actionable{cursor:pointer}.ranking-item-actionable:hover,.ranking-item-actionable:focus-visible{border-color:color-mix(in srgb,var(--color-primary) 52%,var(--color-border));transform:translateY(-1px)}.ranking-item-self{border-color:var(--color-primary);box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 26%,transparent);background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 10%,white),var(--color-surface))}.ranking-rank{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--color-text-muted);flex-shrink:0}.ranking-info{flex:1;display:flex;flex-direction:column;gap:2px}.ranking-name{font-size:.95rem;color:var(--color-text)}.ranking-self-note{margin-left:var(--spacing-xs);font-size:.72rem;color:var(--color-primary)}.ranking-detail{font-size:.8rem;color:var(--color-text-muted)}.ranking-separator{text-align:center;color:var(--color-text-muted);font-size:.8rem;letter-spacing:.2em}.page-actions{margin-top:var(--spacing-lg);display:flex;gap:var(--spacing-sm)}.notice{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:.9rem}.notice.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:var(--color-success)}.notice.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--color-danger)}.item-card.selected{border-color:var(--color-primary);background:var(--color-primary-light)}.shop-item-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.shop-item-stat{font-size:.75rem;color:var(--color-text-muted);background:var(--color-surface-hover);padding:2px 6px;border-radius:var(--radius-sm)}.guild-section{margin-bottom:var(--spacing-lg)}.guild-section-title{font-size:1rem;color:var(--color-text);margin-bottom:var(--spacing-sm)}.help-content h3{font-size:1.05rem;font-weight:700;color:var(--color-text);margin:16px 0 8px}.help-content h4{font-size:.95rem;font-weight:600;color:var(--color-text);margin:12px 0 6px}.help-content p{margin:6px 0;line-height:1.6;color:var(--color-text)}.help-content ul,.help-content ol{margin:6px 0;padding-left:24px}.help-content li{margin:4px 0;line-height:1.6;color:var(--color-text)}.help-content table{width:100%;border-collapse:collapse;margin:10px 0;font-size:.88rem}.help-content thead{background:var(--color-surface-hover)}.help-content th,.help-content td{padding:6px 10px;border:1px solid var(--color-border);text-align:left}.help-content th{font-weight:600;color:var(--color-text)}.help-content td{color:var(--color-text-muted)}.help-content strong{font-weight:600;color:var(--color-text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:flex-end;justify-content:center;background:#00000073;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .2s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-title{font-size:1.05rem;font-weight:700;color:var(--color-text);margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:background .15s}.modal-close:hover{background:var(--color-surface-hover)}.modal-body{padding:16px 20px 24px;overflow-y:auto;-webkit-overflow-scrolling:touch}.loadout-bar{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;padding:10px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}@media (max-width: 360px){.loadout-bar{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.loadout-slot{display:flex;flex-direction:column;align-items:stretch;gap:4px;padding:10px 8px;border-radius:var(--radius-sm);background:var(--color-surface-hover);cursor:pointer;transition:background .15s;min-width:0;min-height:132px}.loadout-slot:hover{background:var(--color-primary-light)}.loadout-slot.active{background:var(--color-primary-light);border:1px solid var(--color-primary)}.loadout-slot-required{box-shadow:inset 0 0 0 1px #3b82f626}.loadout-slot-missing{background:#f0b4291f;border:1px solid rgba(240,180,41,.5)}.loadout-slot-broken{background:#fee2e2;border:1px solid rgba(239,68,68,.45);box-shadow:inset 0 0 0 1px #ef44441f}.loadout-slot-broken .loadout-slot-hint{color:var(--color-danger);font-weight:700}.loadout-slot-low-durability{background:#fef2f2;border:1px solid rgba(248,113,113,.35)}.loadout-slot-low-durability .loadout-slot-hint{color:#b91c1c;font-weight:700}.loadout-slot-inactive{opacity:.65}.loadout-slot-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:3px}.loadout-slot-title{display:inline-flex;align-items:center;gap:4px;min-width:0}.loadout-slot-action{border:0;background:transparent;color:var(--color-primary);padding:0;font-size:.68rem;line-height:1.2;cursor:pointer;flex-shrink:0;min-height:0}.loadout-slot-action:hover{text-decoration:underline}.loadout-slot-label{font-size:.72rem;color:var(--color-text-muted);white-space:normal;text-align:left;line-height:1.2}.loadout-slot-name{font-size:.74rem;font-weight:600;color:var(--color-text);white-space:normal;overflow:hidden;max-width:100%;text-align:left;line-height:1.2}.loadout-slot-empty{font-size:.68rem;color:var(--color-text-muted);font-style:italic;text-align:left}.loadout-slot-meta{display:flex;flex-wrap:wrap;gap:2px 8px;font-size:.58rem;color:var(--color-text-muted)}.loadout-slot-hint{font-size:.68rem;color:var(--color-text-muted);white-space:normal;text-align:left;line-height:1.2}.loadout-summary-stats{margin-top:2px;display:flex;flex-wrap:wrap;gap:2px 12px;font-size:.52rem;color:var(--color-text-muted)}.loadout-control-summary{margin-top:2px;display:flex;flex-wrap:wrap;gap:2px 8px;font-size:.7rem;color:var(--color-text-muted)}.loadout-slot-stats{margin-top:0}.fishing-overview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px}.fishing-overview-item{display:flex;flex-direction:column;gap:1px;padding:5px 7px;border-radius:var(--radius-md);background:var(--color-surface-hover);min-width:0;line-height:1.2}.fishing-overview-item strong{display:flex;font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fishing-metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px}.fishing-metric-card{padding:6px 7px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-hover)}.fishing-metric-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xs);margin-bottom:3px}.fishing-metric-label{display:inline-flex;align-items:center;gap:4px;min-width:0;font-size:.72rem;color:var(--color-text-muted)}.fishing-metric-value{font-size:.82rem;font-weight:600;color:var(--color-text);white-space:nowrap}.fishing-metric-progress{height:4px;margin-top:3px}.fishing-compact-card{padding:var(--spacing-xs)}.fishing-log-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:320px;overflow-y:auto;padding-right:2px}.fishing-log-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius-md);background:var(--color-surface-hover);border:1px solid transparent}.fishing-log-item--info{border-color:#3b82f61f}.fishing-log-item--warn{background:#f59e0b14;border-color:#f59e0b3d}.fishing-log-item--success{background:#22c55e14;border-color:#22c55e3d}.fishing-log-time{flex-shrink:0;width:64px;font-size:.72rem;color:var(--color-text-muted)}.fishing-log-message{flex:1;min-width:0;font-size:.86rem;color:var(--color-text)}.fishing-log-empty{padding:12px;border-radius:var(--radius-md);background:var(--color-surface-hover)}.keep-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);flex-wrap:wrap}.keep-toolbar-stat{display:flex;flex-direction:column;gap:2px;min-width:72px;font-size:.86rem}.keep-action-row{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.keep-card-meta,.inventory-card-meta{min-width:0;font-size:.72rem;color:var(--color-text-muted);line-height:1.25}.keep-card-meta span,.inventory-card-meta span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.square-card-meta-line{display:flex;flex-wrap:wrap;gap:3px}.achievement-card-unlocked{border-color:#22c55e52}.achievement-card-locked{opacity:.78}.message-card{border-left:4px solid var(--color-border)}.message-card--catch{border-left-color:var(--color-primary)}.message-card--achievement{border-left-color:var(--color-warning)}.message-card--trade{border-left-color:var(--color-success)}.message-card--system{border-left-color:var(--color-text-muted)}.message-title{font-size:.95rem;color:var(--color-text)}@media (max-width: 480px){.fishing-overview-grid,.fishing-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.skill-card{position:relative;overflow:hidden;min-height:48px}.skill-card-content{position:relative;z-index:1}.skill-card-progress{position:absolute;left:0;right:0;bottom:0;height:8px;background:var(--color-surface-hover)}.skill-card-progress>div{height:100%;background:var(--color-primary)}.skill-card-progress-text{position:absolute;right:8px;bottom:8px;font-size:.68rem;color:var(--color-text-muted)}.fish-card-photo{width:100%;height:54px;object-fit:contain;border-radius:var(--radius-sm);background:#fff}.fish-card-photo--wide{height:96px;margin-bottom:var(--spacing-sm)}.fish-thumb{width:100%;height:100%;object-fit:contain}.fish-detail-photo{width:100%;height:180px;object-fit:contain;border-radius:var(--radius-md);background:#fff;margin-bottom:var(--spacing-md)}.catch-rating-bar{display:flex;position:relative;width:100%;height:10px;border-radius:999px;overflow:hidden;background:var(--color-surface-hover)}.catch-rating-bar>div{flex:0 0 auto;opacity:.52}.catch-rating-bar>div.active{opacity:1;box-shadow:inset 0 0 0 2px #ffffffbf}.catch-rating-marker{position:absolute;top:50%;width:12px;height:12px;border:2px solid #fff;border-radius:999px;background:var(--color-text);box-shadow:0 1px 5px #0f172a59;transform:translate(-50%,-50%);pointer-events:none}.detail-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}.detail-stat{display:flex;flex-direction:column;padding:8px 10px;background:var(--color-surface-hover);border-radius:var(--radius-sm)}.detail-stat-label{font-size:.75rem;color:var(--color-text-muted);margin-bottom:2px}.detail-stat-label-row{display:inline-flex;align-items:center;gap:4px}.detail-stat-help{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:var(--color-text-muted);min-height:16px}.detail-stat-help:hover{background:var(--color-primary-light);color:var(--color-primary)}.detail-stat-value{font-size:.9rem;font-weight:600;color:var(--color-text)}.detail-stat.full-width{grid-column:1 / -1}.detail-stat-clickable{border:1px solid var(--color-border);cursor:pointer;text-align:left}.detail-stat-clickable:hover{background:var(--color-primary-light)}.fish-detail-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.fish-detail-section-title{font-size:.8rem;font-weight:600;color:var(--color-text-muted);margin-bottom:8px}.fish-stat-bar-group{display:flex;flex-direction:column;gap:6px}.fish-stat-bar-row{display:flex;align-items:center;gap:8px}.fish-stat-bar-label{font-size:.8rem;color:var(--color-text);width:36px;flex-shrink:0}.fish-stat-bar-track{flex:1;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.fish-stat-bar-fill{height:100%;border-radius:3px;background:var(--color-primary);transition:width .3s ease}.fish-stat-bar-value{font-size:.75rem;color:var(--color-text-muted);width:24px;text-align:right;flex-shrink:0}.inventory-card-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px}.inventory-card-grid .item-card{padding:6px;border-radius:var(--radius-sm)}.inventory-card-grid .inventory-card-meta{font-size:.66rem}.currency-display{display:inline-flex;align-items:center;gap:6px}.currency-item{display:inline-flex;align-items:center;gap:3px;white-space:nowrap}.currency-item svg:first-child{color:var(--color-warning)}.currency-item+.currency-item svg:first-child{color:#38bdf8}.weather-icon-row,.weather-icon-row span{display:inline-flex;align-items:center;gap:3px}.weather-icon-row{gap:8px}.main-content{background:linear-gradient(180deg,#ddf4ff,#eef9ff 58%,#e2f5ff)}.main-bg-fish{color:#fffffff2}.sidebar-fishing-timer{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:8px;color:var(--color-primary);font-size:.78rem}.sidebar-fishing-timer svg{width:20px;height:20px;transform:rotate(0)}.timer-ring-bg,.timer-ring-fill{fill:none;stroke-width:8}.timer-ring-bg{stroke:var(--color-border)}.timer-ring-fill{stroke:var(--color-primary);stroke-linecap:round}.sidebar-item-icon{position:relative;display:inline-flex;align-items:center;justify-content:center}.sidebar-item-dot{position:absolute;top:-3px;right:-4px;width:8px;height:8px;border-radius:999px;background:var(--color-danger);box-shadow:0 0 0 2px var(--color-surface)}.sidebar-stamina{padding:0 10px 10px;color:var(--color-text-muted);font-size:.72rem}.sidebar-stamina-track{height:5px;overflow:hidden;border-radius:999px;background:var(--color-border)}.sidebar-stamina-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--color-primary),var(--color-success))}.sidebar-stamina span{display:block;margin-top:4px;text-align:center}.app-announcement-banner{position:relative;overflow:hidden;min-height:38px;margin-bottom:12px;border:1px solid rgba(19,94,160,.16);border-radius:999px;background:linear-gradient(90deg,#fff7d6fa,#ffefadfa);box-shadow:0 8px 24px #135ea014}.app-announcement-track{position:absolute;inset:0 auto 0 0;display:flex;align-items:center;white-space:nowrap;padding-inline:20px;color:#7a4b00;font-weight:700;animation-name:app-announcement-scroll;animation-timing-function:linear;animation-fill-mode:forwards}.app-announcement-track span{padding-right:24px}@keyframes app-announcement-scroll{0%{transform:translate(100%)}to{transform:translate(calc(-100% - 24px))}}.global-error-screen{position:relative;min-height:100vh;min-height:100dvh;overflow:hidden;background:radial-gradient(circle at top,rgba(255,255,255,.78),transparent 42%),linear-gradient(180deg,#ddf4ff,#eef9ff 58%,#e2f5ff)}.global-error-screen:after{content:"";position:absolute;inset:auto 0 0;height:32%;background:linear-gradient(180deg,#7dd3fc00,#7dd3fc33)}.global-error-wrapper{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding-top:var(--spacing-xl);padding-bottom:var(--spacing-xl)}.global-error-card{width:min(100%,560px);padding:18px;border:1px solid rgba(19,94,160,.16);border-radius:24px;background:#ffffffeb;box-shadow:0 24px 50px #135ea01f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.global-error-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#dbeafeeb;color:var(--color-primary);font-size:.76rem;border:1px solid rgba(59,130,246,.14)}.global-error-hero{margin-top:16px;text-align:center}.global-error-icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;margin-bottom:14px;border-radius:50%;background:linear-gradient(180deg,#dbeafef5,#bfdbfee6);color:var(--color-primary);border:1px solid rgba(59,130,246,.14);box-shadow:inset 0 1px #ffffffe6}.global-error-hero h1{margin-bottom:8px;font-size:1.5rem;color:var(--color-text)}.global-error-hero p{margin-bottom:0;color:var(--color-text-muted);font-size:.92rem}.global-error-reason{margin-top:18px;padding:14px 16px;border-radius:18px;background:#f8fafceb;border:1px solid rgba(148,163,184,.2)}.global-error-reason-label{display:inline-block;margin-bottom:8px;color:var(--color-primary);font-size:.8rem}.global-error-reason p{margin-bottom:0;word-break:break-word;color:var(--color-text);line-height:1.55}.global-error-fish-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.global-error-fish{position:absolute;color:#ffffffe6;opacity:.88;animation:global-error-fish-drift 12s ease-in-out infinite}.global-error-fish.fish-1{top:9%;left:10%;width:54px;height:54px;--fish-rotation: -14deg}.global-error-fish.fish-2{top:18%;right:11%;width:38px;height:38px;--fish-rotation: 18deg;animation-delay:-3s}.global-error-fish.fish-3{top:52%;left:6%;width:42px;height:42px;--fish-rotation: -24deg;animation-delay:-6s}.global-error-fish.fish-4{right:7%;bottom:24%;width:64px;height:64px;--fish-rotation: 12deg;animation-delay:-4s}.global-error-fish.fish-5{bottom:12%;left:16%;width:30px;height:30px;--fish-rotation: -10deg;animation-delay:-8s}.global-error-fish.fish-6{top:38%;right:22%;width:28px;height:28px;--fish-rotation: 22deg;animation-delay:-5s}@keyframes global-error-fish-drift{0%,to{transform:translateZ(0) rotate(var(--fish-rotation))}50%{transform:translate3d(6px,-12px,0) rotate(calc(var(--fish-rotation) + 4deg))}}@media (max-width: 767px){.global-error-card{padding:16px;border-radius:20px}.global-error-hero h1{font-size:1.3rem}.global-error-fish.fish-2,.global-error-fish.fish-6{display:none}}
