.app-layout{min-height:100vh;background:linear-gradient(160deg,#f0f4f8,#e2e8f0)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 2rem;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:2rem}.app-title{font-weight:700;font-size:1.1rem;text-decoration:none;color:#1a1a2e}.nav-links{display:flex;gap:1.5rem}.nav-links a{font-size:.875rem;color:#4a5568;font-weight:500;text-decoration:none;padding:.25rem 0;border-bottom:2px solid transparent;transition:all .2s}.nav-links a:hover{color:#0073bb;border-bottom-color:#0073bb;text-decoration:none}.header-right{font-size:.85rem;color:#4a5568}.user-info{display:flex;align-items:center;gap:.75rem}.username{font-weight:600;color:#1a1a2e}.user-role{color:#718096;font-size:.8rem}.logout-btn{padding:.3em .8em;font-size:.8rem;border-radius:4px;border:1px solid #e2e8f0;background:#fff;color:#4a5568}.logout-btn:hover{background:#f7fafc;border-color:#cbd5e0}.app-main{padding:2rem;max-width:1200px;margin:0 auto;width:100%}.home-page{max-width:1000px;margin:0 auto}.home-page h1{margin-bottom:.5rem}.home-page__subtitle{color:#4a5568;font-size:1rem;margin-bottom:2.5rem;line-height:1.6}.quick-actions h2{font-size:1.1rem;margin-bottom:1rem;color:#2d3748}.quick-actions__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.quick-actions__card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.75rem 1.25rem;border:1px solid #e2e8f0;border-radius:12px;text-decoration:none;color:#2d3748;transition:all .2s;background:#fff;min-height:130px;box-shadow:0 1px 3px #0000000a}.quick-actions__card:hover{border-color:#0073bb;background:#f7fbff;transform:translateY(-2px);box-shadow:0 4px 12px #0073bb1a;text-decoration:none}.quick-actions__icon{font-size:2rem;margin-bottom:.75rem}.quick-actions__label{font-size:.9rem;font-weight:600;text-align:center;color:#2d3748}.submission-form{max-width:100%;width:100%;margin:0 auto;padding:2rem 2.5rem;background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000a}.submission-form h2{margin-bottom:.25rem;color:#1a1a2e}.submission-form__user{color:#718096;font-size:.85rem;margin-bottom:1.5rem}.submission-form__error{padding:.75rem 1rem;margin-bottom:1.25rem;border-radius:6px;background-color:#fef2f2;border:1px solid #fecaca;color:#b91c1c;font-size:.875rem}.form-field{margin-bottom:1.5rem}.form-field label{display:block;font-weight:600;font-size:.875rem;margin-bottom:.4rem;color:#2d3748}.field-hint{display:block;font-weight:400;font-size:.8rem;color:#718096;margin-top:.15rem}.form-field select,.form-field textarea,.form-field input{width:100%;padding:.6rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;background:#fff;color:#1a1a2e;transition:border-color .2s,box-shadow .2s}.form-field select:focus,.form-field textarea:focus,.form-field input:focus{outline:none;border-color:#0073bb;box-shadow:0 0 0 3px #0073bb1a}.form-field--error select,.form-field--error textarea,.form-field--error input{border-color:#dc2626}.form-field textarea{resize:vertical;min-height:120px;line-height:1.6}.field-meta{display:flex;justify-content:space-between;align-items:center;margin-top:.35rem}.char-count{font-size:.75rem;color:#718096}.char-count--warning{color:#d97706}.char-count--over{color:#dc2626;font-weight:600}.field-error{font-size:.8rem;color:#dc2626}.form-actions{margin-top:2rem}.form-actions button{padding:.7em 2.5em;font-size:1rem;font-weight:600;border-radius:6px;border:none;background-color:#0073bb;color:#fff;cursor:pointer;transition:background-color .2s}.form-actions button:hover:not(:disabled){background-color:#005a92}.form-actions button:disabled{opacity:.5;cursor:not-allowed}.submission-success{max-width:700px;margin:2rem auto;padding:2rem;border-radius:12px;background:#f0fdf4;border:1px solid #bbf7d0}.submission-success h2{color:#166534;margin-bottom:.75rem}.submission-success button{margin-top:1rem;padding:.6em 1.5em;border-radius:6px;border:1px solid #0073bb;background:#fff;color:#0073bb;font-weight:600}.submission-success button:hover{background:#f7fbff}.loading-container{display:flex;align-items:center;justify-content:center;min-height:200px;color:#4a5568}.access-denied{text-align:center;padding:3rem;color:#4a5568}.notification-banner{margin-bottom:1rem}.notification-banner__item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-radius:8px;margin-bottom:.5rem}.notification-banner__item--reminder{background:#fffbeb;border:1px solid #fde68a}.notification-banner__item--overdue{background:#fef2f2;border:1px solid #fecaca}.notification-banner__content{display:flex;align-items:center;gap:.5rem}.notification-banner__message{font-size:.875rem;color:#2d3748}.notification-banner__dismiss{background:none;border:none;font-size:1.1rem;color:#718096;cursor:pointer;padding:.25rem}.notification-banner__dismiss:hover{color:#1a1a2e}.submission-history{width:100%}.submission-history h2{margin-bottom:1.25rem}.submission-history__filters{display:flex;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-field{display:flex;flex-direction:column;gap:.3rem}.filter-field label{font-size:.8rem;font-weight:600;color:#4a5568}.filter-field select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background:#fff;color:#1a1a2e;min-width:160px}.filter-field select:focus{outline:none;border-color:#0073bb;box-shadow:0 0 0 3px #0073bb1a}.filter-apply-btn{padding:.5rem 1.25rem;background:#0073bb;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer}.filter-apply-btn:hover{background:#005a92}.submission-history__error{padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;font-size:.875rem;margin-bottom:1rem}.submission-history__error button{margin-top:.5rem;padding:.4rem 1rem;background:#fff;border:1px solid #fecaca;border-radius:4px;color:#b91c1c;font-size:.8rem;cursor:pointer}.submission-history__loading,.submission-history__empty{padding:2rem;text-align:center;color:#718096}.submission-history__table-container{overflow-x:auto;border-radius:8px;border:1px solid #e2e8f0;background:#fff}.submission-history__table{width:100%;border-collapse:collapse;font-size:.875rem}.submission-history__table thead{background:#f7fafc;border-bottom:1px solid #e2e8f0}.submission-history__table th{text-align:left;padding:.75rem 1rem;font-weight:600;color:#4a5568;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.submission-history__table td{padding:.75rem 1rem;border-bottom:1px solid #f0f0f0;color:#2d3748}.submission-history__row{cursor:pointer;transition:background .15s}.submission-history__row:hover{background:#f7fbff}.description-cell{max-width:250px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600}.status-badge--submitted{background:#f0fdf4;color:#166534}.status-badge--pending{background:#fffbeb;color:#92400e}.status-badge--failed{background:#fef2f2;color:#b91c1c}.incident-type-badge{font-weight:500}.submission-history__pagination{margin-top:1rem;text-align:center}.load-more-btn{padding:.5rem 1.5rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#4a5568;font-size:.875rem;cursor:pointer}.load-more-btn:hover{background:#f7fafc;border-color:#0073bb;color:#0073bb}:root{font-family:Amazon Ember,Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#1a1a2e;background-color:#f0f2f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}a{font-weight:500;color:#0073bb;text-decoration:none}a:hover{color:#005a92;text-decoration:underline}h1,h2,h3,h4{color:#1a1a2e;margin-top:0}h1{font-size:1.75rem;line-height:1.3}h2{font-size:1.4rem}h3{font-size:1.1rem}button{border-radius:6px;border:1px solid transparent;padding:.6em 1.2em;font-size:.9rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s}select,input,textarea{font-family:inherit;font-size:.9rem}
