body{overscroll-behavior-y:none;-webkit-overflow-scrolling:touch}@media(max-width:768px){body{font-size:16px}*{-webkit-tap-highlight-color:transparent}button,a,input,select,textarea{min-height:44px}}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:1000;background:#fff;border-top:1px solid rgba(0,0,0,.12);box-shadow:0 -2px 8px #0000001a}@supports (padding: max(0px)){.mobile-bottom-nav{padding-bottom:max(8px,env(safe-area-inset-bottom))}}.mobile-page{min-height:100vh;padding-bottom:80px;background:#f5f5f5}.mobile-content{padding:16px}.mobile-card{background:#fff;border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:0 1px 3px #0000001a}.mobile-card-header{display:flex;align-items:center;margin-bottom:12px;font-weight:600;font-size:16px}.mobile-card-icon{margin-right:8px;width:24px;height:24px}.mobile-list-item{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.06)}.mobile-list-item:last-child{border-bottom:none}.mobile-list-item-avatar{width:40px;height:40px;border-radius:50%;margin-right:12px;flex-shrink:0}.mobile-list-item-content{flex:1;min-width:0}.mobile-list-item-title{font-weight:500;font-size:14px;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-list-item-subtitle{font-size:12px;color:#0009;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-fab{position:fixed;bottom:80px;right:16px;width:56px;height:56px;border-radius:50%;box-shadow:0 4px 12px #0003;z-index:999}.mobile-button-primary{width:100%;height:48px;border-radius:8px;font-weight:600;font-size:16px;text-transform:none}.mobile-button-secondary{width:100%;height:44px;border-radius:8px;font-weight:500;font-size:14px;text-transform:none}.mobile-input{width:100%;height:48px;padding:12px 16px;border:1px solid rgba(0,0,0,.23);border-radius:8px;font-size:16px;background:#fff}.mobile-input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d21a}.mobile-textarea{width:100%;min-height:120px;padding:12px 16px;border:1px solid rgba(0,0,0,.23);border-radius:8px;font-size:16px;font-family:inherit;resize:vertical}.mobile-modal{position:fixed;inset:0;background:#fff;z-index:1300;overflow-y:auto}.mobile-modal-header{position:sticky;top:0;background:#fff;border-bottom:1px solid rgba(0,0,0,.12);z-index:1}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-up{animation:slideUp .3s ease-out}.slide-down{animation:slideDown .3s ease-out}.fade-in{animation:fadeIn .2s ease-in}.pull-to-refresh{position:relative}.pull-to-refresh-indicator{position:absolute;top:-60px;left:50%;transform:translate(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:top .2s ease}.pull-to-refresh.pulling .pull-to-refresh-indicator{top:10px}.swipeable-item{position:relative;overflow:hidden}.swipeable-actions{position:absolute;top:0;right:0;bottom:0;display:flex;align-items:center}.swipeable-action{height:100%;padding:0 24px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;cursor:pointer}.swipeable-action.delete{background:#d32f2f}.swipeable-action.complete{background:#388e3c}.mobile-only{display:none}@media(max-width:768px){.mobile-only{display:block}.desktop-only{display:none!important}}.mobile-text-center{text-align:center}.mobile-mt-1{margin-top:8px}.mobile-mt-2{margin-top:16px}.mobile-mt-3{margin-top:24px}.mobile-mb-1{margin-bottom:8px}.mobile-mb-2{margin-bottom:16px}.mobile-mb-3{margin-bottom:24px}.mobile-p-1{padding:8px}.mobile-p-2{padding:16px}.mobile-p-3{padding:24px}.mobile-skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite;border-radius:4px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.mobile-spinner{width:40px;height:40px;border:4px solid rgba(0,0,0,.1);border-top-color:#1976d2;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(prefers-contrast:high){.mobile-card,.mobile-button-primary{border:2px solid #000}}@media(prefers-color-scheme:dark){.mobile-page{background:#121212}.mobile-card{background:#1e1e1e;color:#fff}.mobile-input,.mobile-textarea{background:#1e1e1e;color:#fff;border-color:#ffffff3b}}
