*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f5f5f5;color:#212121;overscroll-behavior:none;-webkit-overflow-scrolling:touch}input,select,textarea{font-size:16px!important;font-family:inherit}button{min-height:48px;cursor:pointer;font-family:inherit}ul,ol{list-style:none;margin:0;padding:0}html{scroll-behavior:smooth}img{max-width:100%;height:auto}.safe-bottom{padding-bottom:env(safe-area-inset-bottom,0px)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}.chip-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.chip-row::-webkit-scrollbar{display:none}.chip{display:inline-flex;align-items:center;height:34px;padding:0 14px;border-radius:17px;font-size:13px;font-weight:600;white-space:nowrap;border:2px solid transparent;background:#f1f5f9;color:#64748b;cursor:pointer;transition:background .15s,color .15s,border-color .15s;flex-shrink:0;min-height:34px}.chip.active{background:#f59e0b;color:#1e293b;border-color:#d97706}.bottom-sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:flex-end;justify-content:center}.bottom-sheet-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080}.bottom-sheet-panel{position:relative;background:#fff;border-radius:20px 20px 0 0;padding:20px 20px 0;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom,16px);z-index:1}.offline-banner{background:#fef3c7;border-bottom:2px solid #f59e0b;padding:10px 16px;display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:#92400e}.step-bar{height:4px;border-radius:2px;background:#e2e8f0;overflow:hidden}.step-bar-fill{height:100%;background:#f59e0b;border-radius:2px;transition:width .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .25s ease-out forwards}@keyframes checkPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.check-pop{animation:checkPop .4s ease-out forwards}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 1.5s ease-in-out infinite}.install-banner{position:fixed;bottom:72px;left:12px;right:12px;background:#1a237e;color:#fff;border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 20px #00000040;z-index:400;animation:fadeInUp .3s ease-out}.install-banner button.install-btn{background:#f59e0b;color:#1e293b;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:700;min-height:36px;white-space:nowrap}.install-banner button.dismiss-btn{background:none;border:none;color:#fff9;font-size:20px;min-height:32px;padding:0 4px;margin-left:auto}
