.app{display:flex;justify-content:center;align-items:center;height:100%;background-color:#f0f2f5;padding:0}.calculator{background-color:#e9ecef;border-radius:0;box-shadow:none;padding:15px;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.display-container{display:flex;align-items:stretch;background-color:#f8f9fa;border-radius:8px;margin-bottom:15px;border:1px solid #dee2e6;min-height:60px;overflow:hidden}.display-input{flex-grow:1;padding:20px;font-family:monospace;font-size:28px;color:#343a40;text-align:left;border:none;outline:none;background-color:transparent;width:1%;min-width:50%;caret-color:#007bff;caret-shape:bar;cursor:text;-webkit-user-select:text;user-select:text}@media (max-width: 768px){input.display-input{-webkit-user-modify:read-only!important;-webkit-appearance:none!important;caret-color:#007bff!important;cursor:text!important;-webkit-user-select:text!important;user-select:text!important;touch-action:manipulation!important}input.display-input:focus{outline:none!important;caret-color:#007bff!important;-webkit-text-fill-color:#343a40!important}}input[readonly].display-input{opacity:1;background-color:transparent;color:#343a40;-webkit-appearance:none;caret-color:#007bff!important;cursor:text!important}.display-answer{padding:20px;font-family:monospace;font-size:28px;color:#6c757d;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:1px solid #e0e0e0;background-color:#f8f9fa;flex-shrink:0}.display{display:none}.keypad{flex-grow:1;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-top:10px}.button{padding:6px;border:none;border-radius:6px;font-size:16px;cursor:pointer;transition:background-color .2s,box-shadow .2s;background-color:#fff;color:#495057;border:1px solid #dee2e6;box-shadow:0 2px 3px #0000000d;height:40px;display:flex;align-items:center;justify-content:center}.button:hover{background-color:#f1f3f5;box-shadow:0 3px 5px #0000001a}.button:active{box-shadow:inset 0 1px 3px #0000001a;transform:translateY(1px)}.button.operator{background-color:#e7f5ff;color:#1971c2}.button.operator:hover{background-color:#d0ebff}.button.function{background-color:#f8f9fa;color:#495057}.button.function:hover{background-color:#e9ecef}.button.equals{background-color:#339af0;color:#fff;grid-column:span 2}.button.equals:hover{background-color:#1c7ed6}.button.clear{background-color:#fa5252;color:#fff}.button.clear:hover{background-color:#f03e3e}.mode-toggle{display: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}}.keypad-form{flex:0 0 auto;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding-top:2px}.sessions-list{flex-grow:1;overflow-y:auto;flex-shrink:1;gap:8px;padding-right:5px}.session-item{border:2px solid transparent;border-radius:8px;padding:3px;transition:border-color .2s ease-in-out,background-color .2s ease-in-out;cursor:pointer;background-color:#f8f9fa}.session-item:hover{border-color:#adb5bd}.session-item.active{border-color:#339af0;background-color:#fff;cursor:default}.session-item .display-container{min-height:50px;border-radius:6px;margin-bottom:0;display:flex;align-items:stretch;overflow:hidden}.session-item .display-input{padding:10px 15px;font-size:20px;font-family:monospace;color:#343a40;text-align:left;border:none;outline:none;background-color:transparent;width:1%;flex-grow:1;min-width:50%;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.session-item .display-input.inactive-expression::placeholder{color:#adb5bd;font-style:italic}.placeholder-text{display:none}.add-session-container{flex-shrink:0;margin:10px 0}.add-session-button{width:50px;height:50px;font-size:26px;line-height:1;padding:0;border-radius:50%;background-color:#20c997;color:#fff;border:none;box-shadow:0 2px 5px #0000001a}.add-session-button:hover{background-color:#1aa07a;box-shadow:0 4px 8px #00000026}.session-item .display-answer{touch-action:pan-y;cursor:grab;padding:10px 15px;font-size:16px;font-family:monospace;color:#6c757d;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:1px solid #e0e0e0;background-color:transparent;flex-shrink:0}.cancel-delete-button{background-color:#dc3545;color:#fff;border:none;padding:10px 15px;font-size:16px;font-family:monospace;text-align:center;flex-grow:1;cursor:pointer;border-radius:0 6px 6px 0;transition:background-color .2s;white-space:nowrap}.cancel-delete-button:hover{background-color:#c82333}@media (orientation: landscape) and (max-height: 600px){.calculator{flex-direction:row;height:100%;padding:10px}.session-area{flex:1 1 auto;height:auto;min-height:auto;display:flex;flex-direction:column;margin-right:10px;overflow:hidden}.sessions-list{flex-grow:1;height:auto;margin-bottom:0}.add-session-container{order:1;margin:10px 0 5px;justify-content:flex-start}.keypad-form{flex:0 0 auto;height:auto;padding-left:10px;min-height:auto;overflow:hidden;display:flex;flex-direction:column}}@media (max-width: 360px) and (orientation: portrait){.calculator{padding:10px}.session-item .display-input{font-size:14px}.session-item .display-answer{font-size:12px}}.session-area{flex:1 1 auto;min-height:0;overflow:hidden;display:flex;flex-direction:column;margin-bottom:10px}.keypad-form{flex:0 0 auto;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding-top:5px}.fn-toggle{position:absolute;top:0;left:0;z-index:2;padding:8px 12px;font-size:14px;background-color:#e7f5ff;color:#1971c2;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;transition:background-color .2s;font-weight:500}.fn-toggle:hover{background-color:#d0ebff}.back-button{background-color:#f8f9fa;color:#495057;font-weight:500;grid-column:1 / 2;grid-row:1 / 2}.back-button:hover{background-color:#e9ecef}.keypad.function-mode{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#fff;z-index:1;animation:slideIn .2s ease-out}.keypad.standard-mode{animation:slideOut .2s ease-out}.button.abs-value{font-family:serif;font-weight:700}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOut{0%{transform:translate(-100%)}to{transform:translate(0)}}.keypads-container{position:relative;flex-grow:1;display:flex;flex-direction:column}.add-session-button-low-profile{padding:8px 16px;border:none;border-radius:6px;background-color:#e7f5ff;color:#1971c2;font-size:14px;cursor:pointer;transition:all .2s;margin-right:8px}.add-session-button-low-profile:hover{background-color:#d0ebff}.reset-button-low-profile{padding:8px 16px;border:none;border-radius:6px;background-color:#fff5f5;color:#e03131;font-size:14px;cursor:pointer;transition:all .2s}.reset-button-low-profile:hover{background-color:#ffe3e3}.reset-button-low-profile[title^=Click]{background-color:#fa5252;color:#fff;animation:pulse 1s infinite}.reset-button-low-profile[title^=Click]:hover{background-color:#ff6b6b}@keyframes pulse{0%{opacity:1}50%{opacity:.8}to{opacity:1}}html,body,#root{height:100%;width:100%;margin:0;padding:0}: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{display:flex;place-items:center}
