*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sans:-apple-system,BlinkMacSystemFont,"Plus Jakarta Sans","DM Sans",sans-serif;--serif:"Instrument Serif","DM Serif Display",Georgia,serif;--bg:#F7F5F1;--surface:#FFFFFF;--s2:#F0EDE7;--s3:#E3DED6;--s4:#C8C2B8;--t1:#1A1710;--t2:#4E4840;--t3:#968E84;--t4:#BEB8B0;--border:rgba(0,0,0,.06);--border2:rgba(0,0,0,.11);--brand:#E23744;--bodyos:#1A6B4A;--blight:#EAF5EF;--green:#16A34A;--green-bg:#F0FDF4;--green-dark:#14532D;--amber:#D97706;--amber-bg:#FFFBEB;--red:#DC2626;--red-bg:#FEF2F2;--blue:#1D4ED8;--blue-bg:#EFF6FF;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:22px;--sh1:0 1px 4px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);--sh2:0 4px 16px rgba(0,0,0,.09),0 2px 4px rgba(0,0,0,.05);--sh3:0 12px 36px rgba(0,0,0,.14),0 4px 10px rgba(0,0,0,.08);--sh4:0 24px 64px rgba(0,0,0,.2),0 8px 20px rgba(0,0,0,.1)}html{font-size:16px;-webkit-text-size-adjust:100%;color-scheme:light}body{font-family:var(--sans);background:var(--bg);color:var(--t1);min-height:100dvh;-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{max-width:430px;margin:0 auto;min-height:100dvh;background:var(--bg);position:relative;isolation:isolate}::-webkit-scrollbar{width:2px}::-webkit-scrollbar-thumb{background:var(--s4);border-radius:2px}h1{font-size:24px;font-weight:700;letter-spacing:-.5px;line-height:1.2}h2{font-size:19px;font-weight:700;letter-spacing:-.3px}h3{font-size:15px;font-weight:600}p{line-height:1.65}.topbar{position:sticky;top:0;z-index:100;background:#f7f5f1eb;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:.5px solid var(--border2);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px}.topbar-brand{font-family:var(--serif);font-size:22px;color:var(--brand);letter-spacing:-.5px;line-height:1}.topbar-loc{font-size:11px;color:var(--t2);font-weight:500;display:flex;align-items:center;gap:3px}.plat-wrap{display:flex;gap:3px;background:var(--s2);border-radius:20px;padding:3px;border:.5px solid var(--border2)}.plat-btn{padding:4px 11px;border-radius:20px;font-size:11px;font-weight:700;border:none;cursor:pointer;transition:all .18s;background:transparent;color:var(--t4);font-family:var(--sans)}.plat-btn.on{color:#fff}.bos-toggle{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:20px;border:1px solid var(--border2);background:var(--surface);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .25s cubic-bezier(.4,0,.2,1)}.bos-toggle.on{border-color:var(--bodyos);background:var(--blight)}.bos-label{font-size:11px;font-weight:700;color:var(--t3);transition:color .2s}.bos-toggle.on .bos-label{color:var(--bodyos)}.track{width:28px;height:16px;border-radius:8px;background:var(--s3);position:relative;transition:background .25s;flex-shrink:0}.bos-toggle.on .track{background:var(--bodyos)}.thumb{position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:transform .25s cubic-bezier(.34,1.56,.64,1);box-shadow:0 1px 3px #00000040}.bos-toggle.on .thumb{transform:translate(12px)}.botnav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:#f7f5f1f7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:.5px solid var(--border2);display:flex;padding:8px 0 20px;z-index:200}.botnav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;cursor:pointer;padding:4px 0;color:var(--t4);font-family:var(--sans);transition:color .15s}.botnav-btn.on{color:var(--brand)}.botnav-icon{font-size:19px;line-height:1}.botnav-label{font-size:10px;font-weight:600;letter-spacing:.3px}.card{background:var(--surface);border:.5px solid var(--border2);border-radius:var(--r-lg);padding:16px;box-shadow:var(--sh1)}.card-sm{background:var(--surface);border:.5px solid var(--border2);border-radius:var(--r-md);padding:12px 14px;box-shadow:var(--sh1)}.pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px;white-space:nowrap}.p-green{background:var(--green-bg);color:var(--green)}.p-amber{background:var(--amber-bg);color:var(--amber)}.p-red{background:var(--red-bg);color:var(--red)}.p-blue{background:var(--blue-bg);color:var(--blue)}.p-gray{background:var(--s2);color:var(--t2)}.p-bos{background:var(--blight);color:var(--bodyos)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 20px;border-radius:var(--r-md);font-family:var(--sans);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.42;cursor:not-allowed;transform:none}.btn-brand{background:var(--brand);color:#fff;box-shadow:0 2px 8px #e237444d}.btn-bos{background:var(--bodyos);color:#fff;box-shadow:0 2px 8px #1a6b4a4d}.btn-soft{background:var(--s2);color:var(--t1);border:.5px solid var(--border)}.btn-block{width:100%}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#08060499;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:400;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.modal-sheet{background:var(--surface);border-radius:24px 24px 0 0;width:100%;max-width:430px;max-height:92dvh;overflow-y:auto;padding:22px 18px 44px;box-shadow:var(--sh4);animation:slideUp .32s cubic-bezier(.34,1.16,.64,1)}.modal-handle{width:36px;height:4px;background:var(--s3);border-radius:2px;margin:0 auto 20px}.spinner{width:32px;height:32px;border-radius:50%;border:2.5px solid var(--s3);border-top-color:var(--bodyos);animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes popIn{0%{transform:scale(.9);opacity:0}60%{transform:scale(1.02)}to{transform:scale(1);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes glowPulse{0%,to{box-shadow:0 4px 20px #1a6b4a59,0 2px 8px #1a6b4a33}50%{box-shadow:0 6px 32px #1a6b4a8c,0 4px 12px #1a6b4a4d}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}.enter-1{animation:popIn .35s ease both}.enter-2{animation:popIn .35s .07s ease both}.enter-3{animation:popIn .35s .14s ease both}.enter-4{animation:popIn .35s .21s ease both}.enter-5{animation:popIn .35s .28s ease both}.slide-down{animation:slideDown .25s ease both}.fade-in{animation:fadeIn .3s ease both}.skeleton{background:linear-gradient(90deg,var(--s2) 25%,var(--s3) 50%,var(--s2) 75%);background-size:400px 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-md)}.dot-pulse{display:flex;gap:5px;align-items:center}.dot-pulse span{width:7px;height:7px;border-radius:50%;background:var(--t3);animation:pulse 1.2s ease-in-out infinite}.dot-pulse span:nth-child(2){animation-delay:.2s}.dot-pulse span:nth-child(3){animation-delay:.4s}.fab{position:fixed;z-index:150;width:56px;height:56px;border-radius:50%;background:var(--bodyos);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:26px;animation:glowPulse 3s ease-in-out infinite;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.fab:hover{transform:scale(1.1)}.fab:active{transform:scale(.94)}.aqi-gauge-track{stroke:#ffffff26}.aqi-gauge-fill{stroke-linecap:round;transition:stroke-dasharray .8s ease}.macro-row{display:flex;align-items:center;gap:8px;margin-bottom:7px}.macro-label{font-size:11px;color:var(--t3);min-width:50px;font-weight:500}.macro-track{flex:1;height:5px;background:var(--s2);border-radius:3px;overflow:hidden}.macro-fill{height:100%;border-radius:3px;transition:width .6s ease}.macro-val{font-size:11px;color:var(--t2);min-width:44px;text-align:right;font-weight:600}
