*,:before,:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}body{margin:0}#root{width:100%;min-height:100svh}:root{--navy:#1b2850;--navy-mid:#253568;--teal:#3bbdd5;--teal-dark:#2ea8bf;--teal-light:#e8f7fb;--bg:#f0f2f7;--white:#fff;--text:#2d3142;--text-light:#5c6480;--text-muted:#9ca3af;--border:#dde1ea;--border-light:#eef0f5;--shadow-sm:0 1px 4px #1b285012, 0 2px 12px #1b28500d;--shadow-md:0 4px 24px #1b28501f;--radius:8px;--radius-lg:12px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Hiragino Kaku Gothic ProN,Hiragino Sans,Noto Sans JP,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.6}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--white);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 1px 6px #1b28500f}.header-left{align-items:center;gap:14px;display:flex}.btn-admin{background:var(--navy);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s}.btn-admin:hover{background:var(--navy-mid)}.app-header h1{color:var(--navy);letter-spacing:.03em;align-items:center;gap:10px;font-size:15px;font-weight:700;display:flex}.app-header h1:before{content:"";background:var(--teal);border-radius:2px;width:3px;height:16px;display:inline-block}.header-info{align-items:center;gap:10px;display:flex}.company-badge{background:var(--teal-light);color:var(--teal-dark);border:1px solid #3bbdd54d;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.btn-text{color:var(--text-light);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;padding:5px 10px;font-family:inherit;font-size:13px;transition:all .15s}.btn-text:hover{color:var(--navy);background:var(--bg)}.app-main{flex:1;width:100%;max-width:1240px;margin:0 auto;padding:28px 20px}.page{justify-content:center;display:flex}.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);width:100%;max-width:640px;padding:32px}.card.wide{max-width:1100px}.card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:baseline;margin-bottom:22px;padding-bottom:14px;display:flex}.card h2{color:var(--navy);align-items:center;gap:8px;margin:0;font-size:17px;font-weight:700;display:flex}.card h2:before{content:"";background:var(--teal);border-radius:2px;flex-shrink:0;width:3px;height:15px;display:inline-block}.login-page{align-items:flex-start;padding-top:64px}.login-card{max-width:420px}.login-brand{text-align:center;border-bottom:1px solid var(--border-light);margin-bottom:28px;padding-bottom:24px}.login-brand h2{justify-content:center;margin-bottom:6px;font-size:20px}.login-brand h2:before{display:none}.login-brand p{color:var(--text-muted);margin-top:4px;font-size:12px}.login-card form{flex-direction:column;gap:14px;display:flex}.login-card .form-label{flex-direction:column;gap:5px;display:flex}.login-card .form-label span{color:var(--text-light);letter-spacing:.03em;font-size:12px;font-weight:600}input[type=password],input[type=text],input[type=number],input[type=date]{border:1px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--text);outline:none;width:100%;padding:10px 13px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #3bbdd51f}input::placeholder{color:var(--text-muted);font-size:13px}select{border:1px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--text);cursor:pointer;outline:none;width:100%;min-width:0;padding:9px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}select:focus{border-color:var(--teal);box-shadow:0 0 0 3px #3bbdd51f}.btn-primary{background:var(--teal);color:#fff;border-radius:var(--radius);cursor:pointer;letter-spacing:.02em;white-space:nowrap;border:none;padding:11px 24px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s,box-shadow .15s,transform .1s}.btn-primary:hover{background:var(--teal-dark);box-shadow:0 3px 10px #3bbdd566}.btn-primary:active{transform:translateY(1px)}.btn-primary:disabled{cursor:not-allowed;box-shadow:none;background:#a8d8e5;transform:none}.btn-secondary{background:var(--white);color:var(--navy);border:1.5px solid var(--navy);border-radius:var(--radius);cursor:pointer;white-space:nowrap;padding:9px 20px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.btn-secondary:hover{background:var(--navy);color:#fff}.btn-outline-teal{background:var(--white);color:var(--teal-dark);border:1.5px solid var(--teal);border-radius:var(--radius);cursor:pointer;white-space:nowrap;padding:9px 20px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.btn-outline-teal:hover{background:var(--teal);color:#fff}.btn-small{border:1px solid var(--teal);background:var(--teal);color:#fff;cursor:pointer;white-space:nowrap;border-radius:6px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.btn-small:hover{background:var(--teal-dark);border-color:var(--teal-dark)}.btn-small:disabled{opacity:.5;cursor:not-allowed}.btn-cancel{background:var(--white);color:var(--text-light);border-color:var(--border)}.btn-cancel:hover{background:var(--bg);color:var(--text);border-color:var(--border)}.btn-icon{cursor:pointer;color:var(--text-light);background:0 0;border:none;border-radius:5px;padding:5px 7px;font-family:inherit;font-size:14px;line-height:1;transition:background .15s}.btn-icon:hover{background:var(--bg);color:var(--text)}.btn-danger{color:#d45252}.btn-danger:hover{color:#b33;background:#fff0f0}.btn-large{padding:12px 32px;font-size:15px}.error{color:#c0392b;margin-top:4px;font-size:12px}.hint{color:var(--text-muted);font-size:12px;line-height:1.5}.message{border-radius:var(--radius);color:#1a6644;background:#edfaf4;border:1px solid #9de8c0;margin-bottom:16px;padding:10px 16px;font-size:13px}.company-section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.company-count{color:var(--text-muted);font-size:12px;font-weight:400}.company-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-bottom:20px;display:grid}.company-item{position:relative}.company-btn{background:var(--bg);border:1.5px solid var(--border);cursor:pointer;width:100%;min-height:68px;color:var(--navy);text-align:center;word-break:break-all;border-radius:10px;justify-content:center;align-items:center;padding:12px 10px;font-family:inherit;font-size:13px;font-weight:600;line-height:1.4;transition:all .15s;display:flex}.company-btn:hover{border-color:var(--teal);background:var(--teal-light);transform:translateY(-1px);box-shadow:0 2px 8px #3bbdd533}.company-actions{background:#fff;border-radius:6px;gap:2px;padding:2px;display:none;position:absolute;top:4px;right:4px;box-shadow:0 1px 4px #0000001f}.company-item:hover .company-actions{display:flex}.company-edit{background:var(--bg);border:1.5px solid var(--teal);border-radius:10px;align-items:center;gap:6px;min-height:68px;padding:6px;display:flex}.company-edit input{flex:1;min-width:0;padding:6px 8px;font-size:13px}.add-company-row{border-top:1px solid var(--border-light);align-items:center;gap:8px;margin-top:4px;padding-top:14px;display:flex}.add-company-row input{flex:1}.upload-area{margin-bottom:20px}.dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;background:var(--bg);justify-content:center;align-items:center;min-height:180px;padding:48px 24px;transition:all .2s;display:flex}.dropzone:hover,.dropzone.active{border-color:var(--teal);background:var(--teal-light)}.dropzone-icon{color:var(--text-muted);margin-bottom:10px;font-size:36px}.dropzone-text .main-text{color:var(--navy);margin-bottom:6px;font-size:15px;font-weight:600}.dropzone-text .hint{margin:2px 0;display:block}.preview-grid{flex-wrap:wrap;justify-content:flex-start;gap:10px;width:100%;display:flex}.preview-item{text-align:center;flex-shrink:0;width:110px;position:relative}.preview-thumb{object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);width:110px;height:84px;display:block}.preview-file{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:110px;height:84px;color:var(--teal-dark);justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.preview-name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:110px;margin-top:4px;font-size:10px;display:block;overflow:hidden}.preview-remove{border:1px solid var(--border);cursor:pointer;color:#c0392b;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;line-height:1;display:flex;position:absolute;top:-6px;right:-6px;box-shadow:0 1px 3px #00000026}.preview-add{border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;width:110px;height:84px;color:var(--text-muted);background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:26px;transition:all .15s;display:flex}.preview-add:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}.upload-footer{justify-content:space-between;align-items:center;gap:12px;margin-top:16px;display:flex}.upload-footer .btn-primary{flex:1}.result-page .card-header{flex-wrap:wrap;gap:8px}.result-page .card-header .hint{font-size:12px}.table-wrapper{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;overflow-x:auto}.result-table{border-collapse:collapse;table-layout:fixed;width:100%;font-size:13px}.result-table col.col-date{width:148px}.result-table col.col-account{width:200px}.result-table col.col-desc{width:auto}.result-table col.col-amount{width:120px}.result-table col.col-action{width:44px}.result-table th{background:var(--navy);color:#ffffffe6;text-align:left;white-space:nowrap;letter-spacing:.04em;text-overflow:ellipsis;padding:10px;font-size:12px;font-weight:600;overflow:hidden}.result-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.result-table th.sortable:hover{background:var(--navy-mid)}.result-table th.col-amount-h,.result-table td.col-amount-h{text-align:right;padding-right:12px}.result-table td{border-bottom:1px solid var(--border-light);vertical-align:middle;padding:6px;overflow:hidden}.result-table tr:last-child td{border-bottom:none}.result-table tr:hover td{background:#f8f9fc}.result-table input,.result-table select{border:1px solid var(--border);background:var(--white);width:100%;color:var(--text);box-sizing:border-box;text-overflow:ellipsis;border-radius:5px;padding:6px 7px;font-family:inherit;font-size:13px;transition:border-color .15s;overflow:hidden}.result-table input:focus,.result-table select:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 2px #3bbdd526}.result-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding-top:16px;display:flex}.total{color:var(--text-light);white-space:nowrap;font-size:14px;font-weight:500}.total strong{color:var(--navy);margin-left:6px;font-size:22px;font-weight:700}.admin-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:24px;display:flex;overflow-x:auto}.tab{cursor:pointer;color:var(--text-light);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:9px 20px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.tab.active{color:var(--teal-dark);border-bottom-color:var(--teal);font-weight:700}.tab:hover{color:var(--navy);background:var(--bg)}.admin-section{margin-top:4px}.admin-section h3{color:var(--navy);align-items:center;gap:6px;margin-bottom:14px;font-size:14px;font-weight:700;display:flex}.admin-section h3:before{content:"";background:var(--teal);border-radius:2px;width:3px;height:13px;display:inline-block}.admin-section h4{color:var(--text-light);margin:16px 0 10px;font-size:13px;font-weight:600}.admin-table{border-collapse:collapse;border:1px solid var(--border);border-radius:var(--radius);table-layout:fixed;width:100%;margin-bottom:16px;font-size:13px;overflow:hidden}.admin-table th{background:var(--bg);text-align:left;border-bottom:1px solid var(--border);color:var(--navy);letter-spacing:.03em;white-space:nowrap;text-overflow:ellipsis;padding:9px 14px;font-size:12px;font-weight:600;overflow:hidden}.admin-table td{border-bottom:1px solid var(--border-light);text-overflow:ellipsis;white-space:nowrap;padding:8px 14px;overflow:hidden}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#f8f9fc}.admin-table.companies col.col-id{width:52px}.admin-table.companies col.col-name{width:auto}.admin-table.companies col.col-mf{width:80px}.admin-table.companies col.col-act{width:44px}.settings-form{flex-direction:column;gap:16px;max-width:480px;margin:16px 0;display:flex}.settings-form label{color:var(--text-light);letter-spacing:.03em;text-transform:uppercase;flex-direction:column;gap:5px;font-size:12px;font-weight:600;display:flex}.settings-form input{font-size:14px;font-weight:400}.status-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-light);padding:10px 14px;font-size:13px}.company-selector{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.import-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.import-row input[type=date]{width:auto;padding:7px 10px}.import-row span{color:var(--text-muted)}.add-form{align-items:center;gap:8px;margin-top:12px;display:flex}.add-form input{flex:1}
