.fish-list-toggle{color:#0a3d62;cursor:pointer;background:#ffffffe6;border:none;border-radius:999px;padding:14px 18px;font-size:1rem;box-shadow:0 6px 16px #0000002e}.fish-list-panel{top:calc(env(safe-area-inset-top,0px) + 76px);right:calc(env(safe-area-inset-right,0px) + 12px);width:min(380px, calc(100vw - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px) - 24px));max-height:calc(100vh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 100px);color:#0a3d62;z-index:5;background:linear-gradient(#fff 0%,#f4f8fc 100%);border:1px solid #0a3d6214;border-radius:20px;padding:16px;position:absolute;overflow:auto;box-shadow:0 18px 48px #0a3d6259,inset 0 2px #ffffffb3}.fish-list-panel header{border-bottom:1px solid #0a3d621a;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:10px;display:flex}.fish-list-title{letter-spacing:.2px;align-items:center;gap:10px;font-size:1.05rem;font-weight:800;display:inline-flex}.fish-list-title .title-icon{color:#1982c4;font-size:1.25rem}.fish-list-title .title-count{color:#6b3a00;text-align:center;background:linear-gradient(#ffd166 0%,#ff9f1c 100%);border-radius:999px;min-width:22px;padding:2px 9px;font-size:.78rem;font-weight:800;box-shadow:0 2px 4px #f76b1c40}.fish-list-close{cursor:pointer;color:#0a3d62;background:#0a3d620f;border:none;border-radius:50%;place-items:center;width:32px;height:32px;font-size:1.15rem;transition:background .12s ease-out,transform 80ms ease-out;display:grid}.fish-list-close:hover{background:#0a3d621f}.fish-list-close:active{transform:scale(.94)}.fish-list-panel ul{grid-template-columns:repeat(auto-fill,minmax(104px,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.fish-list-empty{text-align:center;color:#6b8aa3;flex-direction:column;align-items:center;gap:12px;padding:32px 8px;font-size:.95rem;font-weight:600;display:flex}.fish-list-empty svg{color:#b3cce0;font-size:2.4rem}.fish-card{background:#fff;border:2px solid #0a3d6214;border-radius:16px;flex-direction:column;align-items:stretch;padding:8px 8px 6px;transition:border-color .14s ease-out,transform 80ms ease-out,box-shadow .14s ease-out;display:flex;position:relative;box-shadow:0 2px 6px #0a3d620f}@keyframes selectedPulse{0%{box-shadow:0 0 #1982c480}60%{box-shadow:0 0 0 12px #1982c400}to{box-shadow:0 0 #1982c400}}.fish-card.selected{border-color:#1982c4;animation:.6s ease-out selectedPulse;box-shadow:0 0 0 3px #1982c42e,0 4px 12px #1982c42e}.fish-card:hover{border-color:#1982c459;transform:translateY(-2px);box-shadow:0 6px 14px #0a3d621a}.fish-thumb{aspect-ratio:1;cursor:pointer;background:linear-gradient(160deg,#eaf4fb 0%,#d6e7f2 100%);border:none;border-radius:12px;place-items:center;width:100%;padding:0;display:grid;overflow:hidden}.fish-thumb img{object-fit:contain;filter:drop-shadow(0 2px 4px #0a3d621f);max-width:92%;max-height:92%}.fish-name{text-align:center;font:inherit;color:#0a3d62;cursor:pointer;-webkit-line-clamp:2;line-clamp:2;word-break:break-word;background:0 0;border:none;-webkit-box-orient:vertical;padding:8px 4px 2px;font-size:.86rem;font-weight:700;line-height:1.15;display:-webkit-box;overflow:hidden}.fish-name-input{font:inherit;text-align:center;box-sizing:border-box;color:#0a3d62;background:#fff;border:2px solid #1982c4;border-radius:8px;width:100%;margin-top:6px;padding:6px 8px;font-size:.86rem;font-weight:700}.fish-name-input:focus{outline:none;box-shadow:0 0 0 3px #1982c433}.fish-delete{cursor:pointer;color:#c0392b;background:#fffffff2;border:1px solid #c0392b2e;border-radius:50%;place-items:center;width:26px;height:26px;padding:0;font-size:.85rem;transition:background .12s ease-out,transform 80ms ease-out;display:grid;position:absolute;top:6px;right:6px;box-shadow:0 2px 6px #0000001f}.fish-delete:hover{color:#fff;background:#c0392b}.fish-delete:active{transform:scale(.92)}.fish-confirm{text-align:center;z-index:2;background:#fffffffa;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:6px;display:flex;position:absolute;inset:4px;overflow:hidden;box-shadow:inset 0 0 0 2px #ff595e}.confirm-q{color:#0a3d62;white-space:nowrap;font-size:.78rem;font-weight:800}.confirm-actions{justify-content:center;gap:6px;width:100%;display:flex}.confirm-yes,.confirm-no{font:inherit;cursor:pointer;text-align:center;border:none;border-radius:999px;justify-content:center;align-items:center;min-width:0;padding:4px 10px;font-size:.78rem;font-weight:700;line-height:1;transition:transform 80ms ease-out;display:inline-flex}.confirm-yes{color:#fff;background:linear-gradient(#ff7a7e 0%,#d9434a 100%);box-shadow:0 2px 4px #c0392b40}.confirm-yes:hover{transform:translateY(-1px)}.confirm-no{color:#0a3d62;background:#eef3f8}.confirm-no:hover{background:#dfe7ee}@media (width<=480px){.fish-list-panel{width:auto;left:8px;right:8px}.fish-list-panel ul{grid-template-columns:repeat(auto-fill,minmax(92px,1fr))}}@media (width<=540px){.aquariums-panel{left:calc(env(safe-area-inset-left,0px) + 12px);right:calc(env(safe-area-inset-right,0px) + 12px);width:auto}}.aquariums-panel{top:calc(env(safe-area-inset-top,0px) + 76px);right:calc(env(safe-area-inset-right,0px) + 12px);width:min(340px, calc(100vw - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px) - 24px));max-height:calc(100vh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 100px);color:#0a3d62;z-index:5;background:linear-gradient(#fff 0%,#f4f8fc 100%);border:1px solid #0a3d6214;border-radius:20px;padding:16px;position:absolute;overflow:auto;box-shadow:0 18px 48px #0a3d6259,inset 0 2px #ffffffb3}.aquariums-panel header{border-bottom:1px solid #0a3d621a;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:10px;display:flex}.aquariums-title{letter-spacing:.2px;align-items:center;gap:10px;font-size:1.05rem;font-weight:800;display:inline-flex}.aquariums-title .title-icon{color:#1982c4;font-size:1.3rem}.aquariums-title .title-count{color:#6b3a00;text-align:center;background:linear-gradient(#ffd166 0%,#ff9f1c 100%);border-radius:999px;min-width:22px;padding:2px 9px;font-size:.78rem;font-weight:800;box-shadow:0 2px 4px #f76b1c40}.aquariums-close{cursor:pointer;color:#0a3d62;background:#0a3d620f;border:none;border-radius:50%;place-items:center;width:32px;height:32px;font-size:1.15rem;transition:background .12s ease-out,transform 80ms ease-out;display:grid}.aquariums-close:hover{background:#0a3d621f}.aquariums-close:active{transform:scale(.94)}.aquariums-panel ul{flex-direction:column;gap:8px;margin:0 0 14px;padding:0;list-style:none;display:flex}.aq-row{background:#fff;border:2px solid #0a3d6214;border-radius:12px;grid-template-columns:1fr auto auto;align-items:center;gap:4px;padding:6px 8px;transition:border-color .14s ease-out,transform 80ms ease-out,box-shadow .14s ease-out;display:grid;box-shadow:0 2px 6px #0a3d620f}.aq-row:hover{border-color:#1982c44d;transform:translateY(-1px);box-shadow:0 4px 12px #0a3d621a}.aq-row.current{background:linear-gradient(#f0f8ff 0%,#e0f0fa 100%);border-color:#1982c4;box-shadow:0 0 0 3px #1982c42e,0 4px 12px #1982c42e}.aq-name{text-align:left;font:inherit;color:inherit;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;font-size:.95rem;font-weight:700;display:flex}.aq-name:hover{background:#1982c40f}.aq-count{color:#6b8aa3;white-space:nowrap;background:#0a3d620f;border-radius:999px;padding:2px 8px;font-size:.8rem;font-weight:700}.aq-row.current .aq-count{color:#0a3d62;background:#1982c41f}.aq-edit,.aq-delete{cursor:pointer;color:#0a3d62;background:#0a3d620d;border:none;border-radius:50%;place-items:center;width:30px;height:30px;font-size:.9rem;transition:background .12s ease-out,color .12s ease-out,transform 80ms ease-out;display:grid}.aq-edit:hover{color:#1982c4;background:#1982c426}.aq-delete{color:#c0392b}.aq-delete:hover:not(:disabled){color:#fff;background:#c0392b}.aq-edit:active,.aq-delete:active:not(:disabled){transform:scale(.92)}.aq-delete:disabled{opacity:.3;cursor:not-allowed}.aq-confirm{background:#ff595e14;border-radius:999px;grid-column:2/span 2;justify-content:flex-end;align-items:center;gap:8px;padding:2px 4px;display:flex;box-shadow:inset 0 0 0 2px #ff595e}.aq-confirm .confirm-q{color:#0a3d62;white-space:nowrap;padding-left:8px;font-size:.8rem;font-weight:800}.aq-confirm .confirm-actions{gap:6px;display:inline-flex}.aq-confirm .confirm-yes,.aq-confirm .confirm-no{font:inherit;cursor:pointer;border:none;border-radius:999px;padding:6px 12px;font-size:.8rem;font-weight:800;line-height:1;transition:transform 80ms ease-out,box-shadow .12s ease-out}.aq-confirm .confirm-yes{color:#fff;background:linear-gradient(#ff7a7e 0%,#d9434a 100%);box-shadow:0 2px 4px #c0392b40}.aq-confirm .confirm-yes:hover{transform:translateY(-1px)}.aq-confirm .confirm-no{color:#0a3d62;background:#eef3f8}.aq-confirm .confirm-no:hover{background:#dfe7ee}.aq-confirm .confirm-yes:active,.aq-confirm .confirm-no:active{transform:scale(.95)}.aq-row input{font:inherit;color:#0a3d62;background:#fff;border:2px solid #1982c4;border-radius:8px;padding:8px 10px;font-weight:700}.aq-row input:focus{outline:none;box-shadow:0 0 0 3px #1982c433}.aq-add{color:#6b3a00;width:100%;font:inherit;cursor:pointer;background:linear-gradient(#ffd166 0%,#ff9f1c 100%);border:none;border-radius:999px;justify-content:center;align-items:center;gap:10px;padding:12px 18px;font-size:1rem;font-weight:800;transition:transform 80ms ease-out,box-shadow .12s ease-out;display:inline-flex;box-shadow:0 4px 12px #f76b1c4d,inset 0 1px #ffffffb3}.aq-add:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #f76b1c66,inset 0 1px #ffffffb3}.aq-add:active:not(:disabled){transform:translateY(1px)}.aq-add:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.5)}@media (width<=540px){.aquariums-panel{left:calc(env(safe-area-inset-left,0px) + 12px);right:calc(env(safe-area-inset-right,0px) + 12px);width:auto}}.confetti-layer{pointer-events:none;z-index:9999;position:fixed;inset:0;overflow:hidden}.confetti-piece{transform-origin:50%;will-change:transform, opacity;width:6px;height:6px;animation:1.4s cubic-bezier(.16,.84,.44,1) forwards confetti-fly;position:absolute;top:auto;bottom:0;left:50%}@keyframes confetti-fly{0%{opacity:1;transform:translate(-50%)rotate(0)scale(1)}60%{opacity:1}to{transform:translate(calc(-50% + var(--dx,0px)), var(--dy,0px)) rotate(var(--rot,360deg)) scale(.85);opacity:0}}@media (prefers-reduced-motion:reduce){.confetti-piece{animation-duration:.6s}}.quota-warning{color:#fff;z-index:10000;background:#2b1c1c;border:2px solid #ff7676;border-radius:12px;align-items:center;gap:12px;max-width:min(560px,100vw - 32px);padding:14px 18px;font-size:15px;line-height:1.35;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 12px 32px #00000059}.quota-warning__text{flex:1;margin:0}.quota-warning__btn{color:#fff;cursor:pointer;background:#ff7676;border:none;border-radius:8px;flex:none;padding:8px 14px;font-size:14px;font-weight:600}.quota-warning__btn:hover,.quota-warning__btn:focus-visible{background:#ff8e8e;outline:none}.snapshot-modal-backdrop{-webkit-backdrop-filter:blur(4px);z-index:200;background:#0a3d628c;place-items:center;padding:16px;animation:.18s ease-out snap-fade-in;display:grid;position:fixed;inset:0}@keyframes snap-fade-in{0%{opacity:0}to{opacity:1}}.snapshot-modal{background:#fff;border-radius:24px;flex-direction:column;gap:16px;width:100%;max-width:min(92vw,720px);max-height:92vh;padding:20px;animation:.22s cubic-bezier(.2,.9,.3,1.3) snap-pop;display:flex;box-shadow:0 20px 60px #00000059}@keyframes snap-pop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.snapshot-modal-image{object-fit:contain;background:#eef6fb;border-radius:16px;width:100%;max-height:60vh;display:block;box-shadow:0 4px 14px #0000001f}.snapshot-modal-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.snapshot-modal-actions .primary-btn,.snapshot-modal-actions .secondary-btn{min-width:140px}.secondary-btn{color:#0a3d62;cursor:pointer;background:#eef2f7;border:none;border-radius:999px;padding:12px 22px;font-size:1rem;font-weight:700;transition:transform 80ms ease-out;box-shadow:0 4px 10px #00000014}.secondary-btn:hover{transform:translateY(-1px)}.secondary-btn:active{transform:translateY(1px)}.snapshot-modal-loading{color:#0a3d62;place-items:center;min-height:200px;font-size:1.05rem;font-weight:600;display:grid}@media (width<=540px){.snapshot-modal{border-radius:20px;gap:12px;padding:14px}.snapshot-modal-actions .primary-btn,.snapshot-modal-actions .secondary-btn{flex:30%;min-width:0;padding:10px 12px;font-size:.95rem}}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-family:system-ui,-apple-system,Segoe UI,sans-serif}*{box-sizing:border-box}button{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html,body{color:#fff;overscroll-behavior:none;background:#0a3d62;width:100%;height:100%;margin:0;padding:0;overflow:hidden}#root,.app-root{color:#fff;background:#0a3d62;width:100dvw;height:100dvh;margin:0;padding:0;position:fixed;inset:0;overflow:hidden}.hud{top:calc(env(safe-area-inset-top,0px) + 16px);left:calc(env(safe-area-inset-left,0px) + 16px);z-index:5;max-width:calc(100vw - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px) - 32px);flex-wrap:wrap;align-items:center;gap:10px;display:flex;position:absolute}.hud-right{left:auto;right:calc(env(safe-area-inset-right,0px) + 16px)}.primary-btn{color:#0a3d62;cursor:pointer;background:linear-gradient(#fff 0%,#f0f6ff 100%);border:none;border-radius:999px;align-items:center;gap:8px;padding:14px 22px;font-size:1.05rem;font-weight:600;transition:transform 80ms ease-out,box-shadow .12s ease-out;display:inline-flex;box-shadow:0 6px 16px #0000002e,inset 0 1px #ffffffb3}.primary-btn:hover{transform:translateY(-1px);box-shadow:0 8px 22px #00000038,inset 0 1px #ffffffb3}.primary-btn:active{transform:translateY(1px);box-shadow:0 3px 8px #0000002e,inset 0 1px #ffffffb3}.primary-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:0 2px 6px #0000001a}.primary-btn.accent{color:#6b3a00;background:linear-gradient(#ffd166 0%,#ff9f1c 100%)}.icon-btn{color:#0a3d62;cursor:pointer;background:#ffffffe6;border:none;border-radius:50%;place-items:center;width:52px;height:52px;font-size:1.4rem;transition:transform 80ms ease-out;display:grid;position:relative;box-shadow:0 6px 16px #0000002e}.icon-btn:hover{transform:translateY(-1px)}.icon-btn:active{transform:translateY(1px)}.icon-btn .count-badge{color:#fff;background:#0a3d62;border-radius:999px;place-items:center;min-width:20px;height:20px;padding:0 6px;font-size:.72rem;font-weight:700;display:grid;position:absolute;top:-4px;right:-4px}.primary-btn.active{color:#fff;background:linear-gradient(#52b3ff 0%,#1982c4 100%)}.feed-hint{color:#0a3d62;pointer-events:none;z-index:5;background:#ffffffeb;border-radius:999px;padding:10px 18px;font-weight:600;position:absolute;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0000002e}.aquarium-loading{z-index:0;background:#0a3d62;position:fixed;inset:0}.empty-hint{z-index:4;pointer-events:none;place-items:center;display:grid;position:absolute;inset:0}.empty-hint .bubble{color:#0a3d62;background:#ffffffeb;border-radius:22px;align-items:center;gap:12px;padding:18px 26px;font-size:1.4rem;font-weight:700;animation:2.4s ease-in-out infinite hint-bob;display:inline-flex;box-shadow:0 8px 24px #00000040}.empty-hint svg.arrow{width:40vw;max-width:380px;height:40vh;max-height:320px;position:absolute;top:70px;left:60px;overflow:visible}.empty-hint svg.arrow path{fill:none;stroke:#ffd166;stroke-width:6px;stroke-linecap:round;stroke-dasharray:14 10;animation:1.2s linear infinite arrow-march}.empty-hint svg.arrow polygon{fill:#ffd166;animation:1.6s ease-in-out infinite arrow-tip-bob}@keyframes hint-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes arrow-march{to{stroke-dashoffset:-24px}}@keyframes arrow-tip-bob{0%,to{transform:translate(0)}50%{transform:translate(2px,-4px)}}.primary-btn.pulse{animation:2.8s ease-out infinite btn-pulse}@keyframes btn-pulse{0%{box-shadow:0 6px 16px #0000002e,0 0 #ffd16699}45%{box-shadow:0 6px 16px #0000002e,0 0 0 10px #ffd16600}to{box-shadow:0 6px 16px #0000002e,0 0 0 10px #ffd16600}}.snapshot-flash:after{content:"";z-index:100;pointer-events:none;background:#fff;animation:.22s ease-out forwards snap-flash;position:fixed;inset:0}@keyframes snap-flash{0%{opacity:.9}to{opacity:0}}@media (width<=540px){.hud{top:calc(env(safe-area-inset-top,0px) + 10px);left:calc(env(safe-area-inset-left,0px) + 10px);gap:8px}.hud-right{right:calc(env(safe-area-inset-right,0px) + 10px)}.primary-btn{gap:0;padding:10px 12px;font-size:1rem}.primary-btn>span{display:none}.primary-btn>svg{font-size:1.4rem}.icon-btn{width:44px;height:44px;font-size:1.2rem}.icon-btn .count-badge{min-width:18px;height:18px;font-size:.65rem}.feed-hint{bottom:calc(env(safe-area-inset-bottom,0px) + 16px);padding:8px 14px;font-size:.9rem}}
