*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #469BDE;--primary-hover: #3A7FB8;--primary-light: #E8F4FC;--secondary-color: #454545;--secondary-hover: #2A2A2A;--error-color: #BE2823;--error-light: #FCE8E7;--success-color: #28A745;--success-light: #D4EDDA;--warning-color: #FFC107;--warning-light: #FFF3CD;--text-primary: #454545;--text-secondary: #666666;--text-light: #999999;--border-color: #E0E0E0;--background: #F5F7FA;--surface: #FFFFFF;--surface-hover: #F8F9FA}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-primary)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.project-list-page{min-height:100vh;background-color:var(--background);padding:2rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{font-size:2rem;color:var(--text-primary)}.btn-primary{padding:.75rem 1.5rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s;font-weight:500}.btn-primary:hover{background-color:var(--primary-hover)}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.btn-secondary{padding:.75rem 1.5rem;background-color:var(--secondary-color);color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s;font-weight:500}.btn-secondary:hover{background-color:var(--secondary-hover)}.btn-secondary:disabled{background-color:#ccc;cursor:not-allowed}.btn-link{background:none;border:none;color:var(--primary-color);cursor:pointer;text-decoration:underline;font-size:.875rem}.btn-link:hover{color:var(--primary-hover)}.filters{background-color:var(--surface);padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end;border:1px solid var(--border-color)}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.filter-group label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.filter-group input,.filter-group select{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.project-count{margin-bottom:1rem;color:var(--text-secondary);font-size:.875rem}.project-table{background-color:var(--surface);border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #00000014;border:1px solid var(--border-color)}.project-table table{width:100%;border-collapse:collapse}.project-table thead{background-color:var(--surface-hover)}.project-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color)}.project-table td{padding:1rem;border-bottom:1px solid var(--border-color)}.project-table tbody tr:hover{background-color:var(--surface-hover)}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.badge-presale{background-color:var(--warning-light);color:#856404}.badge-dev{background-color:var(--primary-light);color:var(--primary-hover)}.badge-maintain{background-color:var(--success-light);color:#155724}.badge-recurring{background-color:#e2e3e5;color:var(--text-primary)}.empty-state{background-color:var(--surface);padding:3rem;border-radius:8px;text-align:center;color:var(--text-secondary);border:1px solid var(--border-color)}.loading,.error{background-color:var(--surface);padding:2rem;border-radius:8px;text-align:center;border:1px solid var(--border-color)}.error{color:var(--error-color)}.project-form-page{min-height:100vh;background-color:var(--background);padding:2rem}.project-form{background-color:var(--surface);padding:2rem;border-radius:8px;max-width:600px;box-shadow:0 2px 4px #00000014;border:1px solid var(--border-color)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.required{color:var(--error-color)}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.form-group input.error,.form-group select.error{border-color:var(--error-color)}.form-group input:disabled,.form-group select:disabled{background-color:var(--surface-hover);cursor:not-allowed}.error-message{color:var(--error-color);font-size:.875rem;margin-top:.25rem}.general-error{padding:1rem;background-color:var(--error-light);border:1px solid var(--error-color);border-radius:4px;margin-bottom:1.5rem;color:var(--error-color)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.time-record-page{min-height:100vh;background-color:var(--background);padding:2rem}.week-selector{background-color:var(--surface);padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;display:flex;gap:1rem;align-items:center;justify-content:center;box-shadow:0 2px 4px #00000014;border:1px solid var(--border-color)}.week-display{display:flex;flex-direction:column;align-items:center;min-width:250px}.week-number{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.week-range{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.summary-card{background-color:var(--surface);padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;display:flex;gap:2rem;align-items:center;box-shadow:0 2px 4px #00000014;border:1px solid var(--border-color);flex-wrap:wrap}.summary-card.over-limit{border:2px solid var(--error-color);background-color:var(--error-light)}.holiday-notice{width:100%;padding:.75rem;background-color:var(--primary-light);color:var(--primary-hover);border-radius:4px;font-size:.875rem;font-weight:500}.summary-item{display:flex;flex-direction:column;gap:.5rem}.summary-label{font-size:.875rem;color:var(--text-secondary)}.summary-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.warning-message{color:var(--error-color);font-weight:500;margin-left:auto}.success-message{background-color:var(--success-light);border:1px solid var(--success-color);color:#155724;padding:1rem;border-radius:4px;margin-bottom:1.5rem}.time-record-table{background-color:var(--surface);padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;box-shadow:0 2px 4px #00000014;border:1px solid var(--border-color)}.time-record-table h2{font-size:1.25rem;color:var(--text-primary);margin-bottom:1rem}.time-record-table table{width:100%;border-collapse:collapse}.time-record-table thead{background-color:var(--surface-hover)}.time-record-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color)}.time-record-table td{padding:1rem;border-bottom:1px solid var(--border-color)}.input-number{width:100px;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;text-align:right}.input-number:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.unit{margin-left:.5rem;color:var(--text-secondary);font-size:.875rem}.additional-hours{background-color:var(--surface);padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;box-shadow:0 2px 4px #00000014;border:1px solid var(--border-color)}.additional-hours h2{font-size:1.25rem;color:var(--text-primary);margin-bottom:1rem}.form-row{display:flex;gap:2rem}.form-row .form-group{flex:1}.report-page{min-height:100vh;background-color:var(--background);padding:2rem}.report-page h1{font-size:2rem;color:var(--text-primary);margin-bottom:2rem}.query-section{background-color:var(--surface);padding:2rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 2px 4px #00000014;border:1px solid var(--border-color)}.query-section h2{font-size:1.5rem;color:var(--text-primary);margin-bottom:1.5rem}.query-section h3{font-size:1.125rem;color:var(--text-primary);margin-bottom:1rem}.time-range-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.quick-range-buttons{display:flex;gap:.5rem;margin-bottom:1rem}.quick-range-buttons button{padding:.5rem 1rem;background-color:var(--surface-hover);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .2s;color:var(--text-primary)}.quick-range-buttons button:hover{background-color:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.date-inputs{display:flex;gap:1rem;flex-wrap:wrap}.date-inputs .form-group{flex:1;min-width:200px}.filter-section{margin-bottom:2rem}.checkbox-group{display:flex;gap:1rem;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s}.checkbox-label:hover{background-color:var(--surface-hover)}.checkbox-label input[type=checkbox]{cursor:pointer;accent-color:var(--primary-color)}.query-actions{display:flex;justify-content:flex-end;margin-top:1.5rem}.result-section{background-color:var(--surface);padding:2rem;border-radius:8px;box-shadow:0 2px 4px #00000014;border:1px solid var(--border-color)}.result-section h2{font-size:1.5rem;color:var(--text-primary);margin-bottom:1.5rem}.result-section h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:1rem}.summary-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.breakdown-section{margin-bottom:2rem}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;margin-top:1rem}.data-table thead{background-color:var(--surface-hover)}.data-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap}.data-table td{padding:1rem;border-bottom:1px solid var(--border-color)}.data-table tbody tr:hover{background-color:var(--surface-hover)}.empty-message{color:var(--text-secondary);font-style:italic;padding:2rem;text-align:center;background-color:var(--surface-hover);border-radius:4px}.charts-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-color)}.charts-section h2{font-size:1.5rem;color:var(--text-primary);margin-bottom:1.5rem}.chart-container{margin-bottom:2rem;padding:1.5rem;background-color:var(--surface-hover);border-radius:8px;border:1px solid var(--border-color)}.chart-container h3{font-size:1.125rem;color:var(--text-primary);margin-bottom:1rem}
