body{margin:0;padding:0;font-family:Arial,sans-serif;background:#f0f0f0}.radial-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1000}.radial-menu-container{position:relative;width:370px;height:370px;background:white;border-radius:50%;padding:10px}.menu-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;background:#3498db;color:#fff;font-size:18px;font-weight:700;display:flex;justify-content:center;align-items:center;box-shadow:0 4px 8px #0003;z-index:10}.radial-menu-container svg{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.brand-list-container{background:white;border-radius:8px;padding:20px;max-width:400px;max-height:500px;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.brand-list-title{text-align:center;font-size:18px;font-weight:700;margin-bottom:15px;color:#333}.brand-list-item{padding:12px 15px;margin:5px 0;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;cursor:pointer;transition:all .2s ease}.brand-list-item:hover{background:#e9ecef;border-color:#6c757d}.brand-list-item:active{background:#dee2e6}.brand-name-en{font-weight:700;color:#495057}.brand-name-jp{font-size:12px;color:#6c757d;margin-top:2px}.new-record-button{display:inline-block;margin-left:20px;padding:8px 16px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;box-shadow:0 2px 4px #007bff33;transition:all .2s ease;vertical-align:middle}.new-record-button:hover{background:#0056b3;transform:translateY(-1px);box-shadow:0 4px 8px #007bff4d}.page-title-container{display:flex;align-items:center;margin-bottom:20px}.page-title-container h1{margin:0}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;animation:fadeIn .3s ease-out forwards}@keyframes fadeIn{to{opacity:1}}.modal-content{background:white;border-radius:12px;width:95%;max-width:900px;max-height:90vh;overflow:hidden;box-shadow:0 8px 32px #0000004d;transform:scale(.9);animation:scaleIn .3s ease-out forwards;padding:0 16px;box-sizing:border-box}@keyframes scaleIn{to{transform:scale(1)}}.modal-header{padding:24px 32px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa;border-radius:12px 12px 0 0}.modal-title{font-size:24px;font-weight:700;color:#333;margin:0}.modal-close{background:none;border:none;font-size:28px;cursor:pointer;color:#6c757d;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal-close:hover{color:#dc3545;background:#fff5f5}.modal-body{padding:32px;overflow-y:auto;max-height:calc(90vh - 200px)}.input-group{margin-bottom:28px}.input-group:last-child{margin-bottom:0}.input-group label{display:block;margin-bottom:0;margin-right:16px;font-weight:700;color:#333;font-size:16px;min-width:80px;flex-shrink:0}.input-wrapper{display:flex;align-items:center;gap:12px}.input-field{flex:1;padding:12px 16px;border:2px solid #ddd;border-radius:6px;font-size:16px;transition:all .3s ease;background:white}.input-field:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.input-field:read-only{background:#f8f9fa;color:#6c757d}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover{background:#0056b3;transform:translateY(-1px)}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838;transform:translateY(-1px)}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333;transform:translateY(-1px)}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268;transform:translateY(-1px)}.btn-small{padding:8px 16px;font-size:13px}.buy-item-modal .btn-small{padding:10px 18px!important;font-size:14px!important;min-height:40px!important;line-height:1.2!important}.modal-footer{padding:24px 32px;border-top:1px solid #e9ecef;display:flex;gap:16px;justify-content:flex-end;background:#f8f9fa;border-radius:0 0 12px 12px}.selection-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:2000}.selection-content{background:white;border-radius:8px;width:90%;max-width:500px;max-height:70vh;overflow:hidden;box-shadow:0 4px 20px #0000004d}.selection-header{padding:20px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa}.selection-title{font-size:18px;font-weight:700;color:#333;margin:0}.selection-body{padding:16px;overflow-y:auto;max-height:50vh}.selection-item{padding:12px 16px;margin:4px 0;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;justify-content:space-between;align-items:center}.selection-item:hover{background:#e9ecef;border-color:#6c757d;transform:translate(4px)}.selection-item:active{background:#dee2e6}.item-main{font-weight:600;color:#495057}.item-sub{font-size:12px;color:#6c757d;margin-left:8px}.keypad-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:3000}.keypad-container{background:white;border-radius:8px;padding:24px;box-shadow:0 4px 20px #0000004d;min-width:320px}.keypad-display{background:#f8f9fa;border:2px solid #dee2e6;border-radius:6px;padding:16px;margin-bottom:20px;font-size:24px;text-align:right;font-family:Courier New,monospace;min-height:40px;font-weight:700}.keypad-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.keypad-button{padding:20px;font-size:20px;font-weight:700;border:2px solid #dee2e6;background:#f8f9fa;border-radius:6px;cursor:pointer;transition:all .2s ease}.keypad-button:hover{background:#e9ecef;border-color:#6c757d;transform:scale(1.05)}.keypad-button:active{background:#dee2e6;transform:scale(.95)}.keypad-button.keypad-ok{background:#28a745;color:#fff;border-color:#28a745}.keypad-button.keypad-ok:hover{background:#218838;border-color:#1e7e34}.keypad-button.keypad-control{background:#dc3545;color:#fff;border-color:#dc3545}.keypad-button.keypad-control:hover{background:#c82333;border-color:#bd2130}.voice-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:3000}.voice-modal{background:white;border-radius:8px;padding:0;box-shadow:0 4px 20px #0000004d;min-width:400px;max-width:500px}.voice-modal-header{padding:20px;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;align-items:center}.voice-modal-header h3{margin:0;color:#333}.voice-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.voice-modal-close:hover{color:#dc3545}.voice-modal-content{padding:20px}.voice-status{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:10px;background:#f8f9fa;border-radius:4px}.status-indicator{width:12px;height:12px;border-radius:50%;background:#6c757d;transition:background .3s}.status-indicator.active{background:#e74c3c;animation:pulse 1s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.status-text{font-weight:700;color:#333}.voice-transcript{min-height:100px;max-height:200px;overflow-y:auto;padding:15px;border:2px solid #dee2e6;border-radius:4px;background:#f8f9fa;font-size:16px;line-height:1.5;margin-bottom:20px;white-space:pre-wrap}.voice-transcript:empty:before{content:"音声が認識されるとここに表示されます...";color:#6c757d;font-style:italic}.voice-controls{display:flex;gap:10px;margin-bottom:20px;justify-content:center}.voice-control-btn{padding:12px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px;transition:all .3s}.voice-control-btn:disabled{opacity:.5;cursor:not-allowed}.voice-control-btn.start{background:#28a745;color:#fff}.voice-control-btn.start:hover:not(:disabled){background:#218838}.voice-control-btn.stop{background:#dc3545;color:#fff}.voice-control-btn.stop:hover:not(:disabled){background:#c82333}.voice-control-btn.clear{background:#6c757d;color:#fff}.voice-control-btn.clear:hover:not(:disabled){background:#5a6268}.voice-actions{display:flex;gap:10px;justify-content:flex-end}.voice-action-btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;transition:all .3s}.voice-action-btn.cancel{background:#6c757d;color:#fff}.voice-action-btn.cancel:hover{background:#5a6268}.voice-action-btn.confirm{background:#007bff;color:#fff}.voice-action-btn.confirm:hover{background:#0056b3}@media (max-width: 768px){.modal-content{width:98%;max-width:none;max-height:95vh}.modal-header,.modal-body,.modal-footer{padding:16px}.modal-title{font-size:18px}.input-wrapper{flex-direction:column;align-items:stretch;gap:8px}.input-group label{min-width:auto;margin-right:0;margin-bottom:8px}.btn-small{width:100%;margin-bottom:4px}.page-title-container{flex-direction:column;align-items:flex-start;gap:10px}.new-record-button{margin-left:0;padding:10px 16px;font-size:14px}}@media (max-width: 480px){.modal-header,.modal-body,.modal-footer{padding:12px}.modal-title{font-size:16px}.input-field{font-size:14px;padding:10px 12px}.btn-small{font-size:12px;padding:8px 12px}.buy-item-modal .btn-small{font-size:13px!important;padding:10px 14px!important;min-height:38px!important}}.buy-items-table{width:100%;border-collapse:collapse;background:white;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.buy-items-table thead{background:#f8f9fa;border-bottom:2px solid #dee2e6}.buy-items-table th{padding:12px 8px;text-align:left;font-weight:700;color:#495057;font-size:13px;white-space:nowrap;border-right:1px solid #dee2e6}.buy-items-table th:last-child{border-right:none;text-align:center}.buy-items-table tbody tr{border-bottom:1px solid #f1f3f4;transition:background-color .2s ease}.buy-items-table tbody tr:hover{background-color:#f8f9fa}.buy-items-table tbody tr:last-child{border-bottom:none}.buy-item-cell{padding:10px 8px;font-size:13px;color:#333;border-right:1px solid #f1f3f4;vertical-align:middle}.buy-item-cell:last-child{border-right:none}.buy-item-price{text-align:right;font-family:Courier New,monospace;font-weight:500}.buy-item-number{text-align:center}.buy-item-actions{text-align:center;white-space:nowrap}.buy-item-actions .btn{min-width:45px;font-size:11px;padding:4px 8px;margin:0 2px;white-space:nowrap}.buy-items-table th:nth-child(1){width:12%}.buy-items-table th:nth-child(2){width:15%}.buy-items-table th:nth-child(3){width:12%}.buy-items-table th:nth-child(4){width:20%}.buy-items-table th:nth-child(5){width:12%}.buy-items-table th:nth-child(6){width:8%}.buy-items-table th:nth-child(7){width:12%}.buy-items-table th:nth-child(8){width:9%}@media (max-width: 768px){.buy-items-table{font-size:12px}.buy-items-table th,.buy-item-cell{padding:8px 4px;font-size:11px}.buy-item-actions .btn{font-size:10px;padding:3px 6px;margin:0 1px}.buy-items-table th:nth-child(4),.buy-items-table td:nth-child(4){display:none}}@media (max-width: 480px){.buy-items-table th:nth-child(3),.buy-items-table td:nth-child(3){display:none}}.flash-message{position:fixed;top:20px;right:20px;z-index:9999;min-width:300px;max-width:500px;border-radius:8px;box-shadow:0 4px 12px #0003;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.flash-message-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.flash-message-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.flash-message-warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.flash-message-info{background-color:#cce7ff;border:1px solid #b3d9ff;color:#004085}.flash-message-content{display:flex;align-items:flex-start;justify-content:space-between;padding:16px;gap:12px}.flash-message-text{flex:1;font-weight:500;line-height:1.4;white-space:pre-line}.flash-message-close{background:none;border:none;font-size:18px;font-weight:700;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease;flex-shrink:0}.flash-message-success .flash-message-close:hover{background-color:#1557241a}.flash-message-error .flash-message-close:hover{background-color:#721c241a}.flash-message-warning .flash-message-close:hover{background-color:#8564041a}.flash-message-info .flash-message-close:hover{background-color:#0040851a}@media (max-width: 768px){.flash-message{top:10px;right:10px;left:10px;min-width:auto;max-width:none}.flash-message-content{padding:12px}}
