.dashboard-layout{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr;grid-template-areas:"wind cards";gap:.1rem;height:100vh;min-height:100vh;width:100vw;box-sizing:border-box}@media (orientation: portrait){.dashboard-layout{display:grid;grid-template-columns:1fr;grid-template-rows:50vh 50vh;grid-template-areas:"wind" "cards";height:100vh;min-height:100vh;width:100vw}.wind-direction-area{grid-area:wind;min-height:0;min-width:0;width:100vw;height:50vh;max-width:100vw;max-height:50vh;box-sizing:border-box;display:flex;align-items:center;justify-content:center;z-index:2}.dashboard-cards-area{grid-area:cards;display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:minmax(0,1fr);gap:.05rem;padding:.1rem;overflow-y:auto;align-items:stretch;justify-items:stretch;width:100vw;height:50vh;max-width:100vw;max-height:50vh;min-height:0;z-index:1}}@media (orientation: landscape){.dashboard-layout{display:grid;grid-template-columns:50vw 50vw;grid-template-rows:1fr;grid-template-areas:"wind cards";height:100vh;min-height:100vh;width:100vw}.wind-direction-area{grid-area:wind;min-height:0;min-width:0;width:100%;height:100vh;max-width:50vw;max-height:100vh;box-sizing:border-box;display:flex;align-items:center;justify-content:center;z-index:2;overflow:hidden}.dashboard-cards-area{grid-area:cards;display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:minmax(0,1fr);gap:.05rem;padding:.1rem;overflow-y:auto;align-items:stretch;justify-items:stretch;width:100%;height:100vh;min-height:0;z-index:1}}.dashboard{width:100%;max-width:1600px;margin:0 auto;height:100%}.wind-direction-area{grid-area:wind;display:flex;align-items:center;justify-content:center;height:100%;width:100%}.dashboard-cards-area{grid-area:cards;display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:minmax(0,1fr);gap:.05rem;height:100%;width:100%;overflow-y:auto;padding:.1rem;align-items:stretch;justify-items:stretch}.card.wind-direction-card{background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;background-color:transparent}.card.wind-direction-card:hover{background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;transform:none;border-color:transparent;background-color:transparent}.wind-direction-card{height:100%;min-height:0;display:flex;flex-direction:column;justify-content:center}.card{background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;transition:all .3s ease;min-height:0;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden;color:var(--text-primary);box-shadow:none;position:relative}.card:hover{transform:translateY(-1px);box-shadow:none;border-color:var(--accent-color)}.card-title{font-size:clamp(.6rem,2vw,.8rem);font-weight:600;opacity:.8;text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary);position:absolute;left:.2rem;top:50%;transform:translateY(-50%) rotate(-90deg);transform-origin:center;white-space:nowrap;z-index:1}.card-value{font-size:clamp(1.8rem,min(12vh,10vw),5rem)!important;font-weight:900;text-align:center;margin:0;flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;line-height:.9;margin-left:1.2rem;margin-right:.2rem;text-shadow:0 2px 8px var(--shadow-color);padding:.05rem;color:var(--text-primary);box-sizing:border-box;overflow:hidden;max-width:calc(100% - 1.4rem);z-index:2}[data-theme=light] .card-value{font-weight:900;text-shadow:0 1px 2px var(--bg-card)}[data-theme=light] .card-title{font-weight:700}.value-unit-row{display:flex;flex-direction:row;align-items:flex-start;gap:.1em;justify-content:center}.value-number{font-weight:900;line-height:1}.card-unit{font-size:clamp(.4rem,min(2vh,1.5vw),.8rem);opacity:.9;font-weight:600;align-self:flex-start;line-height:1;margin-top:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}@media (min-width: 768px){.card-title{left:.3rem;font-size:clamp(.7rem,2.5vw,1rem)}.card-value{font-size:clamp(2.2rem,min(15vh,12vw),6rem)!important;margin-left:1.4rem;max-width:calc(100% - 1.6rem)}.card-unit{font-size:clamp(.5rem,min(3vh,2vw),1rem)}}@media (min-width: 1200px){.card-title{left:.4rem;font-size:clamp(.8rem,3vw,1.2rem)}.card-value{font-size:clamp(2.8rem,min(18vh,15vw),8rem)!important;margin-left:1.6rem;max-width:calc(100% - 1.8rem)}.card-unit{font-size:clamp(.6rem,min(4vh,3vw),1.4rem)}}.gps-grid{display:flex;flex-direction:column;justify-content:center;gap:.3rem;width:100%;height:100%;padding:.5rem}.gps-row{display:flex;justify-content:space-between;align-items:center;padding:.1rem 0}.gps-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.5px;text-align:left;flex:1}.gps-value{font-size:.8rem;font-weight:700;color:var(--text-primary);text-shadow:0 1px 4px var(--shadow-color);text-align:right;flex:1}@media (max-width: 1023px) and (min-width: 768px){.tilt-card{min-height:0}}@media (max-width: 767px) and (min-width: 600px){.tilt-card{min-height:0}}@media (max-width: 599px) and (min-width: 400px){.tilt-card{min-height:0}}@media (max-width: 399px){.tilt-card{min-height:0}}@media (max-width: 319px){.tilt-card{min-height:0}}.wind-angle-card{aspect-ratio:1 / 1;width:100%;height:100%;min-height:0;min-width:0;margin:0;position:relative;overflow:hidden;padding:0;box-sizing:border-box}@media (orientation: landscape){.dashboard-center{display:flex!important;justify-content:center;align-items:center;width:100vw;height:100vh;min-width:0;min-height:0;padding:0!important;box-sizing:border-box}.wind-angle-card{aspect-ratio:1/1;margin:0 auto;min-width:0;min-height:0;box-sizing:border-box;width:min(50vw,100vh);height:min(50vw,100vh);max-width:min(50vw,100vh);max-height:min(50vw,100vh)}}.wind-angle-card:before{display:none}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.wind-angle-card>*{position:relative;z-index:1}.wind-compass{display:flex;justify-content:center;align-items:center;flex:1;margin:.1rem 0;width:100%;height:100%;box-sizing:border-box;min-width:0;min-height:0}.compass-svg{width:100%!important;height:100%!important;max-width:100%;max-height:100%;filter:drop-shadow(0 4px 20px var(--shadow-color));display:block}.wind-data{display:flex;justify-content:space-around;margin-top:.1rem;padding:.3rem;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-card)}.wind-data-item{display:flex;flex-direction:column;align-items:center;gap:.05rem}.wind-label{font-size:.7rem;opacity:.8;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.wind-value{font-size:4rem;font-weight:900;color:var(--text-primary);text-shadow:0 2px 10px var(--shadow-color);line-height:.7}.compass-svg text{font-size:16px;font-weight:700;text-shadow:0 1px 3px var(--shadow-color)}@media (min-width: 1400px){.wind-angle-card{min-height:0;max-width:100vw;max-height:100vw}.compass-svg{width:100%!important;height:100%!important;max-width:100vw;max-height:100vw;display:block}.wind-value{font-size:4.5rem}.wind-label{font-size:1.1rem}}@media (max-width: 1399px) and (min-width: 1200px){.wind-angle-card{min-height:0;max-width:100vw;max-height:100vw}.compass-svg{width:100%!important;height:100%!important;max-width:100vw;max-height:100vw;display:block}.wind-value{font-size:4rem}}@media (max-width: 1199px) and (min-width: 1024px){.wind-angle-card{min-height:0;max-width:100vw;max-height:100vw}.compass-svg{width:100%!important;height:100%!important;max-width:100vw;max-height:100vw;display:block}.wind-value{font-size:3.5rem}.wind-label{font-size:.9rem}}@media (max-width: 1023px) and (min-width: 768px){.wind-angle-card{min-height:0;max-width:100vw;max-height:100vw}.compass-svg{width:100%!important;height:100%!important;max-width:100vw;max-height:100vw;display:block}.wind-value{font-size:2.5rem}.wind-data{padding:.75rem;margin-top:.5rem}.wind-label{font-size:.9rem}.compass-svg text{font-size:14px}}@media (max-width: 767px) and (min-width: 600px){.wind-angle-card{min-height:0;max-width:100vw;max-height:100vw;aspect-ratio:1/1;margin:0}.compass-svg{width:100%!important;height:100%!important;max-width:100vw;max-height:100vw;display:block}.wind-value{font-size:2rem}.wind-data{padding:.5rem;margin-top:.5rem}.wind-label{font-size:.8rem}.compass-svg text{font-size:12px}}@media (max-width: 599px) and (min-width: 400px){.wind-angle-card{min-height:0;max-width:100vw;max-height:100vw}.compass-svg{width:100%!important;height:100%!important;max-width:100vw;max-height:100vw;display:block}.wind-value{font-size:1.2rem}.wind-data{flex-direction:row;gap:2rem;padding:.75rem;margin-top:.75rem;justify-content:center}.wind-label{font-size:.8rem}.compass-svg text{font-size:11px}.wind-compass{margin:1rem 0}}@media (max-width: 399px) and (min-width: 320px){.wind-angle-card{min-height:0;max-width:100vw;max-height:100vw}.compass-svg{width:100%!important;height:100%!important;max-width:100vw;max-height:100vw;display:block}.wind-value{font-size:1rem}.wind-data{flex-direction:row;gap:1.5rem;padding:.5rem;margin-top:.5rem;justify-content:center}.wind-label{font-size:.7rem}.compass-svg text{font-size:9px}.wind-compass{margin:.5rem 0}.wind-angle-card:before{animation-duration:60s}}@media (max-width: 319px){.wind-angle-card{min-height:0;max-width:100vw;max-height:100vw}.compass-svg{width:100%!important;height:100%!important;max-width:100vw;max-height:100vw;display:block}.wind-value{font-size:.9rem}.wind-data{flex-direction:column;gap:.5rem;padding:.4rem;margin-top:.4rem}.wind-label{font-size:.65rem}.compass-svg text{font-size:8px}.wind-compass{margin:.4rem 0}.wind-angle-card:before{animation-duration:90s}}.compass-outer-ring{stroke:var(--compass-stroke);fill:none}.compass-inner-ring{stroke:var(--compass-stroke);fill:none;opacity:.7}.compass-north-pointer{fill:var(--compass-fill)}.compass-north-text{fill:var(--text-primary)}.compass-tick-marks{stroke:var(--compass-stroke)}.compass-degree-labels{fill:var(--text-primary)}.boat-shape{fill:var(--text-secondary);stroke:var(--text-primary)}.boat-center{fill:var(--text-primary);stroke:var(--bg-card)}.dead-wind-zone{stroke:var(--error-color)}.apparent-wind-arrow,.apparent-wind-circle{fill:var(--accent-color)}.true-wind-indicator{fill:var(--success-color);stroke:var(--success-color);opacity:.8}.compact-connection-btn{position:absolute;top:10px;left:10px;z-index:100;border:none;cursor:pointer;font-family:inherit;font-weight:600;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-height:auto;box-sizing:border-box}.compact-connection-btn.disconnected{background:var(--error-color);color:#fff;padding:8px 16px;border-radius:20px;font-size:.9rem;box-shadow:0 2px 8px var(--shadow-color)}.compact-connection-btn.disconnected:hover:not(:disabled){background:var(--error-color);opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-color)}.compact-connection-btn.disconnected:disabled{opacity:.6;cursor:not-allowed;transform:none}.compact-connection-btn.connected{background:var(--success-color);width:20px;height:20px;border-radius:50%;padding:0;box-shadow:0 2px 6px var(--shadow-color)}.connection-button-container{position:absolute;top:10px;left:10px;z-index:100}.advanced-connection-options{margin-top:8px;padding:8px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);display:flex;flex-direction:column;gap:6px;min-width:140px}.advanced-connection-options small{color:var(--text-muted);font-size:.75rem;margin-bottom:4px}.recovery-btn{padding:4px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--card-bg);color:var(--text-primary);font-size:.75rem;cursor:pointer;transition:all .2s ease}.recovery-btn:hover{background:var(--hover-bg);border-color:var(--primary-color)}.recovery-btn:active{transform:translateY(1px)}.compact-connection-btn.connected:hover:not(:disabled){background:var(--success-color);opacity:.9;transform:scale(1.1);box-shadow:0 3px 8px var(--shadow-color)}.connection-dot{width:8px;height:8px;background:white;border-radius:50%;opacity:.9}@media (max-width: 768px){.connection-button-container{top:5px;left:5px}.compact-connection-btn.disconnected{padding:6px 12px;font-size:.8rem}.compact-connection-btn.connected{width:18px;height:18px}.connection-dot{width:6px;height:6px}.advanced-connection-options{min-width:120px}}.satellite-btn{position:fixed;top:0rem;left:0rem;z-index:1001;background:none;border:none;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.satellite-btn:hover{transform:scale(1.1)}.satellite-btn:active{transform:scale(1.05)}.satellite-icon{width:1.5rem!important;height:1.5rem!important;stroke-width:2!important;flex-shrink:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);border-radius:12px;border:1px solid var(--border-color);box-shadow:0 20px 40px #0000004d;max-width:400px;width:90vw;max-height:80vh;overflow:hidden;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{transform:translateY(-20px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:600}.modal-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;line-height:1;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-body{padding:1.5rem}.gps-info-grid{display:flex;flex-direction:column;gap:1rem}.gps-info-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.gps-info-label{font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.gps-info-value{font-weight:700;color:var(--text-primary);font-size:1.125rem;font-family:JetBrains Mono,monospace}@media (max-width: 480px){.modal-content{width:95vw}.modal-header,.modal-body{padding:1rem}.gps-info-row{padding:.5rem .75rem}.satellite-btn{width:2.5rem;height:2.5rem}.satellite-icon{width:1.25rem!important;height:1.25rem!important}}@media (prefers-color-scheme: dark){.modal-overlay{background:rgba(0,0,0,.8)}}.bluetooth-btn{position:fixed;top:0rem;left:2.5rem;z-index:1001;background:none;border:none;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.bluetooth-btn:hover{transform:scale(1.1)}.bluetooth-btn:active{transform:scale(1.05)}.bluetooth-icon{width:1.5rem!important;height:1.5rem!important;stroke-width:2!important;flex-shrink:0}.bluetooth-info-grid{display:flex;flex-direction:column;justify-content:center;gap:.3rem;width:100%;height:100%;padding:.5rem}.bluetooth-info-row{display:flex;justify-content:space-between;align-items:center;padding:.1rem 0}.bluetooth-info-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.5px;text-align:left;flex:1}.bluetooth-info-value{font-size:.8rem;font-weight:700;color:var(--text-primary);text-shadow:0 1px 4px var(--shadow-color);text-align:right;flex:1}.bluetooth-connected{color:var(--success-color)!important}@media (max-width: 480px){.bluetooth-btn{width:2.5rem;height:2.5rem}.bluetooth-icon{width:1.25rem!important;height:1.25rem!important}}.firmware-update-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:20px;box-shadow:0 2px 4px var(--shadow-color);min-height:200px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-header h3{margin:0;color:var(--text-primary);font-size:1.1rem;font-weight:600}.status-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-disconnected{background:var(--bg-secondary);color:var(--text-secondary)}.status-update-available{background:var(--status-update-available-bg);color:var(--status-update-available-text);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.firmware-info{margin-bottom:20px}.version-info{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.version-item{display:flex;justify-content:space-between;align-items:center}.version-item label{color:var(--text-secondary);font-size:.9rem}.version-number{font-family:Monaco,Menlo,monospace;font-size:.9rem;color:var(--text-color);background:var(--bg-secondary);padding:2px 8px;border-radius:4px}.last-checked{font-size:.8rem;color:var(--text-secondary);text-align:center;font-style:italic}.update-progress{margin-bottom:20px}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.9rem;color:var(--text-color)}.progress-bar{width:100%;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),var(--success-color));transition:width .3s ease;border-radius:4px}.update-warning{text-align:center;font-size:.8rem;color:var(--warning-color);font-weight:500;margin-top:8px}.action-buttons{display:flex;gap:12px;flex-wrap:wrap}.btn{padding:10px 16px;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;flex:1;min-width:120px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--bg-secondary);color:var(--text-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-card)}.btn-primary{background:linear-gradient(135deg,var(--accent-color),var(--success-color));color:var(--bg-card)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-color),var(--success-color));transform:translateY(-1px);opacity:.9}.error-message{margin-top:16px;padding:12px;background:var(--bg-secondary);border:1px solid var(--error-color);border-radius:6px;color:var(--error-color);font-size:.9rem}@media (max-width: 768px){.firmware-update-card{padding:16px}.card-header{flex-direction:column;align-items:flex-start;gap:8px}.version-item{flex-direction:column;align-items:flex-start;gap:4px}.action-buttons{flex-direction:column}.btn{min-width:unset}}.theme-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;background:var(--bg-secondary);color:var(--text-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.theme-toggle:hover{background:var(--bg-card);transform:translateY(-1px)}.theme-toggle:active{transform:translateY(0)}.theme-toggle--menu{background:var(--bg-secondary);border:1px solid var(--border-color);margin:0;padding:8px 12px;font-size:.9rem;height:auto;min-height:auto;border-radius:6px}.theme-toggle--menu:hover{background:var(--bg-card);transform:none}.theme-toggle--menu:active{transform:none}.theme-toggle-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px}.theme-toggle-text{font-size:.9rem;white-space:nowrap}@media (max-width: 768px){.theme-toggle{padding:.4rem .8rem;font-size:.8rem}.theme-toggle-icon{width:18px;height:18px}.theme-toggle-icon svg{width:18px;height:18px}}@media (max-width: 480px){.theme-toggle-text{display:none}.theme-toggle{padding:.5rem;min-width:44px;justify-content:center}}.settings-container{position:relative;z-index:100}.hamburger-button{background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s;width:40px;height:40px;min-height:auto;position:absolute;top:10px;right:10px;box-sizing:border-box}.hamburger-button:hover{background:var(--bg-card)}.hamburger-icon{display:flex;flex-direction:column;justify-content:space-between;width:18px;height:14px}.hamburger-icon span{display:block;height:2px;width:100%;background:var(--text-primary);border-radius:2px;transition:transform .2s,opacity .2s}.settings-menu{position:absolute;top:50px;right:10px;background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;width:320px;max-height:80vh;overflow-y:auto;box-shadow:0 4px 20px var(--shadow-color);animation:slideIn .2s ease-out;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;border:1px solid var(--border-color)}.settings-menu::-webkit-scrollbar{width:6px}.settings-menu::-webkit-scrollbar-track{background:transparent}.settings-menu::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:3px}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.menu-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-color)}.menu-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.back-button{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:4px 8px;line-height:1;width:32px;height:32px;min-height:auto;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s,color .2s;margin-right:8px}.back-button:hover{background:var(--bg-secondary);color:var(--text-primary)}.close-button{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0;line-height:1;width:32px;height:32px;min-height:auto;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s,color .2s;margin-left:8px;box-sizing:border-box}.close-button:hover{background:var(--bg-secondary);color:var(--text-primary)}.menu-section{padding:16px;border-bottom:1px solid var(--border-color)}.menu-section:last-of-type{border-bottom:none}.menu-section h4{margin:0 0 12px;font-size:.9rem;color:var(--text-secondary);font-weight:600}.menu-item{display:block;width:100%;text-align:left;padding:10px 12px;background:var(--bg-secondary);border:none;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:background-color .2s;border-radius:6px;margin-bottom:8px}.menu-item:hover:not(:disabled){background:var(--bg-card)}.menu-item:disabled{opacity:.5;cursor:not-allowed}.menu-item.half-width{width:calc(50% - 4px);display:inline-block;margin-right:8px}.menu-item.half-width:last-child{margin-right:0}.main-menu-item{display:flex;align-items:center;padding:16px 12px;background:var(--bg-secondary);margin-bottom:8px;transition:all .2s}.main-menu-item:hover{background:var(--bg-card);transform:translate(2px)}.menu-icon{font-size:1.5rem;margin-right:12px;width:24px;text-align:center}.menu-item-content{flex:1}.menu-item-content h4{margin:0 0 4px;font-size:1rem;font-weight:600;color:var(--text-primary)}.menu-item-content p{margin:0;font-size:.8rem;color:var(--text-secondary);line-height:1.3}.menu-arrow{font-size:1.2rem;color:var(--text-secondary);margin-left:8px}.version-info{background:var(--bg-secondary);padding:12px;border-radius:6px;margin-bottom:8px}.version-info p{margin:4px 0;font-size:.9rem;color:var(--text-primary)}.version-info strong{color:var(--text-primary)}.input-group{margin-bottom:12px}.input-group label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:4px}.input-group input{width:calc(100% - 80px);padding:8px 10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.9rem;margin-right:8px}.input-group input::placeholder{color:var(--text-secondary)}.input-group input:focus{outline:none;border-color:var(--accent-color);background:var(--bg-card)}.input-group button{width:72px;padding:8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:background-color .2s}.input-group button:hover:not(:disabled){background:var(--bg-card)}.input-group button:disabled{opacity:.5;cursor:not-allowed}.button-group{display:flex;gap:8px}.help-text{font-size:.75rem;color:var(--text-secondary);margin:4px 0 0;line-height:1.3}.connection-warning{background:var(--bg-secondary);border:1px solid var(--warning-color);border-radius:6px;padding:12px;margin:16px;text-align:center}.connection-warning p{margin:0;font-size:.85rem;color:var(--text-primary)}.menu-footer{padding:12px 16px;border-top:1px solid var(--border-color);text-align:center}.version{font-size:.8rem;color:var(--text-secondary)}@media (max-width: 768px){.hamburger-button{top:5px;right:5px}.settings-menu{width:calc(100% - 20px);right:5px;top:45px}.input-group input{width:calc(100% - 70px)}.input-group button{width:62px}}.settings-menu{color:var(--text-primary)}.action-button,.calibrate-button{background:var(--bg-secondary)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important}.action-button:hover,.calibrate-button:hover{background:var(--bg-card)!important;border-color:var(--accent-color)!important}.device-name-section{border-bottom:1px solid var(--border-color)!important}.range-input{background:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;color:var(--text-primary)!important}.range-input:focus{border-color:var(--accent-color)!important;background:var(--bg-card)!important}.input-group input{background:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;color:var(--text-primary)!important}.input-group input:focus{border-color:var(--accent-color)!important}.settings-section h4,.settings-section label{color:var(--text-primary)!important}.settings-item p{color:var(--text-secondary)!important}.theme-menu-item{cursor:default!important}.theme-menu-item:hover{transform:none!important}.theme-toggle-container{margin-left:8px}.bluetooth-status{background:var(--bg-secondary);border-radius:6px;padding:12px;margin-bottom:12px}.connection-info{display:flex;flex-direction:column;gap:8px}.status-indicator{display:flex;align-items:center;gap:8px;font-weight:600}.status-dot{width:8px;height:8px;border-radius:50%}.status-indicator.connected .status-dot{background:var(--success-color)}.status-indicator.disconnected .status-dot{background:var(--error-color)}.device-name,.signal-strength,.last-update{margin:0;font-size:.85rem;color:var(--text-secondary)}.error-message{margin:0;font-size:.85rem;color:var(--error-color)}.connection-button{font-weight:600}.connection-button.connected{background:var(--error-color);color:#fff}.connection-button.connected:hover:not(:disabled){background:var(--error-color);opacity:.9}.connection-button.disconnected{background:var(--error-color);color:#fff}.connection-button.disconnected:hover:not(:disabled){background:var(--error-color);opacity:.9}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: linear-gradient(135deg, #f5f5f5 0%, #e0e0e0 100%);--bg-secondary: rgba(255, 255, 255, .4);--bg-card: rgba(255, 255, 255, .6);--text-primary: #2d3748;--text-secondary: #4a5568;--text-accent: #718096;--border-color: rgba(0, 0, 0, .1);--shadow-color: rgba(0, 0, 0, .1);--accent-color: #000000;--text-on-accent: #ffffff;--success-color: #000000;--warning-color: #d69e2e;--error-color: #e53e3e;--compass-stroke: #a9a9a9;--compass-fill: #a9a9a9}[data-theme=dark]{--bg-primary: linear-gradient(135deg, #1a202c 0%, #2d3748 100%);--bg-secondary: rgba(45, 55, 72, .7);--bg-card: rgba(55, 65, 81, .7);--text-primary: #ffffff;--text-secondary: #e2e8f0;--text-accent: #a0aec0;--border-color: rgba(255, 255, 255, .1);--shadow-color: rgba(0, 0, 0, .3);--accent-color: #ffffff;--text-on-accent: #000000;--success-color: #ffffff;--warning-color: #f6e05e;--error-color: #fc8181;--compass-stroke: #a9a9a9;--compass-fill: #a9a9a9}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}.app-main{flex:1;display:flex;align-items:stretch;min-height:100vh}[data-theme=light]{--text-primary: #0d1421;--text-secondary: #1a202c;--text-accent: #1a365d}@media (max-width: 768px){.app-main{min-height:100vh}}@media (max-width: 599px){.app-main{min-height:100vh}}@media (max-width: 480px){.app-main{min-height:100vh}}@media (hover: none) and (pointer: coarse){.card:hover{transform:none;box-shadow:none;border-color:#fff3}.card:active{transform:scale(.98);transition:transform .1s ease}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;--btn-bg: #1a1a1a;--btn-text: #fff;--btn-primary-text: #000;--btn-update-bg: #ff9800;--btn-update-text: #212121;--btn-update-hover-bg: #ffa726;--btn-update-hover-text: #212121;--btn-alert-bg: #d32f2f;--btn-alert-text: #fff;--btn-alert-hover-bg: #fff;--btn-alert-hover-text: #d32f2f;--status-update-available-bg: #4caf50;--status-update-available-text: #fff}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--btn-bg);color:var(--btn-text);cursor:pointer;transition:border-color .25s;min-height:44px}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (max-width: 768px){h1{font-size:2.5em}button{font-size:.9em;padding:.7em 1.4em}}@media (max-width: 480px){h1{font-size:2em}button{font-size:.85em;padding:.8em 1.5em;min-height:48px}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){body{font-size:16px}}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff;--btn-bg: #f9f9f9;--btn-text: #213547;--btn-primary-text: #212121;--btn-update-bg: #ff9800;--btn-update-text: #212121;--btn-update-hover-bg: #ffa726;--btn-update-hover-text: #212121;--btn-alert-bg: #d32f2f;--btn-alert-text: #fff;--btn-alert-hover-bg: #fff;--btn-alert-hover-text: #d32f2f;--status-update-available-bg: #2e7d32;--status-update-available-text: #fff}a:hover{color:#747bff}button{background-color:var(--btn-bg);color:var(--btn-text)}}
