:root{--color-background: #121212;--color-surface: #1e1e1e;--color-surface-alt: #2a2a2a;--color-text-primary: #e0e0e0;--color-text-secondary: #a0a0a0;--color-text-accent: #f0f0f0;--color-primary: #00d4d4;--color-accent: #ff6700;--color-success: #4caf50;--color-danger: #e53935;--color-warning: #ffc107;--color-border: rgb(224 224 224 / 10%);--shadow-sm: 0 2px 4px rgb(0 0 0 / 10%);--shadow-md: 0 4px 12px rgb(0 0 0 / 15%);--shadow-lg: 0 8px 24px rgb(0 0 0 / 20%);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-family: -apple-system, blinkmacsystemfont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", sans-serif;--font-size-sm: 12px;--font-size-base: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: .2s ease;--z-header: 100;--z-nav: 200;--z-overlay: 500;--z-modal: 10000;--z-water-mode: 9999}*{margin:0;padding:0;box-sizing:border-box;scrollbar-width:none;-ms-overflow-style:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:pan-x pan-y}.hidden{display:none!important}*::-webkit-scrollbar{display:none}html{scroll-behavior:smooth;touch-action:pan-x pan-y;--vh: 1vh}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.2;color:var(--color-text-primary);background-color:var(--color-background);padding-bottom:70px;touch-action:pan-x pan-y}body.modal-open{overflow:hidden}@media (width >= 1025px){body{padding-bottom:0;margin-left:240px}}@media (width >= 768px) and (width <= 1024px){body{padding-bottom:0}}button{font-family:inherit;font-size:inherit;cursor:pointer}input,textarea,select{font-family:inherit;font-size:16px;color:inherit}.header{position:sticky;top:0;z-index:var(--z-header);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.header-left{display:flex;align-items:center;gap:var(--spacing-md);flex:0 0 auto}.header-logo{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:var(--color-primary);border-radius:var(--radius-md);color:var(--color-background);font-size:var(--font-size-xl)}.logo-img{width:100%;height:100%;object-fit:contain;filter:brightness(0) invert(0)}.header-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);min-width:0}.header-center{flex:1;min-width:0}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);transition:border-color var(--transition)}.search-input:focus{outline:none;border-color:var(--color-primary)}.search-input::placeholder{color:var(--color-text-secondary)}.header-right{position:relative;display:flex;align-items:center;gap:var(--spacing-md)}.header-icon-btn{position:relative;width:40px;height:40px;padding:0;background:none;border:none;color:var(--color-text-primary);font-size:var(--font-size-xl);border-radius:var(--radius-md);transition:all var(--transition);display:flex;align-items:center;justify-content:center;cursor:pointer}.header-icon-btn:hover{background-color:var(--color-surface-alt);color:var(--color-primary)}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;background-color:var(--color-danger);color:#fff;border-radius:50%;font-size:var(--font-size-sm);font-weight:600;display:flex;align-items:center;justify-content:center}.burger-menu-btn{display:none;flex-direction:column;gap:4px;background:none;border:none;color:var(--color-text-primary);padding:8px}.burger-line{width:24px;height:2px;background-color:currentcolor;border-radius:1px;transition:all var(--transition)}@media (width <= 1024px){.header-center{display:none}.burger-menu-btn{display:flex}}.sidebar{display:none}@media (width >= 1025px){.sidebar{position:fixed;top:0;left:0;bottom:0;width:240px;background-color:var(--color-surface);border-right:1px solid var(--color-border);box-shadow:var(--shadow-sm);z-index:var(--z-nav);display:flex;flex-direction:column;padding:var(--spacing-lg)}.sidebar-header{margin-bottom:var(--spacing-lg)}.sidebar-title{font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.sidebar-nav-items{flex:1;list-style:none;display:flex;flex-direction:column;gap:var(--spacing-sm)}.sidebar-nav-items .nav-item{list-style:none}.sidebar-nav-items .nav-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:none;border:none;color:var(--color-text-primary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition);cursor:pointer;width:100%;text-align:left;font-size:var(--font-size-base)}.sidebar-nav-items .nav-link:hover,.sidebar-nav-items .nav-link.active{background-color:#00d4d41a;color:var(--color-primary)}.sidebar-nav-items .nav-link i{font-size:var(--font-size-lg);width:24px;text-align:center}.sidebar-divider{list-style:none;border-top:1px solid var(--color-border);margin:var(--spacing-md) 0;padding:0}.sidebar-nav-items .sidebar-secondary-link{opacity:.8;font-size:var(--font-size-sm)}.sidebar-nav-items .sidebar-secondary-link:hover,.sidebar-nav-items .sidebar-secondary-link.active{opacity:1;background-color:#00d4d41a;color:var(--color-primary)}}.top-nav{display:none}@media (width >= 768px) and (width <= 1024px){.top-nav{position:sticky;top:60px;z-index:var(--z-nav);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-md)}.top-nav-items{display:flex;list-style:none;gap:var(--spacing-lg)}.top-nav-items .nav-item{list-style:none}.top-nav-items .nav-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;color:var(--color-text-primary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition);cursor:pointer;font-size:var(--font-size-base);position:relative}.top-nav-items .nav-link:hover,.top-nav-items .nav-link.active{color:var(--color-primary)}.top-nav-items .nav-link.active:after{content:"";position:absolute;bottom:-17px;left:0;right:0;height:2px;background-color:var(--color-primary)}.top-nav-items .nav-link i{font-size:var(--font-size-lg)}}.burger-overlay{position:fixed;inset:0;background-color:#0000007f;z-index:var(--z-overlay);opacity:0;pointer-events:none;transition:opacity var(--transition)}.burger-overlay.active{opacity:1;pointer-events:all}.burger-menu-content{position:fixed;top:0;right:0;bottom:0;width:280px;background-color:var(--color-surface);z-index:var(--z-overlay);display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--transition);box-shadow:var(--shadow-lg)}.burger-overlay.active .burger-menu-content{transform:translate(0)}.burger-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.burger-header h3{font-size:var(--font-size-lg);font-weight:600}.burger-close-btn{width:40px;height:40px;padding:0;background:none;border:none;color:var(--color-text-primary);font-size:var(--font-size-2xl);cursor:pointer;display:flex;align-items:center;justify-content:center}.burger-nav-items{flex:1;list-style:none;padding:var(--spacing-md);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-sm)}.burger-nav-items .nav-item{list-style:none}.burger-nav-items .nav-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:none;border:none;color:var(--color-text-primary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition);cursor:pointer;width:100%;text-align:left;font-size:var(--font-size-base)}.burger-nav-items .nav-link:hover,.burger-nav-items .nav-link.active{background-color:#00d4d41a;color:var(--color-primary)}.user-menu-item i,.sub-tab i{font-size:var(--font-size-lg)}.section-title i{color:var(--color-primary)}.item-toggle-details-btn i{transition:transform var(--transition);display:inline-block}.burger-nav-items .nav-link i{font-size:var(--font-size-lg);width:24px;text-align:center}.burger-water-mode-item{margin-top:auto;padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.water-mode-link{background:linear-gradient(135deg,var(--color-accent) 0%,#ff7a1a 100%)!important;color:#fff!important;font-weight:600;justify-content:center;box-shadow:var(--shadow-md)}.water-mode-link:hover{background:linear-gradient(135deg,#ff7a1a 0%,var(--color-accent) 100%)!important;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.main-content{min-height:auto;padding:var(--spacing-lg);max-width:1400px;margin:0 auto;overflow-y:auto}@media (width <= 767px){.main-content{padding:var(--spacing-md);min-height:auto}}.bottom-nav{display:none}@media (width <= 767px){.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-nav);display:flex;align-items:stretch;background-color:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:0 -2px 8px #0000001a}.bottom-nav-items{display:flex;list-style:none;width:100%}.bottom-nav-items .nav-item{flex:1;list-style:none}.bottom-nav-items .nav-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:none;border:none;color:var(--color-text-primary);text-decoration:none;height:70px;font-size:var(--font-size-sm);transition:all var(--transition);cursor:pointer}.bottom-nav-items .nav-link:hover,.bottom-nav-items .nav-link.active{color:var(--color-primary)}.bottom-nav-items .nav-link i{font-size:var(--font-size-2xl)}}.water-mode-fab{position:fixed;bottom:90px;right:var(--spacing-lg);width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;border:none;font-size:28px;cursor:pointer;box-shadow:0 4px 12px #4a90e266,0 2px 4px #0003;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;z-index:9998;padding:0}.water-mode-fab:hover,.water-mode-fab:focus{background:linear-gradient(135deg,#5ba0f2,#4680cd);transform:scale(1.1);box-shadow:0 6px 16px #4a90e27f,0 4px 8px #0000004d}.water-mode-fab:active{transform:scale(.95)}@media (width >= 768px){.water-mode-fab{bottom:var(--spacing-lg);width:72px;height:72px;font-size:32px}}body.water-mode .water-mode-fab{display:none}.fab{position:fixed;bottom:90px;right:var(--spacing-lg);width:56px;height:56px;border-radius:50%;background-color:var(--color-accent);color:#fff;border:none;font-size:var(--font-size-2xl);cursor:pointer;box-shadow:var(--shadow-lg);transition:all var(--transition);display:flex;align-items:center;justify-content:center;z-index:50}.fab:hover{background-color:#ff7a1a;transform:scale(1.1);box-shadow:var(--shadow-lg)}@media (width >= 768px){.fab{bottom:var(--spacing-lg)}}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:999;opacity:0;pointer-events:none;transform:translateY(-10px) scale(.95);transition:all var(--transition);min-width:220px;overflow:hidden}.user-menu-dropdown.active{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}.user-menu-item{width:100%;padding:var(--spacing-md);background:none;border:none;color:var(--color-text-primary);text-align:left;cursor:pointer;display:flex;align-items:center;gap:var(--spacing-md);font-size:var(--font-size-base);transition:all var(--transition)}.user-menu-item:hover{background-color:var(--color-surface-alt);color:var(--color-primary)}.user-menu-item-danger{color:var(--color-danger)}.user-menu-item-danger:hover{background-color:#e539351a}.user-menu-divider{border:none;border-top:1px solid var(--color-border);margin:0}.modal-overlay{position:fixed;inset:0;background-color:#0000007f;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:var(--z-modal);opacity:0;pointer-events:none;transition:opacity var(--transition);touch-action:pan-x pan-y}.modal-overlay.active{opacity:1;pointer-events:all}.modal-content{position:fixed;background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-modal);max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;opacity:0;transform:scale(.95);pointer-events:none;transition:all var(--transition);touch-action:pan-x pan-y}.modal-overlay.active .modal-content{opacity:1;transform:scale(1);pointer-events:all}@media (width <= 767px){.modal-content{bottom:0;left:0;right:0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;transform:translateY(100%)}.modal-overlay.active .modal-content{transform:translateY(0)}}@media (width >= 768px){.modal-content{top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:90%;max-width:600px}.modal-overlay.active .modal-content{transform:translate(-50%,-50%) scale(1)}}.modal-drag-handle{width:60px;height:5px;background-color:var(--color-primary);opacity:.5;border-radius:3px;margin:var(--spacing-sm) auto;padding-top:5px;content:"";display:block}@media (width >= 768px){.modal-drag-handle{display:none}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:2px solid var(--color-primary);background:linear-gradient(135deg,rgb(0 212 212 / 10%) 0%,transparent 100%)}.modal-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-accent)}.modal-close-btn{background:none;border:none;color:var(--color-text-primary);font-size:var(--font-size-2xl);cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.modal-close-btn:hover{color:var(--color-primary)}.modal-body{flex:1;padding:var(--spacing-lg);overflow-y:auto;background:linear-gradient(to bottom,rgb(0 212 212 / 3%) 0%,transparent 50px)}.modal-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.modal-section{background:#ffffff08;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);transition:all var(--transition)}.modal-section:hover{border-color:#00d4d44d;background:#ffffff0d}.modal-section:last-child{margin-bottom:0}.modal-section-title{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--spacing-md);text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;gap:var(--spacing-sm)}.modal-section-title:before{content:"";display:inline-block;width:3px;height:14px;background:var(--color-primary);border-radius:2px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border);background:linear-gradient(to top,rgb(0 0 0 / 10%) 0%,transparent 100%)}.modal-input.error,.form-select.error,.form-input.error{border-color:var(--color-danger);background:#e539350d}.modal-input.error:focus,.form-select.error:focus,.form-input.error:focus{border-color:var(--color-danger);box-shadow:0 0 0 4px #e539351a}.button-primary,.button-secondary,.button-danger{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);border:none;font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition);min-height:44px}.button-primary{background-color:var(--color-accent);color:#fff;box-shadow:0 2px 8px #ff6b0033}.button-primary:hover{background-color:#ff7a1a;transform:translateY(-2px);box-shadow:0 4px 16px #ff6b0066}.button-primary:active{transform:translateY(0);box-shadow:0 1px 4px #ff6b004d}.button-secondary{background-color:transparent;color:var(--color-text-primary);border:2px solid var(--color-border)}.button-secondary:hover{background-color:var(--color-surface-alt);border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 2px 8px #00d4d426}.button-secondary:active{transform:scale(.98)}.button-danger{background-color:transparent;color:var(--color-danger);border:none}.button-danger:hover{background-color:#e539351a}.message-display{position:fixed;top:var(--spacing-lg);left:50%;transform:translate(-50%);z-index:var(--z-modal);max-width:400px;opacity:0;pointer-events:none;transition:opacity var(--transition)}.message-display.active{opacity:1;pointer-events:all}.skip-link{position:absolute;top:-40px;left:0;background-color:var(--color-primary);color:var(--color-background);padding:var(--spacing-md);text-decoration:none;z-index:var(--z-modal)}.skip-link:focus{top:0}button:focus-visible,a:focus-visible,input:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.inventory-view{display:flex;flex-direction:column;gap:var(--spacing-lg)}.sub-tabs-container{display:flex;gap:var(--spacing-md);border-bottom:2px solid var(--color-border);overflow-x:auto;scrollbar-width:none}.sub-tabs-container::-webkit-scrollbar{display:none}.sub-tab{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:500;cursor:pointer;position:relative;transition:all var(--transition);white-space:nowrap}.sub-tab:hover{color:var(--color-text-primary)}.sub-tab.sub-tab-active{color:var(--color-primary)}.sub-tab.sub-tab-active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background-color:var(--color-primary)}.sub-tab-content{display:none}.sub-tab-content.sub-tab-content-active{display:block}.inventory-container{width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-lg)}.inventory-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.inventory-cards-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-md)}@media (width <= 767px){.inventory-cards-container{grid-template-columns:1fr}}.sets-container{width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-lg)}.modal-input{width:100%;padding:var(--spacing-md);background-color:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all .3s ease}.modal-input:focus{outline:none;border-color:var(--color-primary);background:#00d4d40d;box-shadow:0 0 0 4px #00d4d41a}.modal-input:hover:not(:focus){border-color:#00d4d47f}.modal-input::placeholder{color:var(--color-text-secondary);opacity:.6}.inventory-header{margin-bottom:var(--spacing-xl)}.inventory-header h2{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-lg)}.add-item-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-primary);color:var(--color-background);border:none;border-radius:var(--radius-md);font-size:var(--font-size-lg);font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.add-item-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00d4d44d}.add-item-btn:active{transform:translateY(0)}.sets-header{margin-bottom:var(--spacing-xl)}.sets-header h2{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-lg)}.add-set-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-primary);color:var(--color-background);border:none;border-radius:var(--radius-md);font-size:var(--font-size-lg);font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.add-set-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00d4d44d}.add-set-btn:active{transform:translateY(0)}.maintenance-container{width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-lg)}.maintenance-header{margin-bottom:var(--spacing-xl)}.maintenance-header h2{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-lg)}.add-maintenance-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-primary);color:var(--color-background);border:none;border-radius:var(--radius-md);font-size:var(--font-size-lg);font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.add-maintenance-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00d4d44d}.add-maintenance-btn:active{transform:translateY(0)}#maintenance-images{display:none}.maintenance-preview-img{max-width:80%;margin:8px}.sets-list{display:flex;flex-direction:column;gap:var(--spacing-xl)}.set-group{display:flex;flex-direction:column;gap:var(--spacing-md)}.items-list{display:flex;flex-direction:column;gap:var(--spacing-xl)}.item-group{display:flex;flex-direction:column;gap:var(--spacing-md)}.item-group-header{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid rgb(0 212 212 / 20%);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all var(--transition)}.post-stats span{display:flex;align-items:center;gap:var(--spacing-xs)}.debug-item span{display:block;font-size:var(--font-size-sm);color:var(--color-text-primary);word-break:normal;overflow-wrap:anywhere}.debug-info-item span{display:block;font-size:var(--font-size-sm);color:var(--color-text-primary);word-break:normal;overflow-wrap:anywhere;font-family:monospace}.test-debug-item span{font-size:13px;color:var(--color-text-primary);font-family:monospace;word-break:normal;overflow-wrap:anywhere}.item-group-header>span:nth-child(2){flex:1}.accordion-icon{font-size:var(--font-size-base);transition:transform .3s ease}.item-group-header .accordion-icon{margin-left:auto}.item-group-header:hover{color:var(--color-primary);border-bottom-color:#00d4d466}.category-icon{display:inline-flex;align-items:center;justify-content:center;font-size:24px;line-height:1;min-width:32px;min-height:32px}.item-cards-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.item-cards-grid.hidden{display:none!important}@media (width >= 768px){.item-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (width >= 1025px){.item-cards-grid{grid-template-columns:repeat(3,1fr)}}.item-card-wrapper{width:100%;transition:all var(--transition);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.item-card-wrapper:hover{transform:translateY(-2px);border-color:#00d4d47f;box-shadow:0 4px 12px #0000004d}.item-card{width:100%;display:flex;flex-direction:column;background-color:transparent;border:none;transition:all var(--transition)}.item-card:focus-visible{outline:none}.item-card-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background-color:var(--color-surface-alt)}.item-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.item-icon{font-size:24px}.item-details-header{display:flex;flex-direction:column;gap:2px;flex:1}.item-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.item-brand{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.item-details-section{padding:0;background-color:var(--color-surface);transition:all var(--transition)}.item-details-section.hidden{display:none!important}.item-card-body{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.item-toggle-details-btn{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);background-color:var(--color-surface);border:none;border-bottom:1px solid var(--color-border);color:var(--color-primary);font-size:var(--font-size-lg);cursor:pointer;transition:all var(--transition)}.item-toggle-details-btn:hover{background-color:var(--color-surface-alt)}.item-toggle-details-btn.active i{transform:rotate(-180deg)}.item-card-footer{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--color-surface);border-top:1px solid var(--color-border)}.item-action-btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:4px}.item-action-btn-primary{background-color:var(--color-primary);color:var(--color-background)}.item-action-btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00d4d433}.item-action-btn-danger{background-color:var(--color-surface);color:var(--color-danger);border:1px solid rgb(229 57 53 / 30%)}.item-action-btn-danger:hover{background-color:#e539351a;border-color:var(--color-danger)}.set-group-header{display:flex;align-items:center;justify-content:space-between;font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid rgb(0 212 212 / 20%);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all var(--transition)}.set-group-header:hover{color:var(--color-primary);border-bottom-color:#00d4d466}.set-cards-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.set-cards-grid.hidden{display:none!important}@media (width >= 768px){.set-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (width >= 1025px){.set-cards-grid{grid-template-columns:repeat(3,1fr)}}.set-item-card{width:100%;display:flex;flex-direction:column;transition:all var(--transition)}.set-item-card:hover{transform:translateY(-2px)}.set-card{width:100%;display:flex;flex-direction:column;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition)}.set-card:hover{border-color:#00d4d47f;box-shadow:0 4px 12px #0000004d}.set-card:focus-visible{outline:none}.set-card-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background-color:var(--color-surface-alt)}.set-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.set-icon{font-size:24px;min-width:32px;text-align:center}.set-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0}.set-type{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.set-card-body{padding:var(--spacing-md);flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.set-details-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.set-details-section.hidden{display:none!important}.set-articles-section,.set-catches-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.set-articles-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.cross-link,.set-article-item{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-primary);padding:var(--spacing-xs) var(--spacing-sm);margin:var(--spacing-xs) 0;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition)}.cross-link:before,.set-article-item:before{content:"→ ";color:var(--color-primary);font-weight:600}.cross-link:hover,.set-article-item:hover{background-color:#00d4d41a;color:var(--color-primary);padding-left:calc(var(--spacing-sm) + 4px)}.set-toggle-details-btn{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);background-color:var(--color-surface);border:none;border-bottom:1px solid var(--color-border);color:var(--color-primary);font-size:var(--font-size-lg);cursor:pointer;transition:all var(--transition)}.set-toggle-details-btn:hover{background-color:var(--color-surface-alt)}.set-toggle-details-btn [class*=fa-chevron],.catch-toggle-details-btn [class*=fa-chevron],.maintenance-toggle-details-btn [class*=fa-chevron]{transition:transform .3s ease}.set-toggle-details-btn.active [class*=fa-chevron],.catch-toggle-details-btn.active [class*=fa-chevron],.maintenance-toggle-details-btn.active [class*=fa-chevron]{transform:rotate(-180deg)}.set-card-footer{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--color-border);background-color:var(--color-surface-alt)}.set-action-btn{flex:1;min-width:60px;padding:6px 12px;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.set-action-btn-primary{background-color:var(--color-primary);color:var(--color-background)}.set-action-btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00d4d433}.set-action-btn-danger{background-color:var(--color-surface);color:var(--color-danger);border:1px solid rgb(229 57 53 / 30%)}.set-action-btn-danger:hover{background-color:#e539351a;border-color:var(--color-danger)}.maintenance-item-card{width:100%;display:flex;flex-direction:column}.maintenance-card{width:100%;display:flex;flex-direction:column;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition)}.maintenance-card:hover{border-color:#00d4d47f;box-shadow:0 4px 12px #0000004d;transform:translateY(-2px)}.maintenance-card-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.maintenance-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.maintenance-icon{font-size:24px;min-width:32px;text-align:center}.maintenance-details-header{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1}.maintenance-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0}.maintenance-date{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.maintenance-card-body{padding:var(--spacing-md);flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.maintenance-details-section{padding:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--spacing-md)}.maintenance-details-section.hidden{display:none!important}.maintenance-toggle-details-btn{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);background-color:var(--color-surface);border:none;border-bottom:1px solid var(--color-border);color:var(--color-primary);font-size:var(--font-size-lg);cursor:pointer;transition:all var(--transition)}.maintenance-toggle-details-btn:hover{background-color:var(--color-surface-alt)}.maintenance-card-footer{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--color-border);background-color:var(--color-surface-alt)}.maintenance-action-btn{flex:1;min-width:60px;padding:6px 12px;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.maintenance-action-btn-primary{background-color:var(--color-primary);color:var(--color-background)}.maintenance-action-btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00d4d433}.maintenance-action-btn-danger{background-color:var(--color-surface);color:var(--color-danger);border:1px solid rgb(229 57 53 / 30%)}.maintenance-action-btn-danger:hover{background-color:#e539351a;border-color:var(--color-danger)}.maintenance-list{display:flex;flex-direction:column;gap:var(--spacing-xl)}.maintenance-group{display:flex;flex-direction:column;gap:var(--spacing-md)}.maintenance-group-header{display:flex;align-items:center;justify-content:space-between;font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid rgb(0 212 212 / 20%);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all var(--transition)}.maintenance-group-header:hover{color:var(--color-primary);border-bottom-color:#00d4d466}.maintenance-cards-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.maintenance-cards-grid.hidden{display:none!important}@media (width >= 768px){.maintenance-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (width >= 1025px){.maintenance-cards-grid{grid-template-columns:repeat(3,1fr)}}.maintenance-item-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background-color:var(--color-surface-alt);transition:background-color var(--transition)}.maintenance-item-header:hover{background-color:#00d4d40d}.maintenance-item-details{padding:var(--spacing-md);flex:1;display:flex;flex-direction:column;gap:var(--spacing-md);animation:slide-down var(--transition) ease-out}.maintenance-item-details.hidden{display:none!important}.maintenance-item-details-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.back-to-categories-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);color:var(--color-primary);cursor:pointer;font-weight:500;transition:all var(--transition)}.back-to-categories-link:hover{gap:var(--spacing-lg)}.section-heading{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text-accent);margin-bottom:var(--spacing-md)}.loading-overlay{position:fixed;inset:0;background-color:var(--color-background);z-index:10000;display:flex;align-items:center;justify-content:center}.loading-overlay.hidden{display:none}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-surface);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.main-app-content-wrapper{min-height:100vh}.main-app-content-wrapper.hidden{display:none}.catches-view{padding:var(--spacing-lg);width:100%}.catches-view .view-header{margin-bottom:var(--spacing-lg)}.catches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg);width:100%}.catch-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition);display:flex;flex-direction:column}.catch-card:hover{border-color:#00d4d47f;box-shadow:0 4px 12px #0000004d;transform:translateY(-2px)}.catch-card-header{background-color:var(--color-surface-alt);padding:var(--spacing-md);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);border-bottom:1px solid var(--color-border)}.catch-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0}.catch-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.catch-card-body{padding:var(--spacing-md);flex:1}.catch-card-body p{margin:var(--spacing-xs) 0;font-size:var(--font-size-base);color:var(--color-text-primary)}.catch-card-body strong{color:var(--color-primary);font-weight:600}.catch-card-footer{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--color-border);background-color:var(--color-surface-alt)}.button-small{flex:1;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition)}.button-small:hover{background-color:#00d4d4cc}.button-small.button-danger{background-color:var(--color-danger)}.button-small.button-danger:hover{background-color:#e53935cc}.community-view{padding:var(--spacing-lg);width:100%}.community-view .view-header{text-align:center;margin-bottom:var(--spacing-2xl)}.view-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.view-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0}.community-sections{display:grid;gap:var(--spacing-2xl);max-width:800px;margin:0 auto}.community-section{border-radius:var(--radius-lg)}.section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0;display:flex;align-items:center;gap:var(--spacing-md)}.community-feed{display:flex;flex-direction:column;gap:var(--spacing-lg)}.community-post{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.post-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.post-author{display:flex;align-items:center;gap:var(--spacing-md)}.author-avatar{width:40px;height:40px;border-radius:50%;background-color:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm)}.author-info{display:flex;flex-direction:column}.author-name{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0}.post-time{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.post-menu-btn{background:none;border:none;font-size:var(--font-size-lg);color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-sm)}.post-content{padding:var(--spacing-md)}.post-content p{margin:0 0 var(--spacing-md) 0;color:var(--color-text-primary);font-size:var(--font-size-base)}.post-image{width:100%;height:auto;border-radius:var(--radius-md);margin-top:var(--spacing-md)}.post-stats{display:flex;gap:var(--spacing-lg);padding:var(--spacing-md);border-top:1px solid var(--color-border);background-color:#00000005;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.activity-list{display:flex;flex-direction:column;gap:var(--spacing-md);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.activity-item{display:flex;align-items:center;gap:var(--spacing-md);font-size:var(--font-size-base);color:var(--color-text-primary)}.activity-dot{font-size:6px;color:var(--color-primary)}.stats-grid-community{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-lg);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.stat-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:120px}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}.shop-view{padding:var(--spacing-lg);max-width:1200px;margin:0 auto}.shop-header{margin-bottom:var(--spacing-2xl)}.shop-header h1{font-size:var(--font-size-2xl);font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-primary)}.shop-header p{color:var(--color-text-secondary);font-size:var(--font-size-base)}.back-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--color-primary);margin-bottom:var(--spacing-lg);background:none;border:none;cursor:pointer;font-size:var(--font-size-base);transition:opacity var(--transition)}.back-button:hover{opacity:.8}.current-plan-status{padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-2xl);background-color:#00d4d414;border:1px solid rgb(0 212 212 / 20%)}.plan-name{font-weight:600;color:var(--color-primary)}.subscription-details{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-sm)}.status-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:9999px;font-size:var(--font-size-xs);font-weight:500;background-color:#22c55e33;color:#22c55e}.status-badge:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background-color:#22c55e}.premium-plans{margin-bottom:var(--spacing-2xl)}.premium-plans h2{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.plans-container{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg);width:100%;justify-content:center;max-width:1200px;margin:0 auto}.plans-carousel{width:100%;overflow:hidden;position:relative}.plans-carousel-track{display:flex;transition:transform .3s ease-out;touch-action:pan-x}.plans-carousel-slide{flex:0 0 100%;min-width:100%;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.plans-carousel-indicators{display:flex;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg) 0 var(--spacing-md);align-items:center}.plans-carousel-indicators .indicator{width:8px;height:8px;border-radius:50%;background-color:var(--color-border);border:none;cursor:pointer;transition:all .3s ease;padding:0}.plans-carousel-indicators .indicator[aria-current=true]{background-color:var(--color-primary);width:24px;border-radius:4px}.plan-card{display:flex;flex-direction:column;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition);position:relative;width:100%;height:100%}.plans-carousel-slide .plan-card{margin:0 auto}.plan-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.plan-card.current-plan{border-color:var(--color-primary);background-color:#00d4d40d}.popular-badge{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background-color:var(--color-primary);color:#fff;font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:9999px}.plan-header{margin-bottom:var(--spacing-md)}.plan-header h3{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.price{display:flex;align-items:baseline;gap:var(--spacing-xs)}.amount{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary)}.period{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.features-list{flex:1;list-style:none;padding:0;margin:var(--spacing-lg) 0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.features-list li{display:flex;align-items:flex-start;gap:var(--spacing-sm);font-size:var(--font-size-base);color:var(--color-text-primary)}.features-list li:before{content:"✓";color:var(--color-primary);font-weight:700;margin-top:2px}.plan-button{width:100%;padding:var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition);margin-top:var(--spacing-lg)}.plan-button.upgrade{background-color:var(--color-primary);color:#fff}.plan-button.upgrade:hover{opacity:.9;transform:translateY(-2px)}.plan-button.current{background-color:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:default}.feature-comparison{margin-bottom:var(--spacing-2xl);background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.feature-comparison h2{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-lg);color:var(--color-text-primary);padding:var(--spacing-lg) var(--spacing-lg) 0}.comparison-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.comparison-table{width:100%;border-collapse:collapse;background-color:var(--color-surface)}.comparison-table thead{background-color:#00d4d41a}.comparison-table th,.comparison-table td{font-size:var(--font-size-sm)}.comparison-table th{padding:var(--spacing-lg);text-align:center;font-weight:600;color:var(--color-text-primary);font-size:var(--font-size-sm);border-bottom:2px solid var(--color-primary)}.comparison-table th.feature-name-header{text-align:left}.comparison-table tbody tr,.mobile-features-table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color var(--transition)}.comparison-table tbody tr:hover{background-color:#00d4d40a}.comparison-table tbody tr.highlighted{background-color:#00d4d414}.comparison-table td{padding:var(--spacing-lg);text-align:center}.comparison-table td.feature-name{text-align:left;color:var(--color-text-primary)}.comparison-table td.plan-column{font-size:var(--font-size-base)}.included{color:#10b981;font-weight:600}.excluded{color:var(--color-text-secondary);font-weight:400}.comparison-cards{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-lg);width:100%;box-sizing:border-box}.features-carousel{width:100%;overflow:hidden;position:relative}.carousel-track{display:flex;transition:transform .3s ease-out;touch-action:pan-x}.carousel-slide{flex:0 0 100%;min-width:100%;padding:0;display:flex;flex-direction:column}.carousel-indicators{display:flex;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg) 0 var(--spacing-md);align-items:center}.carousel-indicators .indicator{width:8px;height:8px;border-radius:50%;background-color:var(--color-border);border:none;cursor:pointer;transition:all .3s ease;padding:0}.carousel-indicators .indicator[aria-current=true]{background-color:var(--color-primary);width:24px;border-radius:4px}@media (width < 768px){.comparison-table{font-size:var(--font-size-xs)}.comparison-table th,.comparison-table td{padding:var(--spacing-sm)}.comparison-table th.feature-name-header,.comparison-table td.feature-name{padding:var(--spacing-md)}.comparison-cards{display:block}}.payment-section{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-top:var(--spacing-2xl)}.payment-section h2{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.security-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.security-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;background-color:#00d4d41a;color:var(--color-primary)}.analytics-container{padding:var(--spacing-lg);max-width:1200px;margin:0 auto}.page-header{margin-bottom:var(--spacing-2xl);text-align:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.stat-table{width:100%;border-collapse:collapse;padding:var(--spacing-lg)}.stat-row{border-bottom:1px solid var(--color-border)}.stat-row:last-child{border-bottom:none}.stat-icon{width:40px;padding:var(--spacing-md);color:var(--color-primary);font-size:var(--font-size-lg);text-align:center}.stat-label{padding:var(--spacing-md);color:var(--color-text-secondary);font-weight:500;font-size:var(--font-size-sm);min-width:150px}.stat-number{padding:var(--spacing-md);color:var(--color-primary);font-weight:700;font-size:var(--font-size-base);text-align:right;flex:1}.clickable-stat{cursor:pointer;transition:background-color var(--transition)}.clickable-stat:hover{background-color:var(--color-surface-alt)}.pb-toggle-row{-webkit-user-select:none;user-select:none}.pb-toggle-icon{transition:transform var(--transition)}.pb-details-row{display:none}.pb-details-row.show{display:table-row}.pb-details{display:table-row-group}.pb-details.hidden{display:none}.pb-detail-item:hover{background-color:var(--color-surface-alt)}.pb-detail-item .stat-icon,.pb-detail-item .stat-label,.pb-detail-item .stat-number{padding:var(--spacing-md)}.pb-detail-item .stat-icon{color:var(--color-text-secondary)}.pb-detail-item .stat-label{color:var(--color-text-primary);font-weight:400;padding-left:var(--spacing-xl)}.pb-detail-item .stat-number{color:var(--color-text-secondary)}@media (width < 768px){.stats-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}.stat-table{padding:var(--spacing-md);font-size:var(--font-size-sm)}.stat-icon{width:30px;padding:var(--spacing-sm)}.stat-label{padding:var(--spacing-sm);min-width:auto;font-size:var(--font-size-xs)}.stat-number{padding:var(--spacing-sm);font-size:var(--font-size-sm)}}@media (768px <= width < 1024px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}}.page-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;gap:var(--spacing-md)}.stat-description{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.analytics-section{margin-bottom:var(--spacing-2xl)}.catch-map-container{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.catch-analytics-map{width:100%;height:400px;position:relative;background-color:var(--color-background);z-index:1}.map-legend{background-color:var(--color-surface);padding:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-primary)}.legend-color{width:12px;height:12px;border-radius:50%}.legend-color.recent{background-color:var(--color-primary)}.legend-color.older{background-color:var(--color-text-secondary)}.location-item{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-md);transition:all var(--transition)}.location-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.location-rank{width:40px;height:40px;background-color:#00d4d41a;color:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.location-name{font-weight:600;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.location-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.no-data-message{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-secondary);font-size:var(--font-size-base)}.desktop-only{display:none}.mobile-only{display:block}@media (width >= 1024px){.desktop-only{display:flex}.mobile-only{display:none}}.mobile-features-table{width:100%;border-collapse:collapse;background-color:var(--color-surface);border:1px solid var(--color-border);overflow:hidden}.mobile-features-table thead{background-color:#00d4d41a}.mobile-features-table th{padding:var(--spacing-sm) 4px;text-align:center;font-weight:600;color:var(--color-text-primary);font-size:var(--font-size-xs);border-bottom:1px solid var(--color-border);white-space:nowrap;width:33.333%}.mobile-features-table th:first-child{text-align:center}.mobile-features-table tbody tr:hover{background-color:#00d4d40a}.mobile-features-table tbody tr.highlighted{background-color:#00d4d414}.mobile-features-table td{padding:var(--spacing-sm) 4px;text-align:center;font-size:var(--font-size-xs);width:33.333%}.mobile-feature-name-row{background-color:var(--color-surface)}.mobile-feature-name-row.highlighted{background-color:#00d4d414}.feature-name-full{color:var(--color-text-primary);font-weight:600;font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);overflow-wrap:break-word;display:table-cell;width:100%}.mobile-feature-support-row{background-color:var(--color-background);border-top:1px solid var(--color-border)}.mobile-feature-support-row.highlighted{background-color:#00d4d40a}.mobile-features-table td.feature-support{font-size:var(--font-size-lg)}.settings-container{width:100%;max-width:1000px;margin:0 auto;padding:var(--spacing-lg)}.settings-header{margin-bottom:var(--spacing-xl)}.settings-header h2{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.settings-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.settings-section{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);transition:all var(--transition)}.settings-section:hover{border-color:#00d4d44d;box-shadow:0 0 12px #00d4d40d}.settings-section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.location-info{padding:var(--spacing-md);background:#00d4d40d;border-radius:var(--radius-md);border:1px solid var(--color-border);margin-top:var(--spacing-sm)}.location-name-display{font-size:var(--font-size-base);color:var(--color-primary);font-weight:600;margin-bottom:var(--spacing-xs)}.coordinates-display{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-family:monospace}.map-container{width:100%;height:400px;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--color-border);margin-bottom:var(--spacing-md)}.location-map{width:100%;height:100%;min-height:400px;background-color:var(--color-surface-alt);z-index:1}.map-instructions{padding:var(--spacing-md);background:#00d4d40d;border-radius:var(--radius-sm);margin-top:var(--spacing-sm)}.map-instructions p{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.map-picker-content{padding:var(--spacing-lg)}@media (width <= 767px){.map-container,.location-map{height:300px;min-height:300px}}.user-info{background-color:var(--color-surface-alt);padding:var(--spacing-md);border-radius:var(--radius-sm);margin-bottom:var(--spacing-lg)}.user-status{font-size:var(--font-size-base);color:var(--color-text-primary);word-break:break-all}.settings-button-group{display:flex;flex-direction:column;gap:var(--spacing-md)}.btn{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn.is-loading,.button-secondary.is-loading{opacity:.8;cursor:wait;pointer-events:none}.btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--color-primary);border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;margin-right:.5rem}@keyframes btn-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.w-full{width:100%}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.legal-links-list{list-style:none;padding:0;margin:0}.legal-links-list li{margin-bottom:var(--spacing-md)}.legal-content li{margin:0 0 var(--spacing-sm) 0;margin-bottom:var(--spacing-xs);color:var(--color-text-primary)}.legal-links-list li:last-child{margin-bottom:0}.legal-link{display:inline-block;padding:var(--spacing-sm);color:var(--color-primary);text-decoration:none;font-weight:500;transition:all var(--transition)}.legal-link:hover{color:var(--color-accent);text-decoration:underline}.acknowledgments-text{color:var(--color-text-secondary);line-height:1.8}.acknowledgments-text p{margin-bottom:var(--spacing-md)}.acknowledgments-item{background-color:var(--color-surface-alt);padding:var(--spacing-md);border-radius:var(--radius-sm);margin-top:var(--spacing-md)}.acknowledgments-item h4{color:var(--color-primary);font-size:var(--font-size-base);margin-bottom:var(--spacing-sm)}.acknowledgments-item p{margin-bottom:0;font-size:var(--font-size-sm)}.devtools-warning{background-color:#ffc1071a;border:1px solid rgb(255 193 7 / 30%);border-radius:var(--radius-sm);padding:var(--spacing-md);color:var(--color-text-primary);font-size:var(--font-size-sm);line-height:1.6}.devtools-warning strong{color:var(--color-warning)}@media (width < 768px){.settings-container,.settings-section{padding:var(--spacing-md)}.btn{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base)}}.catches-container{width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-lg)}.catches-header{margin-bottom:var(--spacing-xl)}.catches-header h2{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-lg)}.add-catch-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-primary);color:var(--color-background);border:none;border-radius:var(--radius-md);font-size:var(--font-size-lg);font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.add-catch-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00d4d44d}.add-catch-btn:active{transform:translateY(0)}.catches-list{display:flex;flex-direction:column;gap:var(--spacing-xl)}.catch-group{display:flex;flex-direction:column;gap:var(--spacing-md)}.catch-group-header{display:flex;align-items:center;justify-content:space-between;font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid rgb(0 212 212 / 20%);margin-bottom:var(--spacing-sm)}.accordion-icon.rotate-90{transform:rotate(90deg)}.catch-cards-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.catch-cards-grid.hidden{display:none!important}@media (width >= 768px){.catch-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (width >= 1025px){.catch-cards-grid{grid-template-columns:repeat(3,1fr)}}.catch-fish-info{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.catch-fish-icon{font-size:24px;min-width:32px;text-align:center}.catch-fish-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0}.catch-weather{font-size:var(--font-size-lg);min-width:2rem;text-align:center;white-space:nowrap}.catch-stats{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-wrap:wrap}.catch-stat{display:flex;flex-direction:column;gap:2px}.catch-stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.catch-stat-value{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary)}.catch-location{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.catch-location-icon{font-size:14px}.catch-details{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6}.catch-detail-item{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.catch-detail-label{font-weight:500;color:var(--color-text-secondary);min-width:50px}.catch-detail-value{color:var(--color-text-primary);overflow-wrap:break-word}.catch-details-section{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md) 0;border-top:1px solid var(--color-border);margin-top:var(--spacing-md)}.catch-details-section.hidden{display:none!important}.catch-toggle-details-btn{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);background-color:var(--color-surface);border:none;border-bottom:1px solid var(--color-border);color:var(--color-primary);font-size:var(--font-size-lg);cursor:pointer;transition:all var(--transition)}.catch-toggle-details-btn:hover{background-color:var(--color-surface-alt)}.catch-toggle-details-btn.active [class*=fa-chevron]{transform:rotate(-180deg)}.catch-action-btn{flex:1;min-width:60px;padding:6px 12px;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.catch-action-btn-primary{background-color:var(--color-primary);color:var(--color-background)}.catch-action-btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00d4d433}.catch-action-btn-secondary{background-color:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.catch-action-btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.catch-action-btn-danger{background-color:var(--color-surface);color:var(--color-danger);border:1px solid rgb(229 57 53 / 30%)}.catch-action-btn-danger:hover{background-color:#e539351a;border-color:var(--color-danger)}.catches-empty{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-secondary)}.catches-empty-icon{font-size:48px;margin-bottom:var(--spacing-lg);opacity:.5}.catches-empty-text{font-size:var(--font-size-base);line-height:1.6}@media (width < 768px){.catches-container{padding:var(--spacing-md)}.catch-card-header,.catch-card-body{padding:var(--spacing-sm) var(--spacing-md)}.catch-stats{gap:var(--spacing-sm)}.catch-card-footer{padding:var(--spacing-sm) var(--spacing-md);gap:4px}.catch-action-btn{padding:5px 10px;font-size:var(--font-size-xs)}.catch-fish-name,.catch-stat-value{font-size:var(--font-size-base)}}body.water-mode .header,body.water-mode .bottom-nav,body.water-mode .top-nav,body.water-mode .sidebar,body.water-mode #view-content{display:none}body.water-mode{padding:0;margin:0;overflow:hidden;touch-action:pan-x pan-y}.water-mode-overlay{position:fixed;inset:0;background-color:var(--color-background);z-index:var(--z-water-mode);display:none;flex-direction:column;touch-action:pan-x pan-y}body.water-mode .water-mode-overlay{display:flex}.water-mode-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background-color:#1e1e1ef2;min-height:60px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border)}.water-mode-close{display:flex;align-items:center;gap:var(--spacing-sm);background:none;border:none;color:var(--color-text-primary);cursor:pointer;font-size:var(--font-size-base);padding:var(--spacing-sm);min-height:44px;min-width:44px;transition:color var(--transition)}.water-mode-close:hover,.water-mode-close:focus{color:var(--color-danger);outline:2px solid var(--color-danger);border-radius:var(--radius-sm)}.water-mode-close span:first-child{font-size:24px}.water-mode-timer{font-size:var(--font-size-xl);font-weight:600;color:var(--color-primary);font-variant-numeric:tabular-nums;letter-spacing:.5px}.water-mode-pause{background:none;border:none;color:var(--color-text-primary);cursor:pointer;font-size:24px;padding:var(--spacing-sm);min-height:44px;min-width:44px;transition:transform var(--transition)}.water-mode-pause:hover,.water-mode-pause:focus{transform:scale(1.1);outline:2px solid var(--color-primary);border-radius:var(--radius-sm)}.water-mode-content{flex:1;padding:var(--spacing-lg);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.water-primary-action{background:linear-gradient(135deg,var(--color-accent) 0%,#ff7a1a 100%);border:none;border-radius:var(--radius-lg);padding:var(--spacing-xl);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);cursor:pointer;min-height:200px;transition:all var(--transition);box-shadow:var(--shadow-lg);color:#fff;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.water-primary-action:hover,.water-primary-action:focus{transform:translateY(-4px);box-shadow:0 12px 32px #ff670066}.water-primary-action:active{transform:translateY(-2px)}.water-primary-icon{font-size:64px;line-height:1}.water-primary-label{font-size:var(--font-size-2xl);font-weight:600;text-transform:uppercase;letter-spacing:1px}.water-secondary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.water-mini-map-container{position:relative;width:100%;height:400px;min-height:400px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border);background-color:var(--color-surface)}.water-mini-map{width:100%;height:100%}.water-mini-map-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);z-index:1000;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:var(--color-text-primary);transition:all var(--transition)}.water-mini-map-close:hover{background-color:var(--color-danger);color:#fff;border-color:var(--color-danger)}.water-mode-set-modal-overlay{position:fixed;inset:0;background-color:#000c;z-index:10001;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.water-mode-set-modal{background-color:var(--color-surface);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 10px 40px #0000007f}.water-mode-set-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.water-mode-set-modal-header h2{margin:0;font-size:var(--font-size-xl);color:var(--color-text-primary)}.water-mode-set-modal-close{background:none;border:none;font-size:24px;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color var(--transition)}.water-mode-set-modal-close:hover{color:var(--color-danger)}.water-mode-set-modal-content{padding:var(--spacing-lg);overflow-y:auto;flex:1}.water-mode-set-modal-description{margin-bottom:var(--spacing-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.water-mode-set-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.water-mode-set-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition)}.water-mode-set-option:hover{border-color:var(--color-primary);background-color:var(--color-surface-alt)}.water-mode-set-option input[type=radio]{width:20px;height:20px;cursor:pointer;accent-color:var(--color-primary)}.water-mode-set-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.water-mode-set-option input[type=radio]:checked~.water-mode-set-info{color:var(--color-primary)}.water-mode-set-icon{font-size:32px;min-width:40px;text-align:center}.water-mode-set-details{flex:1}.water-mode-set-name{font-weight:600;font-size:var(--font-size-base);color:var(--color-text-primary);margin-bottom:2px}.water-mode-set-items{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.water-mode-set-modal-footer{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.water-mode-set-modal-footer .btn{flex:1;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);font-weight:600}.water-mode-summary-overlay{position:fixed;inset:0;background-color:#000c;z-index:10002;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.water-mode-summary-modal{background-color:var(--color-surface);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 10px 40px #0000007f}.water-mode-summary-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.water-mode-summary-header h2{margin:0;font-size:var(--font-size-xl);color:var(--color-text-primary);text-align:center}.water-mode-summary-content{padding:var(--spacing-lg);overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.water-mode-summary-stat{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background-color:var(--color-background);border-radius:var(--radius-md);border:1px solid var(--color-border)}.water-mode-summary-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.water-mode-summary-value{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:600}.water-mode-summary-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;justify-content:center}.water-mode-summary-footer .btn{min-width:150px;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);font-weight:600}.water-mode-bait-modal-overlay{position:fixed;inset:0;background-color:#000c;z-index:10001;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.water-mode-bait-modal{background-color:var(--color-surface);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.water-mode-bait-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.water-mode-bait-modal-header h2{margin:0;font-size:var(--font-size-xl);color:var(--color-text-primary)}.water-mode-bait-modal-close{background:none;border:none;font-size:24px;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition)}.water-mode-bait-modal-close:hover{color:var(--color-danger);background-color:var(--color-background)}.water-mode-bait-modal-content{padding:var(--spacing-lg);overflow-y:auto;flex:1}.water-mode-bait-quick-add{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.water-mode-bait-quick-add .btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.water-mode-bait-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.water-mode-bait-item{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition);text-align:left;width:100%}.water-mode-bait-item:hover{background-color:var(--color-surface-alt);border-color:var(--color-primary)}.water-mode-bait-item.selected{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-background)}.water-mode-bait-item-name{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.water-mode-bait-item.selected .water-mode-bait-item-name{color:var(--color-background)}.water-mode-bait-item-brand{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.water-mode-bait-item.selected .water-mode-bait-item-brand{color:#000000b3}.water-mode-bait-empty{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.water-mode-bait-modal-footer{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.water-mode-bait-modal-footer .btn{flex:1;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);font-weight:600}.water-secondary-action{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);cursor:pointer;min-height:120px;transition:all var(--transition);color:var(--color-text-primary);position:relative;z-index:1;pointer-events:auto;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.water-secondary-action:hover,.water-secondary-action:focus{background-color:var(--color-surface-alt);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.water-secondary-action:disabled,.water-secondary-action.disabled{opacity:.5!important;cursor:not-allowed!important;pointer-events:none!important;background-color:var(--color-background);border-color:var(--color-border)}.water-secondary-action:disabled:hover,.water-secondary-action.disabled:hover,.water-secondary-action:disabled:focus,.water-secondary-action.disabled:focus{transform:none;box-shadow:none;background-color:var(--color-background);border-color:var(--color-border)}.water-secondary-detail{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.water-secondary-action:disabled .water-secondary-detail,.water-secondary-action.disabled .water-secondary-detail{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.water-secondary-icon{font-size:36px;line-height:1}.water-secondary-label{font-size:var(--font-size-lg);font-weight:600;text-align:center}.water-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);padding:var(--spacing-lg);background-color:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.water-stat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-xs)}.water-stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);line-height:1.2}.water-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}@media (width < 768px){.water-mode-content{padding:var(--spacing-md)}.water-primary-action{min-height:160px;padding:var(--spacing-lg);-webkit-tap-highlight-color:rgb(255 255 255 / 10%)}.water-primary-action:active{transform:scale(.98)}.water-primary-icon{font-size:48px}.water-primary-label{font-size:var(--font-size-xl)}.water-secondary-action{min-height:100px;padding:var(--spacing-md);min-width:44px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.water-secondary-action:disabled,.water-secondary-action.disabled{opacity:.4!important}.water-secondary-icon{font-size:28px}.water-secondary-label{font-size:var(--font-size-base)}.water-secondary-detail{font-size:var(--font-size-xs);word-break:normal;overflow-wrap:anywhere;-webkit-hyphens:auto;hyphens:auto}.water-stats{grid-template-columns:1fr;gap:var(--spacing-sm);padding:var(--spacing-md)}.water-stat{flex-direction:row;justify-content:space-between}.water-stat-value{font-size:var(--font-size-lg)}#water-mini-map-container,.water-mini-map-container{touch-action:manipulation;height:60vh;min-height:400px;max-height:70vh}.water-mini-map-close{width:44px;height:44px;min-width:44px;min-height:44px;font-size:22px;top:var(--spacing-xs);right:var(--spacing-xs);-webkit-tap-highlight-color:rgb(0 0 0 / 10%)}.water-mini-map-close:active{transform:scale(.95)}.water-mode-set-modal-overlay{padding:var(--spacing-md)}.water-mode-set-modal{max-width:100%;max-height:90vh;border-radius:var(--radius-md)}.water-mode-set-modal-header{padding:var(--spacing-md)}.water-mode-set-modal-header h2{font-size:var(--font-size-lg)}.water-mode-set-modal-close{width:44px;height:44px;min-width:44px;min-height:44px;font-size:22px;-webkit-tap-highlight-color:rgb(0 0 0 / 10%)}.water-mode-set-modal-close:active{transform:scale(.95)}.water-mode-set-modal-content{padding:var(--spacing-md)}.water-mode-set-option{padding:var(--spacing-md);min-height:60px;-webkit-tap-highlight-color:rgb(0 0 0 / 5%)}.water-mode-set-option:active{transform:scale(.98)}.water-mode-set-icon{font-size:28px;min-width:36px}.water-mode-set-modal-footer{padding:var(--spacing-md);flex-direction:column;gap:var(--spacing-sm)}.water-mode-set-modal-footer .btn{width:100%;min-height:44px;padding:var(--spacing-md)}}@media (width >= 1024px){.water-mode-content{max-width:1200px;margin:0 auto}.water-secondary-grid{grid-template-columns:repeat(4,1fr)}}.water-mode-hotspot-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10002!important;pointer-events:auto}.water-mode-hotspot-modal{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl);width:100%;max-width:500px;box-shadow:var(--shadow-xl);z-index:10003!important;position:relative;pointer-events:auto}.water-mode-hotspot-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.water-mode-hotspot-modal-header h2{margin:0;color:var(--color-text-primary);font-size:var(--font-size-xl)}.water-mode-hotspot-modal-close{background:none;border:none;font-size:24px;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-xs);line-height:1}.water-mode-hotspot-modal-close:hover{color:var(--color-text-primary)}.water-mode-hotspot-modal-content{margin-bottom:var(--spacing-lg)}.water-mode-hotspot-info{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.water-mode-hotspot-input{width:100%;padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-background);color:var(--color-text-primary);font-size:var(--font-size-base)}.water-mode-hotspot-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgb(var(--color-primary-rgb),.2)}.water-mode-hotspot-modal-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end}@media (width < 768px){.water-mode-hotspot-modal{padding:var(--spacing-lg);max-width:95%;margin:var(--spacing-md);max-height:90vh;overflow-y:auto}.water-mode-hotspot-modal-header{margin-bottom:var(--spacing-md)}.water-mode-hotspot-modal-header h2{font-size:var(--font-size-lg)}.water-mode-hotspot-modal-close{font-size:20px;padding:var(--spacing-sm);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.water-mode-hotspot-modal-content{margin-bottom:var(--spacing-md)}.water-mode-hotspot-info{font-size:var(--font-size-xs);margin-bottom:var(--spacing-sm);word-break:normal;overflow-wrap:anywhere}.water-mode-hotspot-input{padding:var(--spacing-md);font-size:var(--font-size-base);min-height:44px}.water-mode-hotspot-modal-footer{flex-direction:column-reverse;gap:var(--spacing-sm)}.water-mode-hotspot-modal-footer .btn{width:100%;min-height:44px;padding:var(--spacing-md);font-size:var(--font-size-base)}}@media (width >= 768px) and (width < 1024px){.water-mode-hotspot-modal{padding:var(--spacing-xl);max-width:85%}}footer.footer{background-color:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--spacing-lg) var(--spacing-md);margin-top:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-md);align-items:center;text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.footer-links{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.footer-links a,.legal-content a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}.footer-links a:hover{color:var(--color-accent);text-decoration:underline}.footer-divider{color:var(--color-text-secondary);display:inline-block}.footer-copyright{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.footer-copyright p{margin:0;padding:0}@media (width >= 768px){footer.footer{padding:var(--spacing-xl) var(--spacing-lg);gap:var(--spacing-lg)}.footer-links{gap:var(--spacing-md)}}.privacy-info-block{background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.privacy-info-block h4{margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-lg);color:var(--color-text-accent);font-weight:600}.privacy-description{margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.5}.privacy-feature{display:flex;gap:var(--spacing-md);align-items:flex-start;padding:var(--spacing-md);background-color:var(--color-surface);border-radius:var(--radius-sm);border-left:3px solid var(--color-primary);transition:all .2s ease}.privacy-feature:hover{background-color:#ffffff08;transform:translate(4px)}.privacy-feature-icon{font-size:var(--font-size-xl);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px}.privacy-feature-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.privacy-feature-content strong{font-size:var(--font-size-base);color:var(--color-text-accent);font-weight:600}.privacy-feature-content p{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.4}.legal-container{width:100%;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;min-height:calc(100vh - 200px)}.legal-wrapper{flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-lg)}.legal-header{display:flex;flex-direction:column;gap:var(--spacing-md);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-lg)}.legal-back-btn{display:inline-flex;align-items:center;width:fit-content;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-primary);text-decoration:none;font-size:var(--font-size-base);cursor:pointer;transition:all .2s ease}.legal-back-btn:hover{background-color:var(--color-surface-alt);border-color:var(--color-primary);transform:translate(-2px)}.legal-title{margin:0;font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-accent)}.legal-meta{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.legal-updated-label{color:var(--color-text-secondary)}.legal-updated-date{color:var(--color-text-secondary);font-weight:500}.legal-content{flex:1;font-size:var(--font-size-base);line-height:1.8;color:var(--color-text-primary);padding:var(--spacing-md)}.legal-content h2{margin:var(--spacing-xl) 0 var(--spacing-md) 0;font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text-accent);padding-top:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.debug-section h2{margin:0 0 var(--spacing-lg) 0;font-size:var(--font-size-lg);color:var(--color-text-primary);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-md)}.test-danger-zone h2{color:#ff4757}.test-card h2{margin:0;font-size:18px;font-weight:700;color:var(--color-text-primary);display:flex;align-items:center;gap:8px}.legal-content h2:first-child{margin-top:0}.legal-content h3{margin:var(--spacing-lg) 0 var(--spacing-sm) 0;font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-accent)}.legal-content h4{margin:var(--spacing-md) 0 var(--spacing-xs) 0;font-size:var(--font-size-base);font-weight:600;color:var(--color-text-accent)}.legal-content p{margin:0 0 var(--spacing-md) 0;line-height:1.8;color:var(--color-text-primary)}.legal-content strong{color:var(--color-text-accent);font-weight:600}.legal-content ul,.legal-content ol{margin:var(--spacing-sm) 0 var(--spacing-md) 0;padding-left:var(--spacing-xl);line-height:1.8}.legal-content a:hover{color:var(--color-accent);text-decoration:underline}.legal-content hr{margin:var(--spacing-lg) 0;border:none;border-top:1px solid var(--color-border)}.legal-footer{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.legal-footer-text{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.legal-footer-links{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.legal-footer-link{color:var(--color-primary);text-decoration:none;font-size:var(--font-size-base);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);transition:all .2s ease}.legal-footer-link:hover{background-color:#00d4d41a;color:var(--color-accent);text-decoration:underline}.legal-footer-separator{color:var(--color-text-secondary)}.login-card{background:var(--color-surface);box-shadow:var(--shadow-lg);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:2.5rem 2rem 2rem;margin:2rem auto;max-width:420px;width:100%;display:flex;flex-direction:column;align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.login-logo{width:120px;height:120px;margin:0 auto 1.5rem;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);padding:8px;overflow:hidden;animation:logo-float 3s ease-in-out infinite}.logo-image{width:100%;height:100%;object-fit:contain;object-position:center;border-radius:50%}.login-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-accent);text-align:center;margin-bottom:.25rem;letter-spacing:.02em}.login-slogan{font-size:var(--font-size-base);color:var(--color-text-secondary);text-align:center;margin-bottom:2rem;font-weight:400;letter-spacing:.01em}.tab-switcher{display:flex;background:var(--color-background);border-radius:var(--radius-md);padding:4px;margin-bottom:2rem;width:100%;gap:4px;border:1px solid var(--color-border)}.tab-btn{flex:1;background:transparent;border:none;outline:none;font-weight:600;font-size:var(--font-size-base);color:var(--color-text-secondary);padding:.75rem 1rem;border-radius:var(--radius-sm);transition:all var(--transition);cursor:pointer;position:relative}.tab-btn:hover{color:var(--color-text-primary);background:var(--color-surface-alt)}.tab-btn.nav-link-active{color:var(--color-text-accent);background:var(--color-primary);font-weight:700;box-shadow:0 2px 8px #00d4d440}.form-input{font-family:inherit;font-size:var(--font-size-base);padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg);color:var(--color-text-primary);transition:all var(--transition)}.login-card .form-input{background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text-primary);border-radius:var(--radius-sm);padding:.85rem 1rem;font-size:var(--font-size-base);margin-bottom:.5rem;width:100%}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #00d4d41a;background-color:var(--color-surface)}.login-card .form-input:focus{border-color:var(--color-primary);background:var(--color-background);outline:none;box-shadow:0 0 0 3px #00d4d41a;transform:scale(1.01);transition:all var(--transition)}.login-card .button-primary,.login-card .button-secondary{font-size:var(--font-size-base);padding:.85rem 1rem;border-radius:var(--radius-sm);margin-top:.5rem;transition:all var(--transition)}.login-card .button-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-lg);border:none;transition:all var(--transition)}.login-card .button-primary:hover{background:var(--color-primary-hover, #00b8b8);box-shadow:var(--shadow-xl);transform:translateY(-2px)}.login-card .button-secondary{background:var(--color-surface-alt);color:var(--color-primary);border:1px solid var(--color-primary)}.login-card .button-secondary:hover{background:var(--color-primary);color:#fff}.login-card .button-secondary svg{margin-right:.5rem}.login-divider{display:flex;align-items:center;width:100%;margin:1.5rem 0 1rem}.login-divider-line{flex:1;height:1px;background-color:var(--color-border);border:none}.login-divider-text{padding:0 1rem;font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.button-link{background:transparent;border:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);padding:.5rem;cursor:pointer;transition:color var(--transition)}.button-link:hover{color:var(--color-primary);text-decoration:underline}.login-card .message-display{margin-bottom:1rem;width:100%;text-align:center}.login-card .button-secondary.is-loading{opacity:.7;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes logo-float{0%{transform:translateY(0)}50%{transform:translateY(-8px)}to{transform:translateY(0)}}.splash-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--color-background) 0%,var(--color-surface) 50%,var(--color-background) 100%);display:flex;align-items:center;justify-content:center;z-index:2500;overflow:hidden}.splash-container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;width:100%;max-width:500px;padding:2rem}.splash-title-container{margin-bottom:1.5rem;overflow:hidden;width:100%;order:1}.splash-title{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-accent);margin:0;transform:translate(-100%);opacity:0;animation-delay:.5s;animation-fill-mode:forwards}.splash-title.animate-title{animation:splash-slide-in-fromleft .8s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes splash-slide-in-fromleft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.splash-logo-container{position:relative;margin:1.5rem 0;perspective:1000px;order:2}.splash-logo{width:128px;height:128px;border-radius:50%;background:var(--color-primary);padding:8px;box-shadow:0 0 40px #00d4d44d;transform:scale(0);opacity:0;animation-delay:1s;animation-fill-mode:forwards}.splash-logo.animate-logo{animation:splash-logo-grow 1.2s cubic-bezier(.34,1.56,.64,1) forwards,splash-logo-pulse 2s ease-in-out 2.5s 3,splash-logo-glow 2s ease-in-out infinite alternate 1.5s}@keyframes splash-logo-grow{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes splash-logo-pulse{0%{transform:scale(1)}50%{transform:scale(.78)}to{transform:scale(1)}}@keyframes splash-logo-glow{0%{box-shadow:0 0 40px #00d4d44d}to{box-shadow:0 0 60px #00d4d47f}}.splash-slogan-container{margin-bottom:2rem;overflow:hidden;width:100%;order:3}.splash-slogan{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin:0;font-weight:400;transform:translate(100%);opacity:0;animation-delay:1.8s;animation-fill-mode:forwards}.splash-slogan.animate-slogan{animation:splash-slide-in-from-right .8s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes splash-slide-in-from-right{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.fishing-scene-container{position:relative;width:90%;max-width:400px;height:200px;background:transparent;border-radius:var(--radius-lg);box-shadow:none;overflow:hidden;display:flex;justify-content:center;align-items:flex-end;margin-top:1rem;order:4;opacity:0;animation:splash-fade-in .8s ease-in-out 1.5s forwards}.water{position:absolute;bottom:0;left:0;width:100%;height:40%;background:transparent;border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);opacity:0}.animation-area{position:absolute;top:0;left:0;width:100%;height:100%}.fishing-rod-wrapper{position:absolute;right:15%;transform-origin:bottom center;transform:scaleX(-1);transition:transform .3s ease-out;z-index:10}.fishing-rod{position:relative;height:120px;width:8px;transform-origin:bottom center}.rod-segment{position:absolute;left:50%;transform:translate(-50%);background:linear-gradient(to bottom,var(--color-text-primary),var(--color-text-secondary));box-shadow:1px 1px 3px #0003;border-radius:2px 2px 0 0}.rod-segment-1{bottom:0;height:24px;width:8px;border-radius:4px 4px 0 0}.rod-segment-2{bottom:22px;height:24px;width:6px}.rod-segment-3{bottom:44px;height:24px;width:5px}.rod-segment-4{bottom:66px;height:24px;width:3px}.rod-segment-5{bottom:88px;height:24px;width:2px}.rod-tip{position:absolute;bottom:110px;left:50%;transform:translate(-50%);width:1px;height:36px;background-color:var(--color-text-secondary);border-radius:.5px .5px 0 0;transform-origin:bottom center;box-shadow:.5px .5px 2px #0000001a}.reel{position:absolute;bottom:12px;left:-15px;width:20px;height:20px;background:linear-gradient(to bottom,var(--color-text-secondary),var(--color-text-primary));border-radius:50%;box-shadow:0 2px 4px #0000004d;overflow:hidden}.reel:before{content:"";position:absolute;top:4px;left:4px;width:12px;height:12px;background:linear-gradient(to bottom,var(--color-accent),var(--color-primary));border-radius:50%;box-shadow:inset 0 0 3px #0000007f}.reel:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:3px;height:100%;background-color:var(--color-text-secondary);box-shadow:1px 0 2px #0000004d}.crank-base{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:4px;background-color:var(--color-accent);border-radius:50%;z-index:2;box-shadow:0 0 2px #fff3}.crank{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;transform-origin:center center;z-index:1}.crank-arm{position:absolute;top:50%;left:50%;width:12px;height:2px;background:linear-gradient(to right,var(--color-accent),var(--color-text-secondary));border-radius:1px;transform-origin:left center;transform:translateY(-50%) rotate(45deg);box-shadow:1px 1px 2px #0003}.handle{position:absolute;width:6px;height:12px;background:linear-gradient(to bottom,var(--color-accent),var(--color-text-secondary));border-radius:3px;top:50%;left:100%;transform:translate(-50%,-50%);transform-origin:center;box-shadow:inset 0 0 2px #0000004d}.fishing-line-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5}#fishing-line{stroke:var(--color-text-primary);stroke-width:1.5;fill:none;opacity:.8}.lure{position:absolute;width:8px;height:8px;background-color:var(--color-accent);border-radius:50%;box-shadow:0 0 4px var(--color-accent);z-index:6;transform:translate(-50%,-50%)}.loading-bar-container{position:absolute;background-color:#00000026;border-radius:var(--radius-sm);overflow:hidden;opacity:1;transition:opacity .3s ease-in-out;z-index:7;display:flex;align-items:center;justify-content:center;height:6px}.loading-bar-fill{height:100%;width:0%;background-color:var(--color-success);border-radius:var(--radius-sm);transition:width .1s linear;position:absolute;left:0;top:0}.loading-bar-percentage{position:absolute;color:var(--color-text-primary);font-size:.6em;font-weight:700;text-shadow:1px 1px 2px rgb(0 0 0 / 50%);z-index:2}@keyframes splash-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width >= 768px){.legal-wrapper{padding:var(--spacing-xl) var(--spacing-xl)}.legal-title{font-size:var(--font-size-3xl)}.legal-content{font-size:var(--font-size-base);line-height:1.9}.legal-content h2{margin-top:var(--spacing-xl)}}.leaflet-container{touch-action:manipulation!important}.debug-view{padding:var(--spacing-lg);background-color:var(--color-background);min-height:100vh;font-family:monospace}.debug-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border)}.debug-header h1{flex:1;margin:0;font-size:var(--font-size-2xl);color:var(--color-text-primary)}.debug-header p{margin:0;font-size:var(--font-size-xs)}.debug-back-btn{background-color:var(--color-surface);border:1px solid var(--color-border);padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-primary);transition:all .3s ease}.debug-back-btn:hover{background-color:var(--color-primary);color:var(--color-background)}.debug-container{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.debug-section{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.debug-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.debug-item{background-color:var(--color-background);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border)}.debug-item label{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);font-weight:600}.debug-btn-secondary{background-color:var(--color-primary);color:var(--color-background);border:none;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);transition:all .3s ease;margin-top:var(--spacing-md)}.debug-btn-secondary:hover{opacity:.9;transform:translateY(-2px)}.debug-log-container{display:flex;flex-direction:column;gap:var(--spacing-md);max-height:400px;overflow-y:auto}.debug-log-entry{background-color:var(--color-background);border-left:4px solid var(--color-border);padding:var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.debug-log-entry.error{border-left-color:var(--color-error);background-color:#ff00000d}.debug-log-entry.warn{border-left-color:var(--color-warning);background-color:#ffc1070d}.debug-log-entry.info,.debug-log-entry.log{border-left-color:var(--color-primary)}.debug-log-header{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);align-items:center}.debug-log-time{color:var(--color-text-secondary);font-size:var(--font-size-xs);min-width:70px}.debug-log-level{font-weight:600;color:var(--color-text-primary)}.debug-log-message{color:var(--color-text-primary);word-break:normal;overflow-wrap:anywhere;margin-bottom:var(--spacing-sm)}.debug-log-data{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-md);margin-top:var(--spacing-sm);overflow-x:auto}.debug-log-data pre{margin:0;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.debug-log-empty{padding:var(--spacing-lg);text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-sm)}details{background-color:var(--color-background);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border);cursor:pointer}details summary{font-weight:600;color:var(--color-text-primary);-webkit-user-select:none;user-select:none}details code{font-family:monospace;font-size:var(--font-size-xs)}.debug-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin:var(--spacing-md) 0}.debug-info-item{padding:var(--spacing-md);background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.debug-info-item label{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:600;margin-bottom:var(--spacing-sm)}.debug-logs-container{background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);font-family:monospace;font-size:var(--font-size-xs);line-height:1.5}.debug-logs-container pre{background-color:var(--color-background);padding:var(--spacing-sm);border-radius:var(--radius-sm);overflow-x:auto}.ios-debug-section{background:linear-gradient(135deg,var(--color-background) 0%,var(--color-background-secondary) 100%);border:2px solid var(--color-border)}.test-dashboard-wrapper{display:flex;flex-direction:column;height:100%;background-color:var(--color-background)}.test-dashboard-header{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark, #1a4d7a));color:#fff;padding:20px 16px;border-bottom:3px solid var(--color-accent)}.test-dashboard-header h1{margin:0 0 4px;font-size:28px;font-weight:700}.test-header-subtitle{margin:0;font-size:13px;opacity:.9;font-weight:500}.test-tabs-nav{display:flex;gap:0;background-color:var(--color-background-secondary);border-bottom:2px solid var(--color-border);overflow:auto hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;padding:0;margin:0}.test-tabs-nav::-webkit-scrollbar{height:4px}.test-tabs-nav::-webkit-scrollbar-track{background:transparent}.test-tabs-nav::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.test-tab-btn{display:flex;align-items:center;gap:6px;padding:12px 16px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:13px;font-weight:600;color:var(--color-text-secondary);white-space:nowrap;transition:all .2s ease;outline:none}.test-tab-btn:hover{background-color:var(--color-background);color:var(--color-text-primary)}.test-tab-btn.active{border-bottom-color:var(--color-accent);color:var(--color-accent);background-color:var(--color-background)}.test-tab-icon{font-size:16px;display:inline-block}.test-tab-label{display:none}@media (width >= 640px){.test-tab-label{display:inline}}.test-tabs-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}@media (width >= 768px){.test-tabs-content{padding:20px;max-width:1200px;margin:0 auto;width:100%}}.test-tab-pane{display:none;animation:fade-in .15s ease-out}.test-tab-pane.active{display:contents}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.test-card{background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:12px}@media (width >= 640px){.test-card{padding:20px}}.test-section-title{margin:12px 0 0;font-size:14px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.test-help-text{margin:0;font-size:13px;color:var(--color-text-secondary);line-height:1.5}.test-button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin:12px 0}@media (width >= 768px){.test-button-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}}.test-button-grid .btn{padding:10px 12px;font-size:12px;display:flex;flex-direction:column;align-items:center;gap:4px;min-height:56px;justify-content:center}@media (width >= 768px){.test-button-grid .btn{min-height:64px;font-size:13px;padding:12px 14px}}.test-control-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.test-status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background-color:var(--color-background);border:1px solid var(--color-border);border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.test-status-badge.online{background-color:#2ed5731a;color:#2ed573;border-color:#2ed573}.test-status-badge.offline{background-color:#ff6b351a;color:#ff6b35;border-color:#ff6b35}.test-sandbox-warning{background-color:#ff6b6b1a;border:1px solid #ff6b6b;border-radius:var(--radius-md);padding:12px;font-size:13px;color:#ff6b6b;font-weight:600;animation:pulse 2s infinite}.test-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:12px;margin:12px 0}.test-stat-item{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px;text-align:center}.test-stat-value{font-size:24px;font-weight:700;color:var(--color-text-primary);margin-bottom:4px}.test-stat-value.pending{color:orange}.test-stat-value.syncing{color:#3498db}.test-stat-value.synced{color:#2ed573}.test-stat-value.failed{color:#ff4757}.test-stat-label{font-size:11px;color:var(--color-text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.test-premium-status{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin:12px 0;padding:16px;background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md)}.test-status-item{display:flex;flex-direction:column;gap:4px}.test-status-label{font-size:11px;color:var(--color-text-secondary);font-weight:600;text-transform:uppercase}.test-status-value{font-size:14px;font-weight:700;color:var(--color-text-primary);word-break:normal;overflow-wrap:anywhere}.test-debug-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin:12px 0}.test-debug-item{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px;display:flex;flex-direction:column;gap:4px}.test-debug-item label{font-size:11px;color:var(--color-text-secondary);font-weight:600;margin:0}.test-debug-logs{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px;font-family:monospace;font-size:11px;max-height:300px;overflow-y:auto;line-height:1.6}.test-debug-logs pre{margin:8px 0;padding:8px;background-color:var(--color-background-secondary);border-radius:4px;overflow-x:auto}.test-log-container{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px;font-family:monospace;font-size:11px;max-height:250px;overflow-y:auto;line-height:1.5}.test-log-entry{padding:4px 0;border-bottom:1px solid var(--color-border)}.test-log-entry:last-child{border-bottom:none}.test-empty-state{margin:0;padding:24px 12px;text-align:center;color:var(--color-text-secondary);font-size:13px}.test-danger-zone{border-left:4px solid #ff4757}.test-results-section,.test-sync-log-section{margin-top:16px}.btn-lg{padding:12px 16px;font-size:14px;min-height:44px}.btn-sm{padding:8px 12px;font-size:12px}@media (width < 640px){.plans-container{grid-template-columns:1fr;max-width:100%}.test-dashboard-wrapper{margin:-16px -16px 0;border-radius:12px 12px 0 0}.test-dashboard-header{border-radius:12px 12px 0 0}.test-tabs-nav{border-radius:0}.test-tabs-content{padding:12px;gap:12px}.test-card{padding:12px}}.profile-container{width:100%;max-width:900px;margin:0 auto;padding:0;display:flex;flex-direction:column;gap:var(--spacing-xl);height:auto}.profile-header{margin-bottom:var(--spacing-lg)}.profile-header h1{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.profile-header p{font-size:var(--font-size-base);color:var(--color-text-secondary)}#profile-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.profile-section{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition)}.profile-section:hover{border-color:#00d4d44d;box-shadow:0 0 12px #00d4d40d}#profile-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);padding:var(--spacing-md);background:linear-gradient(135deg,#00d4d405,#00d4d403);border-radius:var(--radius-md);margin-top:var(--spacing-md)}@media (width >= 768px){#profile-stats{grid-template-columns:repeat(4,1fr)}}#profile-stats>div{padding:var(--spacing-md);text-align:center;background-color:var(--color-surface-alt);border-radius:var(--radius-sm);border:1px solid var(--color-border);transition:all var(--transition)}#profile-stats>div:hover{border-color:var(--color-primary);background-color:#00d4d40d;transform:translateY(-2px)}#profile-stats .text-2xl{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-sm)}.text-meta{color:var(--color-text-secondary)}#profile-stats .text-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.profile-section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-md);text-transform:uppercase;letter-spacing:.5px}.profile-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group:last-child{margin-bottom:0}.form-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.form-label.required:after{content:"*";color:var(--color-danger);font-weight:700}.form-input::placeholder{color:var(--color-text-secondary)}.form-select{font-family:inherit;font-size:var(--font-size-base);padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg);color:var(--color-text-primary);transition:all var(--transition)}.form-select:hover{border-color:#00d4d44d}.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #00d4d41a;background-color:var(--color-surface)}.form-textarea{font-family:inherit;font-size:var(--font-size-base);padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg);color:var(--color-text-primary);transition:all var(--transition);resize:vertical;min-height:100px}.form-textarea::placeholder{color:var(--color-text-secondary)}.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #00d4d41a;background-color:var(--color-surface)}.char-counter{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:right}.grid{display:grid;gap:var(--spacing-md)}.grid-cols-1{grid-template-columns:1fr}.grid-cols-2{grid-template-columns:repeat(2,1fr)}@media (width >= 768px){.md-grid-cols-2{grid-template-columns:repeat(2,1fr)}}.species-dropdown-container{display:flex;flex-direction:column;gap:var(--spacing-sm)}.species-checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md)}.species-checkbox-item{display:flex;align-items:center;gap:var(--spacing-sm)}.species-checkbox-item input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--color-primary)}.species-checkbox-item label{cursor:pointer;-webkit-user-select:none;user-select:none}.dropdown-options-list{display:flex;flex-direction:column;width:100%}.dropdown-option-item{display:flex!important;flex-direction:row;align-items:center;width:100%;padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;border-bottom:1px solid var(--color-border);transition:background-color var(--transition)}.dropdown-option-item:hover{background-color:var(--color-surface-alt)}.dropdown-option-item input[type=checkbox]{cursor:pointer;width:18px;height:18px;margin-right:var(--spacing-sm);accent-color:var(--color-primary);flex-shrink:0}.profile-actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap;margin-top:var(--spacing-lg)}.btn-primary,.btn-secondary,.btn-danger{padding:var(--spacing-md) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-primary{background-color:var(--color-primary);color:#fff;flex:1;min-width:150px}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-2px);box-shadow:0 4px 12px #00d4d433}.btn-secondary{background-color:transparent;color:var(--color-text-primary);border:1px solid var(--color-border);flex:1;min-width:150px}.btn-secondary:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-danger{background-color:transparent;color:var(--color-danger);border:1px solid var(--color-danger);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);margin-top:var(--spacing-lg)}.btn-danger:hover:not(:disabled){background-color:#ef44441a}.spinner-sm{width:16px;height:16px;border:2px solid rgb(255 255 255 / 30%);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.profile-setup-mode .profile-header{text-align:center;margin-bottom:var(--spacing-3xl)}.profile-setup-mode .profile-header h1{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-md)}.profile-setup-mode .profile-actions{margin-top:var(--spacing-2xl)}@media (width < 640px){.profile-container{padding:var(--spacing-md)}.profile-header h1{font-size:var(--font-size-2xl)}.grid-cols-2,.md-grid-cols-2{grid-template-columns:1fr}.profile-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;flex:none;min-width:auto}.species-checkbox-group{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}
