:root{color-scheme:dark}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top,#dbeafe,#f8fafc 40%,#e2e8f0);color:#111827;min-height:100vh}button{font:inherit}.app-shell{min-height:100vh;width:100%;padding:30px 16px;display:flex;justify-content:center;align-items:center;transition:background-color .3s ease;background:radial-gradient(circle at top,#eff6ff,#f8fafc 40%,#e2e8f0);color:#111827}.app-shell.dark{background:radial-gradient(circle at top,#050b16,#070f1c 45%,#0b1726);color:#e2e8f0}.phone-frame{width:min(420px,100%);max-width:420px;background:#fffffff5;border:1px solid rgba(15,23,42,.08);border-radius:44px;box-shadow:0 32px 72px #0f172a2e;padding:22px;display:flex;flex-direction:column;gap:18px}.app-shell.dark .phone-frame{background:#070c18f5;border-color:#ffffff0f;box-shadow:0 44px 112px #00000073}.top-bar{display:flex;align-items:center;justify-content:space-between;gap:12px}.icon-button{width:50px;height:50px;border:none;border-radius:18px;background:#ffffffe0;display:inline-flex;align-items:center;justify-content:center;color:#1e293b;cursor:pointer;box-shadow:0 18px 36px #0f172a14}.app-shell.dark .icon-button{background:#ffffff14;color:#f8fafc;box-shadow:0 18px 36px #0000002e}.title-block{flex:1;text-align:center}.label-text{display:inline-block;font-size:.92rem;font-weight:700;color:#0f172a}.app-shell.dark .label-text{color:#f8fafc}.toggle-button{width:58px;height:32px;border-radius:999px;border:none;background:#ffffffeb;position:relative;display:inline-flex;align-items:center;justify-content:flex-end;padding:5px;color:#0f172a;cursor:pointer;overflow:hidden}.app-shell.dark .toggle-button{background:#ffffff14;color:#f8fafc}.toggle-pill{position:absolute;left:6px;width:22px;height:22px;border-radius:50%;background:#38bdf8;transition:left .3s ease,background-color .3s ease}.app-shell.dark .toggle-pill{left:auto;right:6px;background:#fde047}.toggle-button svg{position:relative;z-index:1}.level-card{background:#fffffff2;border:1px solid rgba(15,23,42,.08);border-radius:32px;padding:24px;box-shadow:0 28px 60px #0f172a1f}.app-shell.dark .level-card{background:#ffffff0d;border-color:#ffffff1a;box-shadow:inset 0 1px #ffffff0a,0 28px 60px #0000002e}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:18px}.card-label{display:block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#64748b}.app-shell.dark .card-label{color:#94a3b8}.card-title{margin:8px 0 0;font-size:1.1rem;font-weight:800;color:#0f172a}.app-shell.dark .card-title{color:#f8fafc}.level-body{display:flex;align-items:center;gap:18px}.level-circle{width:74px;height:74px;border-radius:28px;background:radial-gradient(circle at top,#60a5fa,#2563eb);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.4rem;font-weight:900;box-shadow:0 20px 40px #2563eb3d}.level-text{flex:1}.level-subtitle{margin:0 0 10px;font-size:.96rem;font-weight:700;color:#0f172a}.app-shell.dark .level-subtitle{color:#f8fafc}.progress-bar{width:100%;height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.app-shell.dark .progress-bar{background:#94a3b83d}.progress-fill{height:100%;background:linear-gradient(90deg,#60a5fa,#38bdf8);border-radius:999px}.progress-note{margin:10px 0 0;font-size:.78rem;color:#64748b}.app-shell.dark .progress-note{color:#cbd5e1}.scan-panel{display:flex;justify-content:center}.scan-button{width:152px;height:152px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:radial-gradient(circle at top,#3b82f638,#1e3a8af2);color:#f8fafc;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;font-size:.95rem;font-weight:700;box-shadow:0 30px 72px #0f172a47;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .3s ease}.scan-button:hover{transform:translateY(-2px);box-shadow:0 34px 82px #0f172a59;background:radial-gradient(circle at top,#3b82f647,#1e3a8afa)}.scan-button:hover{transform:translateY(-2px);box-shadow:0 34px 72px #3b82f65c}.summary-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;justify-content:center}.ring-summary{display:flex;justify-content:center;align-items:center;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:28px;padding:14px;box-shadow:0 24px 60px #0000002e}.ring-chart{position:relative;width:96px;height:96px;display:grid;place-items:center;border-radius:50%}.soft-ring{background:#ffffff14;box-shadow:inset 0 10px 18px #ffffff14,inset 0 -6px 18px #0f172a1a}.freshwater .soft-ring{background:linear-gradient(180deg,#38bdf82e,#0f172a1f)}.saltwater .soft-ring{background:linear-gradient(180deg,#22c55e2e,#0f172a1f)}.ring-svg{width:96px;height:96px;transform:rotate(-90deg)}.ring-bg,.ring-progress{fill:none;stroke-width:10;stroke-linecap:round}.ring-bg{stroke:#ffffff1f}.ring-progress{stroke:#fff;transition:stroke-dashoffset .6s ease}.freshwater .ring-progress{stroke:#22d3ee}.saltwater .ring-progress{stroke:#34d399}.ring-label{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.ring-label strong{font-size:1.36rem;line-height:1}.ring-label span{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;opacity:.9}.freshwater .ring-label strong,.saltwater .ring-label strong{color:#fff}.bottom-nav{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;background:#fffffff2;border-radius:28px;padding:10px 12px;box-shadow:0 20px 50px #0f172a14}.app-shell.dark .bottom-nav{background:#0f172ae0}.nav-item{border:none;background:transparent;color:#64748b;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.68rem;padding:6px 0;cursor:pointer}.app-shell.dark .nav-item{color:#94a3b8}.nav-item.active{color:#2563eb}.app-shell.dark .nav-item.active{color:#93c5fd}.nav-item svg{display:block}
