*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: #2563eb;--blue-dark: #1d4ed8;--blue-light: #dbeafe;--green: #16a34a;--green-light: #dcfce7;--red: #dc2626;--red-light: #fee2e2;--orange: #ea580c;--orange-light: #ffedd5;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.08);--shadow-md: 0 4px 6px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05)}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Kaku Gothic ProN,Hiragino Sans,Meiryo,sans-serif;background:var(--gray-100);color:var(--gray-900);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}.app-layout{display:flex;flex-direction:column;height:100dvh}.app-content{flex:1;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav{display:flex;background:#fff;border-top:1px solid var(--gray-200);padding:0 0 env(safe-area-inset-bottom);position:sticky;bottom:0;z-index:100;box-shadow:0 -2px 8px #0000000f}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px 4px 6px;text-decoration:none;color:var(--gray-500);font-size:11px;font-weight:500;gap:3px;transition:color .15s;-webkit-tap-highlight-color:transparent}.bottom-nav a.active{color:var(--blue)}.bottom-nav a svg{width:22px;height:22px}.top-bar{background:var(--blue);color:#fff;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;padding-top:calc(12px + env(safe-area-inset-top))}.top-bar h1{font-size:18px;font-weight:700}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-header{padding:14px 16px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}.card-header h2{font-size:16px;font-weight:700}.card-body{padding:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:var(--blue-dark)}.btn-success{background:var(--green);color:#fff}.btn-danger{background:var(--red);color:#fff}.btn-warning{background:var(--orange);color:#fff}.btn-ghost{background:transparent;color:var(--gray-700);border:1px solid var(--gray-300)}.btn-ghost:hover{background:var(--gray-50)}.btn-sm{padding:6px 12px;font-size:13px;border-radius:6px}.btn-lg{padding:14px 24px;font-size:16px;border-radius:var(--radius)}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-group{margin-bottom:14px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:5px}.form-input{width:100%;padding:10px 12px;border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:15px;outline:none;transition:border-color .15s;background:#fff;font-family:inherit}.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1a}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:20px;padding-right:32px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:12px;font-weight:600}.badge-blue{background:var(--blue-light);color:var(--blue-dark)}.badge-green{background:var(--green-light);color:var(--green)}.badge-red{background:var(--red-light);color:var(--red)}.badge-orange{background:var(--orange-light);color:var(--orange)}.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:12px}@media (min-width: 480px){.product-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 768px){.product-grid{grid-template-columns:repeat(4,1fr)}}.product-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px 10px;background:#fff;border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all .12s;-webkit-tap-highlight-color:transparent;min-height:90px;gap:6px;box-shadow:var(--shadow);position:relative;-webkit-user-select:none;user-select:none}.product-btn:active{transform:scale(.95);box-shadow:none}.product-btn.pressed{transform:scale(.95);background:var(--blue-light);border-color:var(--blue)}.product-btn-name{font-size:14px;font-weight:700;text-align:center;line-height:1.3;word-break:break-all}.product-btn-maker{font-size:11px;color:var(--gray-500);text-align:center}.product-btn-price{font-size:16px;font-weight:800;color:var(--blue)}@keyframes saleFlash{0%{background:var(--green-light);border-color:var(--green)}to{background:#fff;border-color:var(--gray-200)}}.product-btn.just-sold{animation:saleFlash .6s ease-out}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th{background:var(--gray-50);padding:10px 12px;text-align:left;font-size:12px;font-weight:700;color:var(--gray-600);border-bottom:2px solid var(--gray-200);white-space:nowrap}td{padding:10px 12px;border-bottom:1px solid var(--gray-100);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--gray-50)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0}@media (min-width: 640px){.modal-overlay{align-items:center;padding:24px}}.modal{background:#fff;border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:480px;max-height:90dvh;overflow-y:auto;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom))}@media (min-width: 640px){.modal{border-radius:var(--radius)}}.modal-title{font-size:18px;font-weight:700;margin-bottom:16px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:12px}@media (min-width: 640px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:#fff;border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}.stat-label{font-size:12px;color:var(--gray-500);margin-bottom:4px}.stat-value{font-size:22px;font-weight:800}.stat-sub{font-size:12px;color:var(--gray-500);margin-top:2px}.alert{padding:12px 14px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:12px}.alert-info{background:var(--blue-light);color:var(--blue-dark)}.alert-success{background:var(--green-light);color:var(--green)}.alert-danger{background:var(--red-light);color:var(--red)}.page{padding:12px;max-width:900px;margin:0 auto}.section-title{font-size:16px;font-weight:700;margin-bottom:12px;color:var(--gray-800)}.text-sm{font-size:13px}.text-muted{color:var(--gray-500)}.text-right{text-align:right}.text-center{text-align:center}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.fw-bold{font-weight:700}.color-blue{color:var(--blue)}.color-green{color:var(--green)}.color-red{color:var(--red)}.color-orange{color:var(--orange)}.sale-feed{padding:12px;display:flex;flex-direction:column;gap:6px}.sale-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}.sale-item-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}.sale-item-info{flex:1;min-width:0}.sale-item-product{font-size:14px;font-weight:700}.sale-item-meta{font-size:12px;color:var(--gray-500)}.sale-item-price{font-size:15px;font-weight:800;color:var(--blue);white-space:nowrap}.staff-select-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}@media (min-width: 480px){.staff-select-grid{grid-template-columns:repeat(3,1fr)}}.staff-btn{padding:16px 12px;background:#fff;border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;font-size:15px;font-weight:700;text-align:center;transition:all .12s;-webkit-tap-highlight-color:transparent}.staff-btn:active{transform:scale(.96)}.staff-btn.selected{border-color:var(--blue);background:var(--blue-light);color:var(--blue)}.qty-btn{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;border:2px solid var(--gray-300);background:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent}.qty-btn:active{transform:scale(.9)}.qty-display{font-size:24px;font-weight:800;min-width:48px;text-align:center}.recharts-tooltip-wrapper{font-size:13px!important}.recharts-legend-item-text{font-size:12px!important}
