.app{width:100vw;height:100vh;position:relative;overflow:hidden;background:#f5f5f5;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.top-buttons{position:fixed;top:20px;right:20px;z-index:1000;display:flex;gap:10px}.calibrate-button,.toggle-fullscreen-button,.reset-button{width:30px;height:30px;padding:0;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s;display:flex;align-items:center;justify-content:center;font-size:14px;position:relative}.reset-button{background:#dc3545}.calibrate-button:before{content:"";width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M3 18h18v-2H3v2zm0-5h18v-2H3v2zm0-7v2h18V6H3z'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;background-position:center}.reset-button:before{content:"";width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 5V1L7 6l5 5V7c3.31 0 6 2.69 6 6s-2.69 6-6 6-6-2.69-6-6H4c0 4.42 3.58 8 8 8s8-3.58 8-8-3.58-8-8-8z'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;background-position:center}.calibrate-button:hover,.toggle-fullscreen-button:hover{background:#0056b3}.reset-button:hover{background:#c82333}.toggle-measurements-button{display:none}.ruler{position:fixed;top:0;left:0;z-index:500}.horizontal-ruler,.vertical-ruler{position:absolute;background:#ffffffe6;cursor:crosshair;-webkit-user-select:none;user-select:none}.horizontal-ruler{width:calc(100vw - 50px);height:50px;border-bottom:1px solid #ccc;z-index:501;left:50px}.vertical-ruler{width:50px;height:calc(100vh - 50px);border-right:1px solid #ccc;z-index:501;top:50px}.tick{position:absolute;background:#333;pointer-events:none}.horizontal-ruler .tick{width:1px;bottom:0}.vertical-ruler .tick{height:1px;right:0}.tick.mm{height:10px;width:1px}.tick.mm5{height:15px;width:1px}.tick.cm{height:20px;width:2px}.vertical-ruler .tick.mm{width:10px;height:1px}.vertical-ruler .tick.mm5{width:15px;height:1px}.vertical-ruler .tick.cm{width:20px;height:2px}.label{position:absolute;font-size:10px;color:#333}.horizontal-ruler .label{top:25px;transform:translate(-50%)}.vertical-ruler .label{right:25px;transform:translateY(-50%)}.measurement-lines{position:fixed;top:50px;left:50px;width:calc(100vw - 50px);height:calc(100vh - 50px);pointer-events:all}.measurement-line{position:absolute;cursor:move;z-index:100}.measurement-line.horizontal{width:calc(100vw - 50px);height:30px;transform:translateY(-5px);left:0}.measurement-line.vertical{height:calc(100vh - 50px);width:30px;transform:translate(-5px);top:0}.measurement-line:after{content:"";position:absolute;background:#007bff80;transition:background-color .2s}.measurement-line.horizontal:after{width:100%;height:1px;top:50%;transform:translateY(-50%)}.measurement-line.vertical:after{height:100%;width:1px;left:50%;transform:translate(-50%)}.measurement-line.horizontal:after,.measurement-line.vertical:after{border:none}.measurement-line:before{content:"";position:absolute;background:#007bffe6;border-radius:4px;z-index:1;opacity:0;transition:opacity .2s}.measurement-line.horizontal:before{width:24px;height:12px;left:10px;top:50%;transform:translateY(-50%)}.measurement-line.vertical:before{width:12px;height:24px;top:10px;left:50%;transform:translate(-50%)}.measurement-line:hover:after{background:#007bffcc}.measurement-line:hover:before{opacity:1}.measurement-line:active:after{background:#007bff}.calibration-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px;box-sizing:border-box}.modal-content{background:#fff;border-radius:8px;width:500px;max-width:100%;max-height:100%;display:flex;flex-direction:column}.modal-header{padding:20px 30px;border-bottom:1px solid #dee2e6}.modal-header h2{margin:0;color:#333}.modal-body{padding:30px;overflow-y:auto;flex:1}.modal-footer{padding:20px 30px;border-top:1px solid #dee2e6;display:flex;justify-content:flex-end;gap:10px;background:#fff;border-radius:0 0 8px 8px}.modal-footer button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.modal-footer button:first-child{background:#007bff;color:#fff}.modal-footer button:first-child:hover{background:#0056b3}.modal-footer button:last-child{background:#6c757d;color:#fff}.modal-footer button:last-child:hover{background:#5a6268}.calibration-methods{display:flex;flex-direction:column;gap:30px}.method{padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #dee2e6}.method h3{margin:0 0 15px;color:#007bff;font-size:18px}.method p{margin:0 0 20px;color:#666}.calibration-line{height:4px;background:#007bff;margin:40px 0;position:relative;resize:horizontal;overflow:auto;width:200px}.resize-handle{position:absolute;width:10px;height:20px;background:#007bff;top:50%;transform:translateY(-50%);cursor:ew-resize}.resize-handle.left{left:-5px}.resize-handle.right{right:-5px}.control{margin-top:20px}.control label{display:flex;align-items:center;gap:10px;color:#333}.control input{width:80px;padding:6px;border:1px solid #ced4da;border-radius:4px;font-size:14px}.buttons{display:flex;justify-content:flex-end;gap:10px;margin-top:30px}.buttons button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500}.buttons button:first-child{background:#007bff;color:#fff}.buttons button:first-child:hover{background:#0056b3}.buttons button:last-child{background:#6c757d;color:#fff}.buttons button:last-child:hover{background:#5a6268}.measurements-display{position:fixed;bottom:20px;right:20px;background:#fff;padding:15px;border-radius:8px;box-shadow:0 2px 10px #0000001a;z-index:1000;min-width:200px;border:1px solid rgba(0,123,255,.2);transition:transform .3s ease-in-out}.measurements-display.minimized{transform:translateY(calc(100% - 50px))}.measurements-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.minimize-button{background:none;border:none;color:#666;font-size:20px;cursor:pointer;padding:0 5px;line-height:1;transition:color .2s}.minimize-button:hover{color:#333}.measurements-display h3{margin:0;font-size:16px;color:#333;font-weight:600}.measurements-display h4{margin:5px 0;font-size:14px;color:#666;font-weight:500}.measurement-list{display:flex;gap:20px}.measurement-section{flex:1}.measurement-item{font-size:14px;color:#333;padding:4px 0;font-weight:500}.measurement-label{position:absolute;background:#fff;padding:6px 12px;border-radius:4px;font-size:16px;color:#000;pointer-events:none;z-index:2100;box-shadow:0 2px 8px #0003;border:2px solid #007bff;font-weight:600;white-space:nowrap;min-width:50px;text-align:center}.measurement-instructions{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;pointer-events:none}.instruction-box{background:#fffffff2;padding:20px 30px;border-radius:8px;box-shadow:0 2px 10px #0000001a}.instruction-box h3{margin:0 0 10px;color:#333;font-size:18px}.instruction-box ol{margin:0;padding-left:20px}.instruction-box li{color:#666;margin:8px 0;font-size:14px}.ratio-control{display:flex;flex-direction:column;gap:10px}.ratio-inputs{display:flex;align-items:center;gap:10px;justify-content:center}.ratio-inputs input{width:60px;text-align:center}.ratio-divider{font-size:20px;font-weight:700;color:#333}.ratio-preview{text-align:center;color:#666;font-size:14px}.ratio-control button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;background:#007bff;color:#fff;transition:background-color .2s;margin-top:10px}.ratio-control button:hover{background:#0056b3}.app:-webkit-full-screen{width:100vw!important;height:100vh!important;background:#f5f5f5;position:fixed;top:0;left:0}.app:-moz-full-screen{width:100vw!important;height:100vh!important;background:#f5f5f5;position:fixed;top:0;left:0}.app:-ms-fullscreen{width:100vw!important;height:100vh!important;background:#f5f5f5;position:fixed;top:0;left:0}.app:fullscreen{width:100vw!important;height:100vh!important;background:#f5f5f5;position:fixed;top:0;left:0}.current-calibration{background:#f8f9fa;padding:15px;border-radius:8px;margin-bottom:20px;border:1px solid #dee2e6}.current-calibration p{margin:0 0 10px;color:#666;font-size:14px}.calibration-values{display:flex;gap:20px;font-size:16px;color:#333;font-weight:500}.new-calibration-preview{margin-top:15px;padding-top:15px;border-top:1px solid #dee2e6;color:#666;font-size:14px}.new-calibration-preview .calibration-values{margin-top:8px;color:#007bff}.top-buttons button{min-width:30px;min-height:30px;padding:0;margin:4px;font-size:14px;touch-action:manipulation}@media (max-width: 768px){.top-buttons{gap:5px}.top-buttons button{width:30px;height:30px;padding:0;font-size:14px}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}
