@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--primary:#002147;--highlight:gold;--background:#f2f2f2;--card:#fff;--text-primary:#000;--text-secondary:#333;--text-light:#fff;--shadow:0 2px 10px #00000026;--header-bg:#002147}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dark-theme{--primary:#4c8df5;--highlight:gold;--background:#111727;--card:#232939;--text-primary:#fff;--text-secondary:#e0e0e0;--text-light:#fff;--shadow:0 2px 10px #0000004d;--border:#444;--header-bg:#111727}body{background-color:var(--background);color:var(--text-primary);-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px}.trimsmart-app{max-width:100%;min-height:100vh;padding-top:calc(60px + env(safe-area-inset-top));padding-bottom:calc(100px + env(safe-area-inset-bottom));overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;position:relative;overflow-x:hidden}.content-wrapper{will-change:transform;width:100%;transition:transform .3s ease-out}.app-header{background-color:var(--header-bg,#002147);color:var(--text-light);width:100%;height:60px}h2,h3{color:var(--text-primary);font-weight:700}.bottom-nav{background-color:var(--background);height:calc(80px + env(safe-area-inset-bottom));padding:10px 8px;padding-bottom:calc(10px + env(safe-area-inset-bottom));z-index:1000;border-top:1px solid var(--border);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{width:23.5%;height:105px;color:var(--primary);background-color:var(--card);border:1px solid var(--border);border-radius:10px;flex-direction:column;justify-content:center;align-items:center;margin:0 2px;padding:8px 0;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:flex;box-shadow:0 2px 4px #0000000d}.nav-item span,.dark-theme .nav-item span,.nav-item.active span,.dark-theme .nav-item.active span{word-break:break-word;word-wrap:break-word;overflow-wrap:break-word;padding:0 2px;text-align:center!important;box-sizing:border-box!important;width:100%!important;display:block!important}@media (width<=370px){.nav-item{width:24%;height:82px;margin:0 1px;padding:6px 0}.nav-icon{margin-bottom:4px}}.nav-item.active{color:var(--highlight);background-color:var(--primary);border-color:var(--primary)}.dark-theme .nav-item{color:var(--text-secondary)}.nav-item.active span{color:var(--highlight)}.nav-icon-img{object-fit:contain;filter:brightness(0)saturate()invert(12%)sepia(66%)saturate(1455%)hue-rotate(194deg)brightness(96%)contrast(101%);width:44px;height:44px}.nav-item.active .nav-icon-img{filter:brightness(0)saturate()invert(83%)sepia(28%)saturate(1728%)hue-rotate(359deg)brightness(103%)contrast(104%)}.nav-item span{text-align:center;box-sizing:border-box;text-overflow:ellipsis;width:100%;padding:0 2px;display:block;overflow:hidden}.dark-theme .nav-item{background-color:#2a2a2a;border-color:#444}.dark-theme .nav-item.active{border-color:var(--highlight);background-color:#1a1a1a}.dark-theme .nav-icon-img{filter:brightness(0)saturate()invert(80%)sepia(0%)saturate(0%)hue-rotate(137deg)brightness(97%)contrast(92%)}.trimsmart-app{padding-bottom:calc(100px + env(safe-area-inset-bottom))}.dark-theme .settings-card{background-color:#2a2a2a;border-color:#444}.dark-theme .header-card{background-color:#333}.dark-theme .header-card h3{color:#fff}.dark-theme .toggle-icon{color:#bbb}.dark-theme .settings-content li{color:#eee;border-bottom-color:#444}.dark-theme .settings-content strong{color:#fff}.dark-theme .settings-value{color:#eee}.dark-theme .settings-label{color:#fff}.dark-theme .settings-item .settings-label{color:#ddd}.dark-theme .settings-item .settings-value{color:#fff;font-weight:500}.dark-theme .settings-help-link{border-top-color:#444}.dark-theme .settings-help-link a{color:#6da4ff}.dark-theme .settings-help-link a:hover{color:#8ab8ff}.tab-content{margin-top:calc(60px + env(safe-area-inset-top));padding:8px 15px 15px;animation:.3s ease-in-out fadeIn;display:none}.tab-content.active{display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.card{background-color:var(--card);border:1px solid var(--border);box-sizing:border-box;border-radius:8px;width:100%;min-height:200px;margin:8px auto;padding:18px}.card+.card{margin-top:20px}.nav-icon{justify-content:center;align-items:center;height:40px;margin-bottom:6px;display:flex}.nav-icon-img{object-fit:contain;width:38px;height:38px}.card-header{border-bottom:1px solid #0000001a;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;padding-left:5px;padding-right:5px;display:flex}.card-title{color:var(--text-primary);margin:0;font-size:26px;font-weight:700}.pull-refresh-hint{color:var(--text-secondary);opacity:.7;justify-content:center;align-items:center;gap:8px;margin:10px 0;padding:8px;font-size:12px;transition:opacity .3s;display:flex}.pull-refresh-hint.refreshing{opacity:1;color:var(--primary);font-weight:600}.pull-refresh-hint.ready{opacity:1;color:var(--success,#28a745);font-weight:700;transition:all .2s;transform:scale(1.05)}.pull-refresh-hint.ready .pull-icon{color:var(--success,#28a745);animation:.8s ease-in-out infinite readyPulse}@keyframes readyPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.pull-icon{font-size:14px;animation:2s ease-in-out infinite pullBounce}.pull-refresh-hint.refreshing .pull-icon{animation:1s linear infinite spin}@keyframes pullBounce{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}.dark-theme .pull-refresh-hint{color:var(--text-secondary)}@media (width>=768px){.pull-refresh-hint{display:none}}.weather-grid{flex-wrap:wrap;justify-content:center;gap:20px;min-height:140px;margin-bottom:28px;display:flex}.weather-item{text-align:center;background-color:#00000005;border-radius:12px;flex-direction:column;flex:1;align-items:center;min-width:140px;max-width:160px;padding:15px 20px;display:flex}.dark-theme .weather-item{background-color:#ffffff0d}.weather-icon{margin-bottom:12px;font-size:36px}.weather-label{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:600}.weather-value{color:var(--text-primary);font-size:26px;font-weight:700}.weather-gust-value{color:var(--text-secondary);margin-top:4px;font-size:18px;font-weight:500;line-height:1.2}@media (width<=480px){.weather-grid{gap:15px;margin-bottom:20px}.weather-item{min-width:130px;max-width:150px;padding:12px 15px}.weather-icon{margin-bottom:10px;font-size:32px}.weather-label{margin-bottom:6px;font-size:14px}.weather-value{font-size:22px}.weather-gust-value{margin-top:3px;font-size:16px}}@media (width<=360px){.weather-grid{gap:12px}.weather-item{min-width:110px;max-width:130px;padding:10px 12px}.weather-icon{margin-bottom:8px;font-size:28px}.weather-label{margin-bottom:5px;font-size:13px}.weather-value{font-size:20px}.weather-gust-value{margin-top:2px;font-size:14px}}@media (width>=481px) and (width<=768px){.weather-grid{gap:25px}.weather-item{min-width:160px;max-width:180px;padding:18px 25px}.weather-icon{margin-bottom:14px;font-size:40px}.weather-label{margin-bottom:10px;font-size:17px}.weather-value{font-size:28px}.weather-gust-value{margin-top:4px;font-size:20px}}.settings-list{min-height:250px}.manual-wind-section{background-color:#0000000d;border-radius:8px;flex-direction:column;margin-top:20px;padding:10px;display:flex}.settings-item{padding:18px 0}.settings-label,.settings-value{font-size:20px}.weather-card{background-color:var(--card)}.manual-wind-section{background-color:#0000000d;border-radius:8px;flex-direction:column;padding:10px;display:flex}.manual-wind-title{margin-bottom:10px;font-size:16px;font-weight:600}.input-group{gap:6px;display:flex}.wind-input{border:2px solid var(--primary);text-align:center;height:48px;color:var(--text-primary);background-color:var(--card);border-radius:8px;flex:1;padding:0 15px;font-size:15px;font-weight:500}.refresh-button{color:#777;cursor:pointer;background-color:#0000;border:none;justify-content:center;align-items:center;width:48px;height:48px;margin:0;padding:0;font-size:22px;transition:transform .3s;display:flex}.refresh-button:hover{color:#555;transform:rotate(30deg)}.refresh-button:active{transform:rotate(180deg)}.dark-theme .refresh-button{color:#aaa}.theme-toggle{cursor:pointer;color:var(--text-primary);background:0 0;border:none;font-size:20px;position:absolute;top:20px;right:20px}.toast{background-color:var(--primary);color:var(--text-light);z-index:1200;opacity:0;white-space:nowrap;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #fff3;border-radius:12px;flex-flow:row;justify-content:center;align-items:center;gap:8px;max-width:90vw;padding:16px 24px;font-size:16px;font-weight:600;transition:all .3s ease-in-out;display:flex;position:fixed;bottom:80px;left:50%;transform:translate(-50%)translateY(20px);box-shadow:0 6px 20px #0000004d}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.settings-list{margin:0;padding:0;list-style-type:none}.settings-item{border-bottom:1px solid #0000001a;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.settings-item:last-child{border-bottom:none}.settings-label{color:var(--text-primary);font-size:18px;font-weight:600}.settings-value{color:var(--primary);font-size:18px;font-weight:500}.profile-dropdown{z-index:2000;opacity:0;pointer-events:none;background-color:#00000080;justify-content:center;align-items:flex-end;transition:opacity .3s;display:flex;position:fixed;inset:0}.profile-dropdown.open{opacity:1;pointer-events:auto}.profile-content{background-color:var(--card);border-top-left-radius:16px;border-top-right-radius:16px;width:100%;max-width:500px;padding:20px;transition:transform .3s;transform:translateY(100%)}.profile-dropdown.open .profile-content{transform:translateY(0)}.profile-header{text-align:center;margin-bottom:20px}.profile-name{margin:0 0 5px;font-size:24px;font-weight:700}.profile-info{color:var(--text-secondary);font-size:16px}.logout-button{color:#fff;cursor:pointer;background-color:#d32f2f;border:none;border-radius:8px;width:100%;margin-top:20px;padding:16px;font-size:18px;font-weight:600}.logout-button:hover{background-color:#b71c1c}.profile-links{border-top:1px solid #0000001a;border-bottom:1px solid #0000001a;flex-direction:column;margin:15px 0;padding:15px 0;display:flex}.profile-link{color:var(--primary);padding:12px 0;font-size:16px;font-weight:500;text-decoration:none;transition:opacity .2s}.profile-link:hover{opacity:.8}.profile-footer{color:var(--text-secondary);border-top:1px solid #0000001a;margin-top:20px;padding-top:15px;font-size:13px;line-height:1.5}.profile-footer a{color:var(--primary);text-decoration:none}.profile-footer a:hover{text-decoration:underline}.dark-theme .profile-links,.dark-theme .profile-footer{border-color:#ffffff1a}.dark-theme .profile-link,.dark-theme .profile-footer a{color:#6da4ff}@media (width>=768px){.trimsmart-app{max-width:100%;margin:0 auto;padding-left:1px;padding-right:11px}.bottom-nav{max-width:100%;left:0;right:0;transform:none}}.card{width:100%;padding:10px}@media (width>=1400px){.trimsmart-app{max-width:1200px;margin:0 auto}.bottom-nav{max-width:1200px;left:50%;transform:translate(-50%)}}.tab-content{padding-left:1px;padding-right:1px}@media (width<=768px){.wind-arrow{width:80px;height:80px}.compass-needle{width:55px;height:55px}}@media (width<=400px){.wind-arrow{width:70px;height:70px}.compass-needle{width:48px;height:48px}.compass-label{font-size:12px}.compass-center{width:8px;height:8px}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.update-button{background-color:var(--primary);height:52px;color:var(--text-light);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;flex-shrink:0;margin-left:-23px;padding:0 15px;font-size:16px;font-weight:600;transition:all .2s}.update-button:hover{opacity:.9}.update-button:active{transform:translateY(1px)}.app-header{background-color:var(--header-bg);color:var(--text-light);z-index:1010;box-sizing:border-box;justify-content:center;align-items:center;width:100%;height:60px;padding:0 15px;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 4px #0000001a}.gold-filter{filter:invert(83%)sepia(42%)saturate(591%)hue-rotate(359deg)brightness(107%)contrast(107%)}.header-logo{object-fit:contain;width:auto;max-width:80%;height:auto;max-height:36px}.trimsmart-app{padding-top:calc(60px + env(safe-area-inset-top));padding-bottom:calc(100px + env(safe-area-inset-bottom))}.tab-content{margin-top:calc(60px + env(safe-area-inset-top));padding:5px 10px 15px}.card{margin:8px auto;padding:18px}.tab-content.active>.card:first-child{margin-top:4px}.theme-toggle{top:70px}.profile-dropdown{max-height:calc(100vh - 60px);top:60px}.toast{bottom:100px}@media (width<=360px){.app-header{height:50px;padding:0 10px}.header-logo{max-width:85%;max-height:30px}.trimsmart-app{padding-top:calc(50px + env(safe-area-inset-top))}}@media (width>=361px) and (width<=480px){.header-logo{max-height:32px}}@media (width>=481px) and (width<=768px){.app-header{height:65px}.header-logo{max-height:40px}.trimsmart-app{padding-top:calc(65px + env(safe-area-inset-top))}}@media (width>=769px){.app-header{height:70px}.header-logo{max-height:45px}.trimsmart-app{padding-top:calc(70px + env(safe-area-inset-top))}}.card-title-icon{vertical-align:middle;filter:brightness(0)saturate()invert(12%)sepia(66%)saturate(1455%)hue-rotate(194deg)brightness(96%)contrast(101%);width:24px;height:24px;margin-right:8px;position:relative;top:-2px}.dark-theme .card-title-icon{filter:brightness(0)saturate()invert(83%)sepia(28%)saturate(1728%)hue-rotate(359deg)brightness(103%)contrast(104%)}.dark-theme .trimsmart-app,.dark-theme .tab-content{background-color:var(--background)}.dark-theme .manual-wind-title{color:var(--text-primary)}.dark-theme .manual-wind-section{background-color:#ffffff0d}.location{color:var(--text-primary);margin-bottom:15px;font-size:16px;font-weight:500}.dark-theme .location{color:var(--text-primary)}.scroll-dots{opacity:0;z-index:5;gap:4px;transition:opacity .3s;display:flex;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.scroll-dot{background-color:var(--primary);opacity:.5;border-radius:50%;width:6px;height:6px}.tab-content.has-overflow .scroll-dots{opacity:1}.card{box-sizing:border-box;width:100%!important}.wind-arrow-container{flex-direction:column;align-items:center;margin:12px 0 20px;display:flex}.wind-arrow{background-color:#0000;border:none;justify-content:center;align-items:center;width:120px;height:120px;display:flex;position:relative}.compass-background{object-fit:contain;z-index:1;background-color:#0000;border-radius:50%;width:100%;height:100%;position:absolute}.dark-theme .compass-background{mix-blend-mode:screen;background-color:var(--card)!important}.compass-needle-container{z-index:2;width:100%;height:100%;position:absolute}.compass-needle{background-image:url(/arrowred.png);background-position:50%;background-repeat:no-repeat;background-size:contain;width:65px;height:65px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.dark-theme .wind-arrow{background-color:#2a2a2a;border-color:#444}.wind-direction-label{color:#333;margin-top:5px;font-size:16px;font-weight:600}.dark-theme .wind-direction-label{color:#eee}@media (width<=768px){.wind-arrow{width:80px;height:80px}.compass-needle{width:55px;height:55px}}@media (width<=400px){.wind-arrow{width:70px;height:70px}.compass-needle{width:48px;height:48px}.compass-label{font-size:12px}.compass-center{width:8px;height:8px}}.theme-toggle-container{border-top:1px solid #eee;border-bottom:1px solid #eee;justify-content:space-between;align-items:center;margin:15px 0;padding:10px 15px;display:flex}.theme-label{color:#333;font-size:16px;font-weight:500}.dark-theme .theme-label{color:#ddd}.theme-toggle-switch{cursor:pointer;background-color:#ccc;border-radius:15px;width:60px;height:30px;transition:background-color .3s;position:relative}.theme-toggle-switch.active,.dark-theme .theme-toggle-switch{background-color:#4a6da7}.theme-toggle-slider{background-color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:transform .3s;display:flex;position:absolute;top:3px;left:3px}.theme-toggle-slider.active{transform:translate(30px)}.refresh-button.rotating{animation:1.5s linear infinite rotate}.refresh-button:disabled{opacity:.7;cursor:not-allowed}.editable-setting-input{width:100%;color:var(--text-primary);box-sizing:border-box;background-color:#f9f9f9;border:1px solid #a3c1e6;border-radius:4px;margin-top:4px;margin-bottom:4px;padding:8px 10px;font-size:16px}.dark-theme .editable-setting-input{background-color:var(--card);color:var(--text-primary);border:1px solid #4c8df5}.button-group{gap:8px;margin-top:12px;display:flex}.save-button{color:#fff;cursor:pointer;background-color:#4c8df5;border:none;border-radius:6px;padding:8px 12px;font-size:16px;transition:background-color .2s,box-shadow .2s}.save-button:hover{background-color:#3b6ac3;box-shadow:0 2px 4px #0003}.reset-button{color:#d32f2f;cursor:pointer;background-color:#0000;border:1px solid #d32f2f;border-radius:6px;margin-left:8px;padding:6px 10px;font-size:14px;transition:background-color .2s,color .2s,font-weight .2s}.reset-button:hover{color:#b71c1c;background-color:#fbe9e7;font-weight:700}.dark-theme .reset-button{color:#ff6b6b;border-color:#ff6b6b}.dark-theme .reset-button:hover{color:#ff3b3b;background-color:#ff6b6b1a;font-weight:700}.save-button:disabled,.reset-button:disabled{opacity:.6;cursor:not-allowed;background-color:#ccc}.dark-theme .save-button:disabled,.dark-theme .reset-button:disabled{background-color:#555}.location{justify-content:space-between;align-items:center;display:flex}.location-override-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;padding:5px;font-size:18px;transition:background-color .3s}.enable-location-btn{background:var(--primary);color:var(--text-light);cursor:pointer;border:none;border-radius:20px;margin-left:10px;padding:8px 12px;font-size:12px;font-weight:500;transition:all .3s}.enable-location-btn:hover{background:var(--highlight);color:var(--primary);transform:translateY(-1px)}.enable-location-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.help-btn{background:var(--highlight);color:var(--primary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;min-width:24px;height:24px;margin-left:8px;padding:6px 8px;font-size:12px;font-weight:700;transition:all .3s;display:inline-flex}.help-btn:hover{background:var(--primary);color:var(--text-light);transform:scale(1.1)}.modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--card);width:100%;max-width:400px;max-height:90vh;box-shadow:var(--shadow);border-radius:12px;padding:20px;overflow-y:auto}.location-override-modal h3{color:var(--text-primary);margin-bottom:15px}.location-override-modal p{color:var(--text-secondary);margin-bottom:20px}.coord-input-group{margin-bottom:15px}.coord-input-group label{color:var(--text-primary);margin-bottom:5px;font-weight:500;display:block}.coord-input-group input{background-color:var(--card);width:100%;color:var(--text-primary);border:1px solid #ddd;border-radius:6px;padding:10px;font-size:16px}.dark-theme .coord-input-group input{background-color:#333;border-color:#555}.location-suggestions{margin:20px 0}.location-suggestions h4{color:var(--text-primary);margin-bottom:10px}.suggestions-grid{grid-template-columns:1fr;gap:8px;max-height:200px;display:grid;overflow-y:auto}.suggestion-btn{background-color:var(--primary);color:var(--text-light);cursor:pointer;border:none;border-radius:6px;padding:8px 12px;font-size:14px;transition:background-color .3s}.suggestion-btn:hover{background-color:var(--highlight);color:var(--text-primary)}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.cancel-btn,.apply-btn{cursor:pointer;border:none;border-radius:6px;padding:10px 20px;font-size:16px;transition:background-color .3s}.cancel-btn{color:#fff;background-color:#6c757d}.cancel-btn:hover{background-color:#5a6268}.apply-btn{background-color:var(--primary);color:var(--text-light)}.apply-btn:hover{background-color:var(--highlight);color:var(--text-primary)}body{color:#333;background-color:#f5f5f5;margin:0;padding:0;font-family:Inter,Arial,sans-serif;font-size:16px}.enhanced-login-container{justify-content:center;align-items:center;min-height:100vh;padding:15px;display:flex}.login-card{box-sizing:border-box;text-align:center;background-color:#fff;border-radius:16px;width:calc(100% - 20px);max-width:500px;margin:0 auto;padding:30px;box-shadow:0 4px 20px #00000014}.logo,.brand-logo{width:auto;max-height:70px;margin:0 auto 30px;display:block}.logo-fallback{background-color:#4a6da7;border-radius:14px;justify-content:center;align-items:center;width:70px;height:70px;margin:0 auto 30px;display:flex}.logo-text{color:#fff;letter-spacing:1px;font-size:28px;font-weight:600}h1,h2,.login-header h1{color:#333;letter-spacing:-.5px;margin-bottom:20px;font-size:32px;font-weight:700}.welcome-text,.login-subtitle{color:#555;margin-bottom:35px;font-size:18px;line-height:1.5}.scan-button,.primary-button,.nfc-scan-btn{color:#fff;cursor:pointer;box-sizing:border-box;background:linear-gradient(90deg,#4a6da7,#5d7fb9);border:none;border-radius:10px;width:100%;min-height:52px;margin-bottom:30px;padding:14px 24px;font-size:17px;font-weight:500;transition:all .2s;box-shadow:0 4px 12px #4a6da733}.scan-button:hover,.primary-button:hover,.nfc-scan-btn:hover{background:linear-gradient(90deg,#5d7fb9,#6e90ca);transform:translateY(-2px);box-shadow:0 6px 15px #4a6da740}.scan-button:disabled,.primary-button:disabled,.nfc-scan-btn:disabled{cursor:not-allowed;box-shadow:none;background:linear-gradient(90deg,#a0a0a0,#b8b8b8);transform:none}.divider{color:#777;align-items:center;margin:30px 0;font-size:15px;display:flex}.divider:before,.divider:after{content:"";border-bottom:1px solid #e0e0e0;flex:1}.divider span{padding:0 18px}.input-group,.login-field{height:52px;margin-bottom:25px;display:flex}.input-group input,.login-field input,.input-field{box-sizing:border-box;border:1px solid #ddd;border-radius:10px;flex:1;width:100%;max-width:calc(100% - 90px);height:100%;padding:14px 18px;font-size:16px;transition:border-color .2s,box-shadow .2s}.input-group input{border-radius:10px 0 0 10px;max-width:calc(100% - 90px)}.input-group input:focus,.login-field input:focus,.input-field:focus{border-color:#4a6da7;outline:none;box-shadow:0 0 0 2px #4a6da71a}.input-group button,.login-field button,.go-button{color:#fff;cursor:pointer;background:linear-gradient(90deg,#4a6da7,#5d7fb9);border:none;border-radius:0 10px 10px 0;min-width:60px;height:100%;padding:0 20px;font-size:16px;font-weight:500;transition:all .2s}.input-group button:hover,.login-field button:hover,.go-button:hover{background:linear-gradient(90deg,#5d7fb9,#6e90ca)}@media (width<=280px){.input-group,.login-field{flex-direction:column;gap:8px;height:auto}.input-group input,.login-field input{border-radius:8px;width:100%;max-width:100%;height:44px}.input-group button,.login-field button,.go-button{border-radius:8px;width:100%;min-width:100%;height:44px}}.coach-mode-container,.session-option{justify-content:center;margin:20px 0;display:flex}.coach-mode-label{align-items:center;gap:8px;display:flex}.info-icon-container{cursor:pointer;align-items:center;display:inline-flex;position:relative}.info-icon{opacity:.7;width:18px;height:18px}.tooltip{color:#fff;white-space:nowrap;z-index:100;background-color:#333;border-radius:6px;margin-bottom:8px;padding:8px 12px;font-size:14px;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 2px 10px #0003}.tooltip:after{content:"";border:5px solid #0000;border-top-color:#333;margin-left:-5px;position:absolute;top:100%;left:50%}.coach-mode-label label,.session-option{cursor:pointer;color:#555;align-items:center;gap:15px;font-size:16px;display:flex}.coach-mode-label input[type=checkbox],.session-option input[type=checkbox]{cursor:pointer;accent-color:#4a6da7;width:18px;height:18px;margin:0}.session-option{color:#555;justify-content:center;align-items:center;gap:12px;margin:25px 0;font-size:16px;display:flex}.session-option input[type=checkbox]{cursor:pointer;accent-color:#4a6da7;width:20px;height:20px;margin-right:4px}.error-message,.error-text{color:#d32f2f;background-color:#ffebee;border-radius:10px;margin-bottom:25px;padding:14px;font-size:16px;box-shadow:0 2px 8px #d32f2f1a}.help-message,.help-text{color:#777;margin-top:30px;font-size:15px;font-style:italic;line-height:1.5}.version-info,.app-footer{color:#4b5563;text-align:center;margin-top:15px;font-family:monospace;font-size:11px}.support-section{margin-top:20px;padding-top:20px}.support-section hr{border:none;border-top:1px solid #e0e0e0;margin:0 0 15px}.support-section p{color:#666;text-align:center;margin:8px 0;font-size:14px}.support-section p:first-of-type{color:#333;margin-bottom:10px;font-size:16px;font-weight:600}.support-section p:nth-of-type(2){color:#444;margin-bottom:5px;font-weight:500}.support-section p:nth-of-type(3){color:#1976d2;background-color:#f5f5f5;border-radius:6px;margin:10px 0;padding:8px 12px;font-family:monospace;font-weight:600}.support-section p small{color:#888;font-style:italic}@media (width<=768px){.login-card{padding:25px 20px}h1,h2,.login-header h1{margin-top:10px;margin-bottom:15px;font-size:28px}.welcome-text,.login-subtitle{margin-bottom:20px;font-size:16px;line-height:1.4}.divider{margin:20px 0}}@media (width<=375px){.login-card{padding:20px 15px}h1,h2,.login-header h1{margin-bottom:12px;font-size:24px}.welcome-text,.login-subtitle{margin-bottom:18px;font-size:15px;line-height:1.3}.logo,.logo-fallback,.brand-logo{height:50px;max-height:50px;margin-bottom:15px}.scan-button,.primary-button,.nfc-scan-btn{min-height:48px;padding:12px 18px;font-size:16px}.input-group,.login-field{height:48px}.input-group input,.login-field input,.input-group button,.login-field button{font-size:15px}.input-group input,.login-field input{padding:0 10px}.session-option,.help-message,.help-text{font-size:14px}}@media (width<=320px){.login-card{padding:15px 12px}h1,h2,.login-header h1{font-size:22px}.welcome-text,.login-subtitle{margin-bottom:15px;font-size:14px}.scan-button,.primary-button,.nfc-scan-btn{min-height:44px;padding:10px;font-size:14px}.input-group,.login-field{flex-direction:column;gap:10px}.input-group input,.login-field input,.input-group button,.login-field button{border-radius:8px;width:100%;height:44px}.session-option,.help-message,.help-text{font-size:13px}}.input-group button,.login-field button,.go-button{letter-spacing:.5px;white-space:nowrap;min-width:100px;margin-left:-3px;padding:0 16px;font-size:16px;font-weight:500}@media (width<=375px){.input-group,.login-field{height:48px}.input-group button,.login-field button,.go-button{min-width:70px;padding:0 12px;font-size:15px}.input-group input,.login-field input{padding:0 10px}}@media (height<=500px) and (orientation:landscape){.enhanced-login-container{padding:10px}.login-card{margin:5px auto;padding:12px}.logo,.logo-fallback,.brand-logo{height:40px;max-height:40px;margin-bottom:10px}h1,h2,.login-header h1{margin:5px 0 10px;font-size:20px}.welcome-text,.login-subtitle{margin-bottom:10px}.scan-button,.primary-button,.nfc-scan-btn{min-height:40px;padding:8px}.divider{margin:10px 0}.input-group input,.login-field input,.input-group button,.login-field button{min-height:40px}.session-option{margin:10px 0}}.copyright-info{color:#777;text-align:center;margin-top:20px;font-size:12px;line-height:1.5}.copyright-info p{color:#777;margin-top:8px;font-size:11px;font-weight:400}.copyright-info a{color:#04c;margin:0 3px;text-decoration:none}.copyright-info a:hover{text-decoration:underline}.step-indicator{justify-content:center;gap:10px;margin-bottom:20px;display:flex}.step{background-color:#ddd;border-radius:50%;width:8px;height:8px;transition:background-color .2s}.step.active{background-color:#4a6da7}.step.completed{background-color:#28a745}.recovery-link{color:#4a6da7;margin-top:15px;font-size:14px;text-decoration:none;display:inline-block}.recovery-link:hover{text-decoration:underline}.login-header p{color:#666;margin:0;font-size:15px}.login-step{padding:25px}.login-step h2{color:#1d1d1f;text-align:center;margin:0 0 8px;font-size:20px;font-weight:600}.login-step p{color:#666;text-align:center;margin:0 0 25px;font-size:14px;line-height:1.4}.input-group{margin-bottom:20px}.input-group label{color:#333;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.nfc-input,.totp-input,.recovery-input{box-sizing:border-box;border:2px solid #e5e5e5;border-radius:8px;width:100%;padding:14px 16px;font-size:16px;transition:border-color .2s,box-shadow .2s}.totp-input{text-align:center;letter-spacing:4px;font-family:Courier New,monospace;font-size:20px}.nfc-input:focus,.totp-input:focus,.recovery-input:focus{border-color:#007aff;outline:none;box-shadow:0 0 0 3px #007aff1a}.nfc-input:disabled,.totp-input:disabled,.recovery-input:disabled{color:#666;cursor:not-allowed;background:#f8f9fa}.input-group small{color:#666;margin-top:4px;font-size:12px;display:block}.login-actions{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.login-support{color:#666;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;font-size:14px;line-height:1.4;display:flex}.login-support a{color:#007aff;font-weight:600;text-decoration:none}.login-support a:hover{text-decoration:underline}.btn-primary{color:#fff;cursor:pointer;background:#007aff;border:none;border-radius:8px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:background-color .2s}.btn-primary:hover:not(:disabled){background:#0056b3}.btn-primary:disabled{cursor:not-allowed;background:#ccc}.btn-secondary{color:#007aff;cursor:pointer;background:0 0;border:2px solid #007aff;border-radius:8px;width:100%;padding:12px;font-size:14px;font-weight:500;transition:all .2s}.btn-secondary:hover:not(:disabled){color:#fff;background:#007aff}.btn-secondary:disabled{color:#ccc;cursor:not-allowed;border-color:#ccc}.btn-link{color:#007aff;cursor:pointer;background:0 0;border:none;padding:8px 0;font-size:14px;text-decoration:underline;transition:color .2s}.btn-link:hover{color:#0056b3}.coach-mode{border-top:1px solid #f0f0f0;margin-top:20px;padding-top:20px;position:relative}.checkbox-label{color:#333;cursor:pointer;align-items:center;font-size:14px;display:flex}.checkbox-label input[type=checkbox]{margin-right:8px;transform:scale(1.1)}.info-icon-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;margin-left:8px;padding:2px;transition:background-color .2s}.info-icon-btn:hover{background:#f0f0f0}.info-icon-btn img{opacity:.6;width:16px;height:16px}.tooltip{color:#fff;z-index:10;background:#333;border-radius:6px;margin-bottom:8px;padding:8px 12px;font-size:12px;line-height:1.3;position:absolute;bottom:100%;left:0;right:0}.tooltip:after{content:"";border:4px solid #0000;border-top-color:#333;position:absolute;top:100%;left:20px}.login-footer{text-align:center;border-top:1px solid #f0f0f0;padding-top:15px}.app-footer{text-align:center;background:#f8f9fa;border-top:1px solid #f0f0f0;padding:15px 25px}.app-footer p{color:#666;margin:0;font-size:12px}.attempt-warning{color:#ff6b35!important;margin-top:4px!important;font-weight:500!important}.error-message{color:#d32f2f;text-align:center;background:#ffe6e6;border:1px solid #ffcdd2;border-radius:6px;margin:0 25px 20px;padding:12px;font-size:14px;animation:.3s ease-in-out shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@media (width<=480px){.enhanced-login-container{align-items:flex-start;padding:20px 10px 10px}.login-card{border-radius:12px;max-width:none}.login-header{padding:25px 20px 15px}.login-step{padding:20px}.login-header h1{font-size:22px}.login-step h2{font-size:18px}.brand-logo{width:60px;height:60px}.nfc-input,.totp-input,.recovery-input{padding:12px 14px;font-size:16px}.totp-input{letter-spacing:2px;font-size:18px}.tooltip{padding:6px 10px;font-size:11px}}@media (prefers-color-scheme:dark){.login-card{color:#fff;background:#1c1c1e}.login-header{border-bottom-color:#333}.login-header h1{color:#fff}.login-header p,.login-step p{color:#a1a1aa}.login-step h2{color:#fff}.input-group label{color:#f4f4f5}.nfc-input,.totp-input,.recovery-input{color:#fff;background:#2c2c2e;border-color:#444}.nfc-input:focus,.totp-input:focus,.recovery-input:focus{border-color:#007aff}.coach-mode,.login-footer{border-top-color:#333}.checkbox-label{color:#f4f4f5}.app-footer{background:#161618;border-top-color:#333}.app-footer p,.login-support{color:#a1a1aa}}.biometric-btn{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);position:relative;overflow:hidden}.biometric-btn:hover{background:linear-gradient(135deg,#5a6fd8 0%,#6a4190 100%);transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.biometric-btn:disabled{cursor:not-allowed;box-shadow:none;background:#ccc;transform:none}.biometric-info{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;margin:15px 0;padding:15px}.biometric-info ul{margin:0;padding:0;list-style:none}.biometric-info li{color:#555;padding:5px 0;font-size:14px}.biometric-status{text-align:center;background:#e8f5e8;border:1px solid #28a745;border-radius:6px;margin:10px 0;padding:10px}.biometric-status p{color:#155724;margin:2px 0}.biometric-status small{color:#6c757d}@media (width<=480px){.enhanced-login-container{padding:10px}.login-card{padding:20px 15px}.brand-logo{height:40px}.login-header h1{font-size:1.3em}.btn-primary,.btn-secondary{padding:14px 18px;font-size:16px}.totp-input,.nfc-input,.recovery-input{padding:14px;font-size:18px}}.checkbox-group{background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border:1px solid #dee2e6;border-radius:12px;flex-direction:column;gap:8px;margin:20px 0;padding:16px;display:flex}.checkbox-group label{color:#495057;cursor:pointer;align-items:center;gap:12px;font-size:16px;font-weight:500;display:flex}.checkbox-group input[type=checkbox]{cursor:pointer;accent-color:#4a6da7;width:20px;height:20px;transform:scale(1.1)}.checkbox-group small{color:#6c757d;margin-left:32px;font-size:14px;line-height:1.4}.checkbox-group:hover{background:linear-gradient(135deg,#f1f3f4 0%,#e3e6ea 100%)}:root{font-family:Arial,Helvetica,sans-serif;font-weight:400;line-height:1.5}body{background-color:#f5f5f5;min-width:320px;min-height:100vh;margin:0;padding:0}*{box-sizing:border-box}button{cursor:pointer}
