body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.converter-container{align-items:center;background:#fff;box-sizing:border-box;color:#000;display:flex;flex-direction:column;min-height:100vh}.converter-header{margin-bottom:20px;max-width:600px;padding:20px 0;text-align:center;width:100%}.converter-title{color:#6c757d;font-size:2.2rem;line-height:1.2;margin-bottom:8px}.converter-subtitle{color:#333;font-size:1.1rem;line-height:1.4;margin-bottom:12px}.converter-card{background-color:#fff;border:2px solid #39f;border-radius:12px;box-shadow:0 3px 8px #0000001a;box-sizing:border-box;max-width:600px;padding:25px;width:100%}.input-section{display:flex;flex-direction:column;gap:20px;margin-bottom:25px}.section-label{color:#036;font-size:1rem;margin-bottom:6px}.input-group{display:flex;flex-direction:column;gap:8px}.value-input,.value-output{background-color:#fafafa;border:2px solid #39f;border-radius:6px 0 0 6px;box-sizing:border-box;color:#036;flex:1 1;font-size:1.1rem;font-weight:600;padding:14px}.custom-select-wrapper{flex-shrink:0}.unit-select{background-color:#eaf4ff;border:2px solid #39f;border-left:none;border-radius:0 6px 6px 0;box-sizing:border-box;color:#036;cursor:pointer;font-size:1rem;font-weight:600;outline:none;padding:14px 40px 14px 12px}.custom-select-wrapper:after{color:#036;content:"▼";font-size:.9rem;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.quick-unit-select{-webkit-appearance:none;appearance:none;background-color:#eaf4ff;border:2px solid #39f;border-radius:6px;box-sizing:border-box;color:#036;cursor:pointer;font-size:1rem;font-weight:600;outline:none;padding:14px 40px 14px 12px;width:100%}.slider{-webkit-appearance:none;background:#dde1e6;border-radius:3px;height:6px;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#2196f3;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:18px;width:18px}.slider::-moz-range-thumb{background:#2196f3;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:18px;width:18px}.slider-hint{color:#666;font-size:.75rem;margin-top:4px}.action-buttons{gap:15px;justify-content:center;margin:15px 0}.add-btn,.reset-btn,.switch-btn{background-color:#39f;border:none;border-radius:8px;box-shadow:0 2px 6px #0003;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:10px 16px;transition:transform .2s,background-color .2s}.add-btn:hover,.reset-btn:hover,.switch-btn:hover{background-color:#267acc;transform:scale(1.05)}.remove-btn{border-radius:4px;font-size:.9rem;padding:5px 10px;transition:all .2s ease}.result-group{background:linear-gradient(135deg,#4a6cf7,#2196f3);border:1px solid #fff3;border-radius:12px;box-shadow:0 4px 12px #2196f34d;color:#fff;margin-top:15px;padding:20px;position:relative}.result-item{align-items:center;background-color:#ffffff26;border-radius:8px;margin-bottom:15px;padding:12px 15px;transition:all .3s ease}.result-item:hover{background-color:#ffffff40;transform:translateY(-2px)}.result-label{color:#ffffffe6;font-size:1rem;letter-spacing:.5px}.result-value{color:#fff;font-size:1.2rem;font-weight:700;text-shadow:0 2px 4px #0003}.result-note{color:#fffc;font-size:.85rem;margin-left:8px}.result-group{animation:pulse .5s ease}.options-group{display:flex;flex-direction:column;gap:1rem}.options-group.two-columns{grid-gap:1.5rem;gap:1.5rem}.options-group.three-columns{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr 1fr}.option{display:flex;flex-direction:column;gap:.5rem}.radio-group{display:flex;gap:1rem}.radio-label{margin-bottom:12px}.radio-label input[type=radio]{margin-right:8px}.common-sizes-compact{background-color:#f8f9fa;border-radius:12px;box-sizing:border-box;margin-top:30px;max-width:600px;padding:15px;text-align:center;width:100%}.compact-title{color:#333;margin-bottom:8px}.compact-subtitle{color:#666;font-size:.9rem;margin-bottom:15px}.sizes-container{gap:8px;justify-content:center}.size-chip{align-items:center;background-color:#fff;border:1px solid #e0e0e0;display:flex;flex-direction:column;min-width:70px;padding:10px 12px;transition:all .2s ease}.size-chip:hover{background-color:#e3f2fd;border-color:#2196f3;box-shadow:0 2px 8px #2196f333}.size-label{color:#2196f3;font-size:.9rem;font-weight:600;margin-bottom:4px}.size-details{color:#666;font-size:.8rem}.info-section{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;background-color:#f8f9fa;border:1px solid #e9ecef;box-sizing:border-box;max-width:600px;width:100%}.info-section h3{color:#333;font-size:1.4rem;line-height:1.3;margin-bottom:15px}.info-section h4{color:#2c3e50;font-size:1.1rem;line-height:1.3;margin:20px 0 12px}.info-section p{color:#444;font-size:1rem;line-height:1.6;margin-bottom:15px}.info-section ul{margin-bottom:20px}.info-section li{color:#444;font-size:1rem;line-height:1.5;margin-bottom:10px}.info-section strong{color:#2c3e50;font-weight:600}.info-section>:last-child{margin-bottom:0}.items-list{background:#f8f9fa;border-radius:8px;margin:15px 0;padding:15px}.items-list h4{color:#2c3e50;font-size:1rem;margin:0 0 10px}.item-row{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:8px 0}.item-row:last-child{border-bottom:none}.converter-type-section{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:20px;padding:15px}.converter-type-header{display:flex;justify-content:center;margin-bottom:12px}.current-selection-label{color:#495057;font-weight:500}.selected-type{background-color:#e8f0fe;border-radius:4px;color:#4a6cf7;font-weight:600;padding:4px 8px}.converter-type-selector{display:flex;gap:15px;justify-content:center}.type-btn{background-color:#f8f8f8;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s ease}.type-btn.active{background-color:#4a6cf7;border-color:#4a6cf7;box-shadow:0 2px 4px #4a6cf74d;color:#fff}.type-btn:hover{background-color:#eaeaea;transform:translateY(-2px)}.type-btn.active:hover{background-color:#3a5cd8;transform:translateY(-2px)}@media (max-width:900px) and (orientation:landscape){.converter-container{padding:15px}.converter-card{padding:20px}.converter-title{font-size:1.8rem}.converter-subtitle{font-size:1rem}.info-section{padding:15px}.info-section h3{font-size:1.3rem}.info-section h4{font-size:1.1rem}.info-section li,.info-section p{font-size:.95rem}.options-group.three-columns,.options-group.two-columns{gap:1rem;grid-template-columns:1fr}.result-item{align-items:flex-start;flex-direction:column;gap:5px}.result-value{align-self:flex-end}}@media (max-width:768px){.converter-container{padding:15px}.converter-card{padding:20px}.converter-title{font-size:1.8rem}.options-group.three-columns,.options-group.two-columns{grid-template-columns:1fr}.converter-type-selector{flex-direction:column;gap:10px}.type-btn{width:100%}.action-buttons{align-items:center;flex-direction:column}.add-btn,.reset-btn,.switch-btn{max-width:250px;width:100%}.info-section{padding:18px 15px}.info-section h3{font-size:1.3rem}.info-section h4{font-size:1.1rem}.info-section li,.info-section p{font-size:.95rem}.radio-group{flex-direction:column;gap:.5rem}.sizes-container{gap:6px}.size-chip{min-width:60px;padding:8px 10px}.size-label{font-size:.9rem}.size-details{font-size:.7rem}.item-row{align-items:flex-start;flex-direction:column;gap:5px}}@media (max-width:480px){.converter-container{padding:10px}.converter-card{padding:15px}.converter-title{font-size:1.6rem}.converter-subtitle{font-size:.95rem}.quick-unit-select,.unit-select,.value-input,.value-output{font-size:1rem;padding:12px}.info-section{padding:15px 12px}.info-section h3{font-size:1.2rem}.info-section h4{font-size:1rem}.info-section li,.info-section p{font-size:.9rem}.info-section ul{padding-left:16px}.result-group{padding:15px}.result-item{padding:10px}.result-label{font-size:.9rem}.result-value{font-size:1.1rem}.sizes-container{justify-content:space-around}.size-chip{flex-basis:calc(50% - 10px);flex-grow:0;flex-shrink:0;margin-bottom:8px}}@media (max-width:360px){.converter-title{font-size:1.4rem}.info-section{padding:12px 10px}.info-section h3{font-size:1.1rem}.info-section h4{font-size:.95rem}.info-section li,.info-section p{font-size:.85rem}.quick-unit-select,.unit-select,.value-input,.value-output{font-size:.95rem;padding:10px}}@media (max-height:500px) and (orientation:landscape){.converter-container{padding:10px}.converter-card{padding:15px}.input-section{gap:15px}.info-section{-webkit-overflow-scrolling:touch;max-height:70vh;overflow-y:auto}}.remove-btn-text{background:#f8f9fa;border:1px solid #e74c3c;border-radius:4px;color:#e74c3c;cursor:pointer;flex-shrink:0;font-size:.9rem;font-weight:600;margin-left:15px;padding:6px 12px;transition:all .2s ease}.remove-btn-text:hover{background:#e74c3c;color:#fff}.remove-btn,.remove-btn-text{margin-left:10px}.converter-container{margin:0 auto;max-width:1200px;padding:20px}.converter-card{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:20px}.section-title{border-bottom:1px solid #e0e0e0;color:#2c3e50;font-size:1.5rem;margin:0 0 20px;padding-bottom:10px}.input-section{margin-bottom:20px}.section-label{color:#2c3e50;display:block;font-weight:600;margin-bottom:10px}.dimension-group,.dimension-inputs{margin-bottom:15px}.dimension-group label{display:block;font-weight:500;margin-bottom:5px}.input-with-unit{align-items:center;display:flex;gap:10px}.value-input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-size:14px;padding:8px 12px}.custom-select-wrapper{position:relative}.unit-select{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px 32px 8px 12px}.slider-container{margin-top:10px}.slider{margin:10px 0;width:100%}.slider-hint{color:#7f8c8d;display:block;font-size:.8rem;margin-top:5px;text-align:center}.options-group{margin-bottom:15px}.radio-group{margin:10px 0}.radio-label{cursor:pointer;gap:8px}.cut-inputs,.radio-label{align-items:center;display:flex}.cut-inputs{flex-wrap:wrap;gap:10px}.cut-input-group{gap:5px}.count-input{width:60px}.multiply-sign{font-size:1.2rem;font-weight:700;margin:0 5px}.remove-btn{font-size:14px;height:25px;width:25px}.add-btn{padding:8px 15px}.result-group{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;margin-bottom:20px;padding:15px}.result-item{background:#fff;border-left:4px solid #3498db;border-radius:4px;display:flex;justify-content:space-between;margin-bottom:10px;padding:8px}.result-item:last-child{margin-bottom:0}.result-label{color:#2c3e50;font-weight:600}.result-value{color:#2c3e50;font-weight:500}.sufficient{color:#27ae60;font-weight:700}.insufficient{color:#e74c3c;font-weight:700}.visualization-legend{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;flex-wrap:wrap;margin-bottom:15px;padding:10px}.legend-color{border-radius:3px;height:20px;width:20px}.cut-color{background:linear-gradient(135deg,#3498db,#2980b9)}.kerf-color{background:linear-gradient(135deg,#95a5a6,#7f8c8d)}.waste-color{background:linear-gradient(135deg,#e74c3c,#c0392b)}.boards-list{display:flex;flex-direction:column;gap:15px}.board-visualization{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;padding:15px}.board-visualization h4{background:#ecf0f1;border-left:4px solid #3498db;border-radius:4px;color:#2c3e50;font-size:1rem;margin:0 0 10px;padding:8px 12px}.board-visual{background:#f5f5f5;border:1px solid #ddd;border-radius:4px;height:40px;width:100%}.board-visual,.cut-visual{display:flex;overflow:hidden}.cut-visual{align-items:center;background:linear-gradient(45deg,#3498db,#2980b9);box-shadow:inset 0 0 5px #0000001a;color:#fff;flex-shrink:0;font-size:.7rem;font-weight:700;justify-content:center;position:relative}.cut-visual:after{background:linear-gradient(#ffffff1a,#0000001a);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.kerf-visual{background:repeating-linear-gradient(45deg,#95a5a6,#95a5a6 2px,#7f8c8d 0,#7f8c8d 4px);font-size:.6rem}.kerf-visual,.waste-visual{align-items:center;color:#fff;display:flex;flex-shrink:0;justify-content:center;position:relative}.waste-visual{background:repeating-linear-gradient(-45deg,#e74c3c,#e74c3c 2px,#c0392b 0,#c0392b 4px);font-size:.7rem;font-weight:700}.board-stats{color:#7f8c8d;display:flex;flex-wrap:wrap;font-size:.8rem;gap:8px;margin-top:8px}.cut-visual[style*="width: 0%"],.cut-visual[style*="width: 1%"],.cut-visual[style*="width: 2%"],.cut-visual[style*="width: 3%"],.cut-visual[style*="width: 4%"]{font-size:0}.common-sizes-compact{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:20px 0;padding:20px}.compact-title{color:#2c3e50;font-size:1.2rem;margin:0 0 10px}.compact-subtitle{color:#7f8c8d;margin:0 0 15px}.sizes-container{display:flex;flex-wrap:wrap;gap:10px;margin:15px 0}.size-chip{background:#ecf0f1;border:1px solid #ddd;border-radius:20px;cursor:pointer;padding:8px 15px;transition:all .3s ease}.size-chip:hover{background:#3498db;color:#fff;transform:translateY(-2px)}.size-label{font-weight:500}.info-section{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-top:30px;padding:20px}.info-section h3{color:#2c3e50;margin-top:0}.info-section ul{padding-left:20px}.info-section li{margin-bottom:8px}.action-buttons{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.reset-btn{align-items:center;background:#95a5a6;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:5px;padding:10px 15px;transition:background .3s ease}.reset-btn:hover{background:#7f8c8d}.count-input:focus,.quick-unit-select:focus,.unit-select:focus,.value-input:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}@media (max-width:768px){.converter-container{padding:10px}.converter-card{padding:15px}.cut-inputs{align-items:stretch;flex-direction:column;gap:10px}.cut-input-group{width:100%}.multiply-sign{margin:10px 0}.multiply-sign,.remove-btn{align-self:center}.visualization-legend{flex-direction:column;gap:10px}}.kerf-conversion-note{color:#7f8c8d;font-style:italic;margin-top:5px}.table-container{margin-bottom:20px;overflow-x:auto}.holes-table{background:#fff;border-collapse:collapse;border-radius:5px;box-shadow:0 1px 3px #0000001a;overflow:hidden;width:100%}.holes-table td,.holes-table th{border-bottom:1px solid #e0e0e0;padding:10px 15px;text-align:center}.holes-table th{background-color:#f8f9fa;color:#2c3e50;font-weight:600}.holes-table tr:last-child td{border-bottom:none}.formula,.holes-table tr:hover{background-color:#f8f9fa}.formula{border-left:4px solid #3498db;border-radius:5px;font-family:monospace;font-size:1.1rem;margin:10px 0;padding:15px}.board-visualization{margin-bottom:20px}.visualization-legend{display:flex;gap:20px;justify-content:center;margin-top:10px}.legend-item{font-size:.9rem;gap:8px}@media (max-width:768px){.options-group.two-columns{gap:15px;grid-template-columns:1fr}.holes-table{font-size:.9rem}.holes-table td,.holes-table th{padding:8px 10px}.visualization-legend{align-items:center;flex-direction:column;gap:10px}}.angle-visualization{align-items:center;background:#fafafa;border:1px dashed #ccc;border-radius:6px;display:flex;height:200px;justify-content:center;margin:1rem auto;position:relative;width:200px}.wall-line{background:#444;height:100%;left:50%;position:absolute;top:0;width:2px}.molding-line{background:#ff4081;width:90px}.bevel-line,.molding-line{height:2px;left:50%;position:absolute;top:50%;transform-origin:left center}.bevel-line{background:#2196f3;width:70px}.visual-labels{bottom:5px;color:#333;display:flex;flex-direction:column;font-size:12px;left:5px;position:absolute}.legend-section{background:#f9f9f9;border-radius:6px;border-top:1px solid #ddd;margin-top:2rem;padding:1rem}.legend-section h3{color:#333;font-size:1.2rem;margin-bottom:.5rem}.legend-section ul{list-style:none;margin:0;padding:0}.legend-section li{align-items:center;color:#444;display:flex;font-size:.95rem;margin-bottom:.5rem}.legend-box{border-radius:2px;display:inline-block;height:3px;margin-right:8px;width:16px}.legend-box.wall{background:#444}.legend-box.miter{background:#ff4081}.legend-box.bevel{background:#2196f3}.legend-note{color:#666;font-size:.9rem;margin-top:.5rem}.explanation-section{background:#fff8f9;border-radius:6px;border-top:1px solid #ccc;margin-top:2rem;padding:1rem}.explanation-section h3{color:#333;font-size:1.2rem;margin-bottom:.5rem}.explanation-section ul{margin:.5rem 0;padding-left:1.2rem}.explanation-section li{color:#444;font-size:.95rem;margin-bottom:.3rem}.options-group.two-columns{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.cuts-list{margin-bottom:20px}.cut-item{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;margin-bottom:15px;padding:15px}.cut-inputs{grid-gap:15px;align-items:start;display:grid;gap:15px}.cut-input-group{display:flex;flex-direction:column;gap:8px}.cut-input-group label{color:#7f8c8d;font-size:.8rem;font-weight:500}.count-input{border:1px solid #ddd;border-radius:4px;padding:8px;width:100%}.cut-input-group .slider-container{margin-top:5px}.cut-input-group .slider{width:100%}.cut-input-group .slider-hint{display:none}.result-item.highlight{background-color:#e8f4fc;border-left:4px solid #3498db;font-weight:700}.option-hint{color:#7f8c8d;display:block;font-style:italic;margin-top:5px}@media (max-width:900px){.options-group.two-columns{gap:15px;grid-template-columns:1fr}.cut-inputs{grid-template-columns:1fr 1fr}}@media (max-width:600px){.cut-inputs{grid-template-columns:1fr}.cut-input-group .slider-container{margin-top:8px}}.custom-sheet-inputs{background-color:#f0f8ff;border:1px solid #cce5ff;border-radius:5px;margin-bottom:15px;padding:15px}.add-btn{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;display:block;font-weight:500;margin-top:10px;padding:10px 15px;transition:background .3s ease;width:100%}.add-btn:hover{background:#2980b9}.remove-btn{align-items:center;align-self:center;background:#e74c3c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:30px;justify-content:center;transition:background .3s ease;width:30px}.remove-btn:hover{background:#c0392b}.cut-inputs .row{grid-gap:15px;align-items:center;display:grid;gap:15px;grid-template-columns:1fr 1fr}.cut-inputs .row:last-child{grid-template-columns:1fr 1fr auto}.scaffolding-diagram{background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;margin-top:20px;padding:15px}.diagram-container{background-color:#fff;border:1px solid #ddd;height:200px;margin:20px 0;position:relative}.scaffold-structure{height:100%;position:relative;width:100%}.scaffold-vertical{background-color:#4a90e2;bottom:0;height:100%;position:absolute;transform:translateX(-50%);width:4px}.scaffold-horizontal{background-color:#e74c3c;height:4px;left:0;position:absolute;width:100%}.scaffold-section{height:25%;position:relative}.scaffold-joint{background-color:#2c3e50;border-radius:50%;height:12px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:12px}.scaffold-platform{background-color:#27ae60;bottom:0;height:10px;left:0;opacity:.7;position:absolute;width:100%}.dimension-line{background-color:#0003;position:absolute}.dimension-line.horizontal-dim{bottom:10%;height:1px;left:0;width:20%}.dimension-line.vertical-dim{bottom:0;height:20%;left:10%;width:1px}.dimension-arrow{border-style:solid;height:0;position:absolute;width:0}.dimension-arrow.start{border-color:#0000 #0000 #0000 #000;border-width:4px 0 4px 6px;left:0;top:-4px}.dimension-arrow.end{border-color:#0000 #000 #0000 #0000;border-width:4px 6px 4px 0;right:0;top:-4px}.dimension-text{font-size:10px;left:50%;position:absolute;top:-20px;transform:translateX(-50%);white-space:nowrap}.diagram-legend{display:flex;gap:15px;justify-content:center;margin-top:15px}.legend-item{align-items:center;display:flex;font-size:12px;gap:5px}.legend-color{border-radius:2px;height:15px;width:15px}.legend-color.vertical-example{background-color:#4a90e2}.legend-color.horizontal-example{background-color:#e74c3c}.legend-color.platform-example{background-color:#27ae60}.diagram-note{color:#666;font-size:12px;font-style:italic;margin-top:10px;text-align:center}.level-container{background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:800px;min-height:100vh;padding:20px;text-align:center}h1{color:#2c3e50;font-size:24px;margin-bottom:30px}.sensor-readings{background:#fff;border-radius:15px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-around;margin-bottom:30px;padding:15px}.reading{align-items:center;display:flex;flex-direction:column}.label{color:#7f8c8d;font-size:12px;font-weight:600;text-transform:uppercase}.value{color:#2c3e50;font-size:18px}.tools-container{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-around;margin-bottom:30px}.tool{background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;flex:1 1;min-width:300px;padding:20px}.tool h2{color:#34495e;font-size:20px}.level-indicator,.plumb-indicator,.tool h2{margin-bottom:20px}.bubble-container{background:radial-gradient(circle at center,#ecf0f1,#bdc3c7);border:3px solid #34495e;border-radius:50%;height:200px;margin:0 auto 20px;overflow:hidden;position:relative;width:200px}.crosshair{background:#34495e4d;position:absolute}.crosshair.horizontal{height:1px;left:0;right:0;top:50%;transform:translateY(-50%)}.crosshair.vertical{bottom:0;left:50%;top:0;transform:translateX(-50%);width:1px}.bubble{background:radial-gradient(circle at 30% 30%,#e74c3c,#c0392b);border-radius:50%;box-shadow:0 2px 10px #0000004d;height:40px;left:50%;margin-left:-20px;margin-top:-20px;position:absolute;top:50%;transition:transform .2s ease-out;width:40px}.plumb-line{align-items:center;background:#34495e;border-radius:4px;display:flex;justify-content:center;margin:0 auto 20px;width:8px}.plumb-center{background:#fff;border-radius:50%;height:4px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:4px}.plumb-bob{background:radial-gradient(circle at 30% 30%,#e74c3c,#c0392b);box-shadow:0 2px 10px #0000004d;margin-left:-15px;top:20px;transition:transform .2s ease-out}.status{background:#ffeaea;border-radius:10px;color:#e74c3c;font-size:18px;font-weight:700;padding:12px;transition:all .3s ease}.status.level,.status.plumb{background:#eafaf1;color:#27ae60}.calibration{margin:20px 0}.calibrate-btn,.permission-btn{background:#3498db;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:background .3s}.calibrate-btn:hover,.permission-btn:hover{background:#2980b9}.instructions{background:#fff;border-radius:15px;box-shadow:0 2px 10px #0000001a;padding:20px;text-align:left}.instructions h3{color:#2c3e50;margin-top:0}.instructions ul{color:#34495e;padding-left:20px}.instructions li{line-height:1.5;margin-bottom:10px}.browser-tips{background:#fff3cd;border-left:4px solid #ffc107;border-radius:10px;margin-top:15px;padding:15px}.browser-tips h4{color:#856404;margin-bottom:10px}.browser-tips ul{color:#856404}.error-message,.permission-prompt{background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin:20px 0;padding:30px;text-align:center}.error-message h2,.permission-prompt h2{color:#e74c3c;margin-bottom:15px}.ios-instructions,.troubleshooting{background:#f8f9fa;border-radius:10px;margin-top:20px;padding:15px;text-align:left}.ios-instructions p,.troubleshooting h3{color:#2c3e50;margin-top:0}@media (max-width:768px){.tools-container{align-items:center;flex-direction:column}.tool{width:100%}.sensor-readings{flex-direction:column;gap:15px}.bubble-container{height:150px;width:150px}.bubble{height:30px;margin-left:-15px;margin-top:-15px;width:30px}}.plumb-container{background:#f5f5f5;font-family:Arial,sans-serif;margin:0 auto;max-width:400px;min-height:100vh;padding:20px}.header{margin-bottom:30px;text-align:center}.header h1{color:#333;font-size:28px;margin:0 0 10px}.status-indicator{border-radius:25px;display:inline-block;font-size:18px;font-weight:700;padding:10px 20px}.status-indicator.plumb{background:#4caf50;color:#fff}.status-indicator.not-plumb{background:#f44336;color:#fff}.plumb-display{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;height:300px;justify-content:center;margin:30px 0;position:relative}.plumb-line{background:#f44336;border-radius:2px;height:200px;position:relative;transition:background-color .3s ease;width:4px}.plumb-bob{background:#f44336;border-radius:50%;box-shadow:0 2px 5px #0003;height:30px;top:10px;transition:all .3s ease;width:30px}.center-mark,.plumb-bob{left:50%;position:absolute;transform:translateX(-50%)}.center-mark{background:#666;height:200px;opacity:.3;width:2px}.readings{background:#fff;border-radius:10px;box-shadow:0 2px 5px #0000001a;display:flex;justify-content:space-around;margin:20px 0;padding:15px}.deviation,.tilt-reading{text-align:center}.label{color:#666;display:block;font-size:14px;margin-bottom:5px}.value{color:#333;display:block;font-size:24px;font-weight:700}.usage-guide{background:#fff;border-radius:10px;box-shadow:0 2px 5px #0000001a;margin:20px 0;padding:20px}.usage-guide h3{color:#333;margin:0 0 15px}.steps{flex-direction:column}.step,.steps{display:flex;gap:15px}.step,.step-number{align-items:center}.step-number{background:#2196f3;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:30px;justify-content:center;width:30px}.step-text{color:#666;line-height:1.4}.trade-tips{background:#fff;border-radius:10px;box-shadow:0 2px 5px #0000001a;padding:20px}.trade-tips h3{color:#333;margin:0 0 15px}.trade-tips ul{color:#666;margin:0;padding-left:20px}.trade-tips li{line-height:1.4;margin-bottom:8px}.permission-screen{padding:40px 20px;text-align:center}.permission-screen h1{color:#333;margin-bottom:15px}.permission-screen p{color:#666;line-height:1.5;margin-bottom:25px}.enable-btn{background:#2196f3;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:16px;margin-bottom:20px;padding:12px 30px}.enable-btn:hover{background:#1976d2}@media (max-width:480px){.plumb-container{padding:15px}.plumb-display{height:250px}.plumb-line{height:180px}.readings{flex-direction:column;gap:15px}}.flashlight-app{align-items:center;display:flex;height:100vh;justify-content:center;margin:0;padding:0;transition:all .3s ease;width:100vw}.flashlight-app.flash-off{background:#000;color:#fff}.flashlight-app.flash-on{background:#fff;color:#000}.flashlight-app.turning-off{animation:pulse-warning 1s infinite;background:#ff6b35;color:#fff}@keyframes pulse-warning{0%{background-color:#ff6b35}50%{background-color:#ff8c5a}to{background-color:#ff6b35}}.flashlight-screen{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:space-between;padding:40px 20px;text-align:center;width:100%}.status-display{font-size:24px;font-weight:700;margin-bottom:20px}.status-on{color:#0c0}.status-off{color:#666}.status-turn-off{color:#fff}.countdown{font-size:28px;font-weight:700;margin-bottom:10px}.warning{font-size:18px;opacity:.9}.instruction{font-size:16px;font-weight:400;margin-top:5px;opacity:.7}.button-indicator{flex:1 1}.button-circle,.button-indicator{align-items:center;display:flex;justify-content:center}.button-circle{border-radius:50%;font-size:50px;height:120px;transition:all .3s ease;width:120px}.button-circle.off{background:#ffffff1a;border:4px solid #666}.button-circle.on{animation:glow 2s infinite;background:#00cc001a;border:4px solid #0c0}.button-circle.warning{animation:pulse .5s infinite;background:#fff3;border:4px solid #fff}@keyframes glow{0%{box-shadow:0 0 20px #00cc004d}50%{box-shadow:0 0 40px #0c09}to{box-shadow:0 0 20px #00cc004d}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.navigation-info{font-size:14px;margin-top:20px;opacity:.8}.nav-warning{color:#fff;font-weight:700}.nav-normal{color:#666}@media (max-width:480px){.status-display{font-size:20px}.countdown{font-size:24px}.warning{font-size:16px}.button-circle{font-size:40px;height:100px;width:100px}.flashlight-screen{padding:30px 15px}}.compass-container{background:#fff;color:#000;font-family:Arial,sans-serif;margin:0 auto;max-width:400px;min-height:100vh;padding:20px;text-align:center}.compass-header{background:#f8f9fa;border:2px solid #e9ecef;border-radius:15px;margin-bottom:20px;padding:20px}.direction-display{color:#dc3545;font-size:52px;font-weight:700;margin-bottom:10px;text-shadow:1px 1px 2px #0000001a}.heading-display{color:#495057;font-size:28px;font-weight:700}.compass-main{margin:30px 0}.compass-dial-container{background:#f8f9fa;border:3px solid #dee2e6;border-radius:50%;height:300px;margin:0 auto;padding:10px;position:relative;width:300px}.compass-dial{border:2px solid #adb5bd;border-radius:50%;box-shadow:inset 0 0 10px #0000001a;height:100%;position:relative;transition:transform .1s ease;width:100%}.fixed-pointer{font-size:24px;font-weight:700;left:50%;position:absolute;text-shadow:1px 1px 2px #0000004d;top:15px;transform:translateX(-50%);z-index:10}.east-marker,.north-marker,.south-marker,.west-marker{align-items:center;border:2px solid #dee2e6;border-radius:50%;color:#495057;display:flex;font-size:20px;height:30px;justify-content:center;position:absolute;width:30px}.north-marker{border-color:#dc3545;color:#dc3545;font-size:22px;font-weight:700;left:50%;top:10px;transform:translateX(-50%)}.east-marker{right:10px;top:50%;transform:translateY(-50%)}.south-marker{bottom:10px;left:50%;transform:translateX(-50%)}.west-marker{left:10px;top:50%;transform:translateY(-50%)}.simple-instructions{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;color:#6c757d;font-size:16px;font-weight:500;margin-top:30px;padding:15px}.error-screen,.permission-screen{align-items:center;background:#fff;display:flex;flex-direction:column;height:80vh;justify-content:center;text-align:center}.error-screen h1,.permission-screen h1{color:#dc3545;font-size:28px;margin-bottom:15px}.error-screen p,.permission-screen p{color:#6c757d;font-size:18px;margin-bottom:30px}.enable-btn,.retry-btn{background:#28a745;border:none;border-radius:25px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:18px;font-weight:700;padding:15px 40px}.enable-btn:hover,.retry-btn:hover{background:#218838;transform:translateY(-1px)}@media (max-width:480px){.compass-container{padding:15px}.compass-dial-container{height:280px;width:280px}.direction-display{font-size:48px}.heading-display{font-size:24px}}.compass-container{-webkit-user-select:none;user-select:none}button{min-height:50px;min-width:120px}.compass-dial{background:#fff;box-shadow:0 4px 8px #00000026}.east-marker,.north-marker,.south-marker,.west-marker{background:#fff;border:2px solid #495057;font-weight:700}.fixed-pointer{color:#dc3545;font-size:28px;text-shadow:0 2px 4px #0000004d}
/*# sourceMappingURL=main.4cd15f72.css.map*/