*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--deep: #050e1d;--mid: #091a35;--light: #0d2d5a;--teal: #00c9d4;--teal2: #0098a8;--sand: #f4a261;--white: #eef4ff;--muted: #7a90b8;--card: rgba(9, 26, 53, .85);--border: rgba(0, 201, 212, .18);--danger: #ff6b6b}html,body,#root{height:100%}body{font-family:Inter,system-ui,sans-serif;background:var(--deep);color:var(--white);overflow-x:hidden}.ocean-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background:radial-gradient(ellipse 80% 60% at 15% 55%,#0d3166 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 85% 20%,#083055 0%,transparent 60%),linear-gradient(180deg,#060f1f,#050e1d)}.creatures{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;overflow:hidden}.creature{position:absolute}.creature svg{fill:var(--teal);opacity:.07}.shark-1{top:12%;animation:swim-r 30s linear infinite;left:-360px}.shark-1 svg{width:300px}.shark-2{top:60%;animation:swim-r 46s linear infinite 14s;left:-220px}.shark-2 svg{width:190px;opacity:.04}.ray-1{top:38%;animation:swim-l 38s linear infinite 6s;right:-300px}.ray-1 svg{width:260px}.turtle-1{top:78%;animation:swim-r 54s linear infinite 22s;left:-200px}.turtle-1 svg{width:160px;opacity:.05}.turtle-2{top:25%;animation:swim-l 60s linear infinite 30s;right:-180px}.turtle-2 svg{width:140px;opacity:.04}@keyframes swim-r{0%{transform:translate(0) scaleX(1)}to{transform:translate(calc(100vw + 400px)) scaleX(1)}}@keyframes swim-l{0%{transform:translate(0) scaleX(-1)}to{transform:translate(calc(-100vw - 400px)) scaleX(-1)}}.bubbles{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1}.bubble{position:absolute;bottom:-30px;border-radius:50%;background:#00c9d414;border:1px solid rgba(0,201,212,.15);animation:rise linear infinite}@keyframes rise{to{transform:translateY(-105vh) translate(var(--dx, 0px));opacity:0}}.landing{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:0}.landing-logo{display:flex;align-items:center;gap:.7rem;margin-bottom:1.2rem}.landing-logo svg{width:52px;height:52px;fill:var(--teal)}.logo-wordmark{font-size:2.1rem;font-weight:900;letter-spacing:-.03em;background:linear-gradient(135deg,var(--teal) 0%,#a8e8ef 60%,var(--white) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-h1{font-size:clamp(2.2rem,5.5vw,4rem);font-weight:900;text-align:center;line-height:1.1;margin-bottom:.9rem;background:linear-gradient(160deg,var(--white) 0%,#aad4ff 55%,var(--teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;max-width:700px}.landing-sub{font-size:1.08rem;color:var(--muted);text-align:center;max-width:500px;line-height:1.65;margin-bottom:2.8rem}.passcode-card{background:var(--card);border:1px solid var(--border);border-radius:22px;padding:2.4rem 2.5rem 2rem;width:100%;max-width:430px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 32px 80px #00000073,inset 0 1px #ffffff0d}.passcode-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.14em;color:var(--teal);text-transform:uppercase;margin-bottom:.7rem}.passcode-row{display:flex;gap:.7rem}input.passcode-input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.85rem 1.2rem;font-size:1rem;font-family:inherit;color:var(--white);outline:none;transition:border-color .2s,box-shadow .2s}input.passcode-input::placeholder{color:#ffffff47}input.passcode-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #00c9d42e}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border:none;border-radius:12px;padding:.85rem 1.4rem;font-size:.92rem;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .18s,transform .15s;white-space:nowrap}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,var(--teal),var(--teal2));color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--muted)}.btn-outline:hover:not(:disabled){color:var(--white);border-color:#00c9d466;opacity:1}.btn-danger{background:#ff6b6b1f;border:1px solid rgba(255,107,107,.28);color:var(--danger)}.btn-danger:hover:not(:disabled){background:#ff6b6b33;opacity:1}.err-msg{color:var(--danger);font-size:.84rem;margin-top:.7rem;display:flex;align-items:center;gap:.35rem}.chips{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem;justify-content:center}.chip{background:#00c9d412;border:1px solid rgba(0,201,212,.18);border-radius:99px;padding:.35rem .95rem;font-size:.78rem;color:var(--muted);display:flex;align-items:center;gap:.4rem}.chip-icon{font-size:.95rem}.analysis-page{min-height:100vh;padding:0 1.5rem 4rem}.navbar{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 0;border-bottom:1px solid var(--border);margin-bottom:2.2rem;max-width:960px;margin-inline:auto}.nav-brand{display:flex;align-items:center;gap:.55rem;font-size:1.25rem;font-weight:900;background:linear-gradient(135deg,var(--teal),var(--white));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-brand svg{width:28px;height:28px;fill:var(--teal);flex-shrink:0}.main{max-width:960px;margin:0 auto}.page-heading{font-size:1.7rem;font-weight:800;margin-bottom:.35rem}.page-desc{color:var(--muted);font-size:.93rem;margin-bottom:2rem}.upload-zone{border:2px dashed var(--border);border-radius:20px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:#00c9d405;margin-bottom:1.5rem}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--teal);background:#00c9d40e}.upload-zone.has-file{border-color:var(--teal);background:#00c9d40a}.upload-icon{font-size:2.8rem;margin-bottom:.9rem;line-height:1}.upload-title{font-size:1.05rem;font-weight:700;margin-bottom:.45rem}.upload-hint{color:var(--muted);font-size:.83rem;margin-bottom:1.4rem}.file-pill{display:inline-flex;align-items:center;gap:.55rem;background:#00c9d41a;border:1px solid rgba(0,201,212,.28);border-radius:8px;padding:.45rem .95rem;font-size:.83rem;color:var(--teal)}.analyze-row{display:flex;align-items:center;gap:1rem;margin-bottom:2.5rem}.error-banner{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.28);border-radius:12px;padding:1rem 1.4rem;color:#ff8a8a;font-size:.88rem;margin-bottom:1.5rem}.results-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}.results-label{font-size:.82rem;color:var(--muted)}.loading{text-align:center;padding:4rem 0}.spinner{width:46px;height:46px;border:3px solid rgba(0,201,212,.15);border-top-color:var(--teal);border-radius:50%;animation:spin .75s linear infinite;margin:0 auto 1.1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--muted);font-size:.92rem}.result-card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:1.4rem 1.6rem;margin-bottom:.9rem;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);transition:border-color .2s,transform .2s}.result-card:hover{border-color:#00c9d461;transform:translateY(-1px)}.rc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}.sample-badge{background:#00c9d41a;color:var(--teal);border-radius:6px;padding:.2rem .65rem;font-size:.74rem;font-weight:700}.top-pred{font-size:1.05rem;font-weight:800}.top-conf{font-size:.85rem;color:var(--sand);font-weight:700}.pred-list{display:flex;flex-direction:column;gap:.55rem}.pred-row{display:flex;align-items:center;gap:.7rem}.pred-rank{width:18px;font-size:.72rem;color:var(--muted);flex-shrink:0}.pred-species{flex:1;font-size:.86rem;font-style:italic}.pred-bar-wrap{width:110px;height:5px;background:#ffffff12;border-radius:4px;overflow:hidden;flex-shrink:0}.pred-bar{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--teal),#a8eef4);transition:width .5s ease}.pred-pct{width:40px;text-align:right;font-size:.75rem;color:var(--muted);flex-shrink:0}.sparkline-wrap{margin-top:1.1rem;border-top:1px solid var(--border);padding-top:1rem}.sparkline-label{font-size:.7rem;color:var(--muted);margin-bottom:.4rem}.sparkline svg{display:block;width:100%}.rc-error{color:var(--danger);font-size:.82rem;font-style:italic}
