html,body,#root{margin:0;padding:0;width:100%;height:100%;overflow:hidden;display:flex;justify-content:center;align-items:center;background-color:#f0f8ff;font-family:Hiragino Sans,ヒラギノ角ゴシック,メイリオ,Meiryo,MS Pゴシック,MS PGothic,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-select:none;user-select:none}.app-container{width:100%;height:100%;display:flex;flex-direction:column;box-shadow:0 0 20px #0000001a;background-color:#fff;position:relative}.number-pad{margin-top:20px}.number-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.number-grid button{padding:.8rem;font-size:1.6em;border:none;border-radius:10px;background-color:#f0f0f0;cursor:pointer;transition:background-color .2s}.number-grid button:hover{background-color:#e0e0e0}.number-grid button:nth-child(10){grid-column:span 2;width:100%}.action-buttons{margin-top:15px;display:grid;grid-template-columns:1fr 1fr;gap:8px}.action-buttons button{padding:.8rem;font-size:1.6em;border:none;border-radius:10px;cursor:pointer;transition:background-color .2s}.action-buttons button:first-child{background-color:#fdd}.action-buttons button:last-child{background-color:#dfd}.modal-content{background-color:#fff;padding:2vmin;border-radius:20px;text-align:center;box-shadow:0 5px 15px #0003;width:90%;max-width:400px;box-sizing:border-box;position:relative}.wallet-icon{width:10vmin;height:10vmin;margin-bottom:2vmin}.modal-content h2{font-size:6vmin;color:#333;margin-bottom:2vmin}.modal-content input[type=text]{width:50%;padding:1.5vmin;font-size:10vmin;text-align:center;border:2px solid #ddd;border-radius:10px;margin-bottom:2vmin;box-sizing:border-box}.progress-bar-container{width:250px;height:100%;background-color:#e0e0e0;border:2px solid black;position:relative;box-shadow:inset 0 2px 5px #0000001a}.progress-bar{width:100%;position:absolute;bottom:0;display:flex;flex-direction:column-reverse;transition:height .5s cubic-bezier(.68,-.55,.27,1.55)}.progress-bar-segment{width:100%;transition:height .3s ease;opacity:.9}.item-list{width:95%;max-height:100%;position:absolute;bottom:0;overflow-y:auto;display:flex;flex-direction:column-reverse}.item-row{display:flex;justify-content:space-between;align-items:center;padding:15px 30px;background-color:#f2f2f2;border-radius:10px;margin-bottom:10px;transition:opacity .3s,transform .3s;flex-wrap:wrap;box-shadow:0 2px 5px #0003}.main-screen-mobile-portrait .item-row{padding:10px}.item-row.disabled{opacity:.4;background-color:#efefef}.item-info{display:flex;align-items:center;font-size:1.5em;min-width:0}.item-color-circle{width:50px;height:50px;margin-right:15px;border-radius:50%;background-color:#e0e0e0;border:2px solid #fff;box-shadow:0 2px 5px #0000001a}.main-screen-mobile-portrait .item-color-circle{width:12.5px;height:12.5px}.item-actions{display:flex;align-items:center;min-width:0}.delete-button{background:none;border:none;font-size:2em;cursor:pointer;color:#ff6b6b;transition:transform .2s}.delete-button:hover{transform:scale(1.2)}.checkbox-container{display:inline-block;position:relative;cursor:pointer;margin-right:30px}.item-checkbox{position:absolute;opacity:0;width:0;height:0}.custom-checkbox{display:inline-block;width:25px;height:25px;border:2px solid #ccc;border-radius:4px;background-color:#fff;cursor:pointer;margin-right:15px;position:relative}.item-checkbox:checked+.custom-checkbox{background-color:#007bff;border-color:#007bff}.item-checkbox:checked+.custom-checkbox:after{content:"✓";font-size:20px;color:#fff;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.main-screen-mobile-portrait .custom-checkbox{width:25px;height:25px;margin-right:0}.main-screen-mobile-portrait .item-checkbox:checked+.custom-checkbox:after{font-size:20px}.main-screen{display:flex;flex-direction:column;height:100%;width:100%;padding:20px;box-sizing:border-box;aspect-ratio:3 / 2;max-width:100%;max-height:100%;margin:auto;position:relative;background-color:#f5f5f5}.header{text-align:center;padding:10px 0}.header h1{font-size:2.5em;color:#333;margin:0}.header h1.over-budget-alert{color:#ff4d4d}.content{display:flex;flex:1;height:0;gap:60px}.left-panel{flex:1;display:flex;flex-direction:column;justify-content:space-between;align-items:center;height:100%;border-radius:15px;background-color:#fff}.right-panel{flex:1;display:flex;flex-direction:column-reverse;position:relative;max-height:100%;border-radius:15px;background-color:#fff;align-items:center}.money-display-wrapper{width:100%;display:flex;justify-content:center;align-items:center}.money-display{display:flex;align-items:center;font-size:2.5em;font-weight:700;color:#333}.wallet-icon-main{width:60px;height:60px;margin-right:15px}.remaining-amount-display{font-size:1.2em;font-weight:700;margin:0;padding-left:30px}.progress-bar-wrapper{width:100%;flex-grow:1;display:flex;align-items:center;justify-content:center}.total-amount-display{font-size:1.5em;font-weight:700;margin:0}.over-budget-text{color:#ff4d4d}.add-item-button{position:absolute;bottom:15px;left:50%;transform:translate(-50%);background-color:orange;border:none;border-radius:50%;width:80px;height:80px;cursor:pointer;box-shadow:0 4px 10px #0003;display:flex;justify-content:center;align-items:center;transition:transform .2s;z-index:10}.cart-icon{width:60px;height:60px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:2vmin;border-radius:20px;text-align:center;box-shadow:0 5px 15px #0003;width:90%;max-width:400px;position:relative}.close-button{position:absolute;top:15px;right:15px;background:none;border:none;font-size:2em;cursor:pointer;color:#aaa}.cart-icon-modal{width:10vmin;height:10vmin;margin-bottom:2vmin}.input-area{display:flex;align-items:center;margin-bottom:2vmin;justify-content:center}.modal-content input[type=text]{flex:none;width:50%;padding:1.5vmin;font-size:10vmin;text-align:center;border:2px solid #ddd;border-radius:10px;box-sizing:border-box}@media (min-width: 769px){.modal-content input[type=text]{font-size:3em}}@media (min-width: 769px){.modal-content h2{font-size:2em}}.main-screen-mobile-portrait{display:flex;flex-direction:column;height:100%;width:100%;padding:10px;box-sizing:border-box}.main-screen-mobile-portrait .header{text-align:center;padding:5px 0}.main-screen-mobile-portrait .header h1{font-size:1.8em;color:#333;margin:0}.main-screen-mobile-portrait .header h1.over-budget-alert{color:#ff4d4d}.main-screen-mobile-portrait .top-section{display:flex;justify-content:space-around;align-items:center;margin-bottom:10px}.main-screen-mobile-portrait .top-section .money-display{display:flex;align-items:center;font-size:1.5em;font-weight:700;color:#333}.main-screen-mobile-portrait .top-section .wallet-icon-main{width:30px;height:30px;margin-right:10px}.main-screen-mobile-portrait .top-section .remaining-amount-display{font-size:1.2em;font-weight:700}.main-screen-mobile-portrait .top-section .over-budget-text{color:#ff4d4d}.main-screen-mobile-portrait .middle-section{display:flex;flex:1;margin-bottom:10px;position:relative}.main-screen-mobile-portrait .middle-section .progress-bar-container{width:80px;height:98%;background-color:#e0e0e0;border:2px solid black;position:relative;box-shadow:inset 0 2px 5px #0000001a}.main-screen-mobile-portrait .middle-section .item-list{position:absolute;width:auto;inset:0 0 0 90px;overflow-y:auto;padding-right:5px}.main-screen-mobile-portrait .bottom-section{display:flex;justify-content:space-between;align-items:center;padding:5px 0}.main-screen-mobile-portrait .bottom-section .total-amount-display{font-size:1.2em;font-weight:700}.main-screen-mobile-portrait .bottom-section .add-item-button{position:static;transform:none;width:60px;height:60px;box-shadow:0 2px 5px #0003;background-color:orange}.main-screen-mobile-portrait .bottom-section .cart-icon{width:45px;height:45px}.imgSplash{width:30vw;max-width:350px;display:block;margin:auto}.aAppStore{display:inline-block}.imgAppStore{height:45px;vertical-align:middle;object-fit:contain}.modalOverlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.modalContent{background-color:#fff;padding:40px 80px;border-radius:.5rem;box-shadow:0 10px 15px #0000001a;text-align:center;align-items:center;min-width:50vw;animation:fadeInUp 1s ease forwards}.modalCloseButton{padding:10px 30px;margin-top:50px;background-color:#ffc245;color:#000;border-radius:.375rem;font-weight:700;font-size:1.5rem;cursor:pointer;transition:background-color .4s ease}.modalCloseButton:hover{background-color:#ffa600}@keyframes fadeInUp{0%{opacity:0;transform:translate3d(0,40px,0)}to{opacity:1;transform:translateZ(0)}}
