*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;width:100%;height:100%;overflow-x:hidden;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{display:flex;flex-direction:column;min-width:320px;min-height:100vh;color-scheme:light dark;color:#ffffffde;background-color:#242424}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{height:100%;margin:0;padding:0;font-family:Inter,sans-serif;background-color:#f8fafc}.landing-page-container{min-height:100vh;background-color:#f8fafc;overflow:hidden;position:relative;display:flex;flex-direction:column}.header{position:relative;z-index:20;width:100%;background-color:#fff;box-shadow:0 1px 2px #0000000d;padding:1rem 1.5rem}.header-nav{max-width:1280px;margin-left:auto;margin-right:auto;display:flex;justify-content:space-between;align-items:center}.logo-brand{font-size:1.5rem;font-weight:700;color:#1d4ed8;border-radius:.5rem;padding:.5rem;display:flex;align-items:center;gap:.5rem}.header-logo-icon{height:1.5em;width:auto;vertical-align:middle}.desktop-nav-links{display:none;align-items:center;list-style:none;padding:0;margin:0}.desktop-nav-links li{margin-left:1.5rem}.nav-link{color:#4b5563;text-decoration:none;display:flex;align-items:center;gap:.25rem;border-radius:.5rem;padding:.5rem;transition-property:color;transition-duration:.2s}.nav-link:hover{color:#2563eb}.nav-button{background:none;border:none;cursor:pointer;font-size:inherit;font-family:inherit}.simulate-login-button{background-color:#2563eb;color:#fff;padding:.5rem 1rem;border-radius:.5rem;border:none;cursor:pointer;transition-property:background-color;transition-duration:.2s;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.simulate-login-button:hover{background-color:#1d4ed8}.mobile-menu-button-container{display:block}.mobile-menu-button{color:#4b5563;border:none;background:none;cursor:pointer;padding:.5rem;border-radius:.5rem;transition-property:color;transition-duration:.2s}.mobile-menu-button:focus{outline:none;box-shadow:0 0 0 2px #3b82f680}.mobile-menu-dropdown{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#fffffff2;z-index:30;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;padding:1rem;box-sizing:border-box}.mobile-menu-close-button{position:absolute;top:1.5rem;right:1.5rem;color:#4b5563;border:none;background:none;cursor:pointer;padding:.5rem;border-radius:.5rem}.mobile-menu-close-button:focus{outline:none;box-shadow:0 0 0 2px #3b82f680}.mobile-nav-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;align-items:center;gap:1.5rem;font-size:1.25rem}.nav-link-mobile{color:#4b5563;text-decoration:none;display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:.5rem;transition-property:color;transition-duration:.2s}.nav-link-mobile:hover{color:#2563eb}.nav-button-mobile{background:none;border:none;cursor:pointer;font-size:inherit;font-family:inherit}.simulate-login-button-mobile{background-color:#2563eb;color:#fff;padding:.75rem 1.5rem;border-radius:.5rem;border:none;cursor:pointer;transition-property:background-color;transition-duration:.2s;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;font-size:1.125rem}.simulate-login-button-mobile:hover{background-color:#1d4ed8}.hero-section{position:relative;z-index:10;width:100%;min-height:calc(100vh - 80px);background-size:cover;background-position:center;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:1.5rem;box-sizing:border-box;background-image:url(/assets/logo_with_happy_contractors-qZddms5M.jpg)}.hero-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,#0000000d,#00000040);opacity:1}.hero-content{position:relative;z-index:10;color:#fff;text-align:center;max-width:48rem;margin-left:auto;margin-right:auto}.hero-title{font-size:1.5rem;line-height:1.25;font-weight:800;margin-bottom:.5rem;text-shadow:1px 1px 4px rgba(0,0,0,.8)}.hero-subtitle{font-size:1.125rem;margin-bottom:2rem;font-weight:500;text-shadow:1px 1px 4px rgba(0,0,0,.8)}.search-bar-container{width:100%;max-width:32rem;margin-left:auto;margin-right:auto;background-color:#fff;border-radius:9999px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;padding:.5rem;display:flex;align-items:center;gap:.5rem;border:1px solid #60a5fa}.search-input{flex-grow:1;padding:.75rem;color:#1f2937;border-radius:9999px 0 0 9999px;border:none;outline:none;background:none}.search-input::placeholder{color:#6b7280}.search-input:focus{box-shadow:none}.search-button{background-color:#2563eb;color:#fff;border-radius:9999px;padding:.75rem;border:none;cursor:pointer;transition-property:background-color;transition-duration:.2s;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.search-button:hover{background-color:#1d4ed8}.footer{position:relative;z-index:10;width:100%;padding-top:1rem;padding-bottom:1rem;text-align:center;color:#4b5563;font-size:.875rem;background-color:#f3f4f6;margin-top:auto}.contractor-results-section{padding:2rem 1.5rem;max-width:1280px;margin:0 auto;background-color:#fff;border-top:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border-radius:.5rem;margin-top:2rem;margin-bottom:2rem;display:block}.results-loading-container,.results-error-container,.results-no-data-container{text-align:center;padding:2rem;font-size:1.125rem;color:#4b5563;border:1px dashed #ccc;background-color:#f0f0f0}.results-spinner{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:30px;height:30px;animation:spin 1s linear infinite;margin:0 auto 1rem}.contractor-results-display{padding:1rem;background-color:#fff;border-radius:.5rem;box-shadow:0 2px 5px #0000000d}.contractor-card-title{font-size:1.5rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.contractor-card-detail{font-size:.95rem;color:#4b5563;margin-bottom:.25rem}.jobs-list-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.job-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 2px #0000000d}.job-card-detail{font-size:.875rem;color:#4b5563;margin-bottom:.25rem}@media (min-width: 640px){.hero-title{font-size:3rem}.hero-subtitle{font-size:1.25rem}}@media (min-width: 768px){.header{padding-left:2rem;padding-right:2rem}.desktop-nav-links{display:flex}.mobile-menu-button-container,.mobile-menu-dropdown{display:none}.hero-title{font-size:3.75rem}.hero-subtitle{font-size:1.5rem}.hero-content{max-width:64rem}.search-bar-container{max-width:42rem}}.image-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0acc;display:flex;align-items:center;justify-content:center;z-index:9990;animation:fadeIn .2s ease-in-out}.image-modal-content{position:relative;width:92vw;max-width:1200px;height:86vh;background:#111;border-radius:8px;overflow:hidden;box-shadow:0 10px 30px #0009;display:flex;flex-direction:column}.modal-close-button{position:absolute;top:10px;right:10px;background:#0000008c;border:none;color:#fff;padding:6px;border-radius:6px;cursor:pointer;z-index:1001}.modal-close-button:hover{background:#000000bf}.image-nav-button{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:20px;cursor:pointer;z-index:1000}.image-nav-button.left{left:12px}.image-nav-button.right{right:12px}.image-nav-button:hover{background:#000000b3}.image-viewer{display:flex;flex-direction:column;gap:10px;height:100%;padding:46px 16px 16px}.zoom-container{flex:1 1 auto;display:grid;place-items:center;overflow:hidden;background:#0e0e0e;border-radius:6px;-webkit-user-select:none;user-select:none}.zoomed-image{max-width:100%;max-height:100%;object-fit:contain;transition:transform .08s linear}.zoom-slider-container{position:absolute;top:10px;left:50%;transform:translate(-50%);background:#0009;color:#fff;padding:5px 10px;border-radius:6px;display:flex;align-items:center;gap:8px;z-index:20}.zoom-slider-container label{font-size:14px;white-space:nowrap}.zoom-slider-container input[type=range]{accent-color:#007bff}.carousel-thumbnails{display:flex;gap:8px;overflow-x:auto;padding:8px 4px;background:#00000040;border-radius:6px}.carousel-thumbnail{width:64px;height:48px;object-fit:cover;border-radius:4px;opacity:.8;outline:2px solid transparent;transition:transform .15s ease,opacity .15s ease,outline-color .15s ease;cursor:pointer}.carousel-thumbnail:hover{transform:translateY(-2px);opacity:1}.carousel-thumbnail.active{outline-color:#f1b722;opacity:1}.results-loading-container,.results-no-data-container{color:#fff;height:100%;display:grid;place-items:center}.results-spinner{width:36px;height:36px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .9s linear infinite}.results-message{margin-top:10px;color:#ddd}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 640px){.image-modal-content{width:96vw;height:88vh}.image-nav-button{width:38px;height:38px}.zoom-slider-container input[type=range]{width:160px}}.modal-content{background-color:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 4px 12px #0003;position:relative;width:95%;max-width:800px;box-sizing:border-box;max-height:90vh}.search-results-display{padding:.5rem}.results-message{color:#4b5563}.contractor-card{background-color:#f3f4f6;border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #ddd}.contractor-card-title{font-size:1.4rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.contractor-card-detail{font-size:.9rem;color:#4b5563;margin-bottom:.25rem}.jobs-list-container{padding-top:1rem;border-top:1px solid #e5e7eb}.jobs-list-title{font-size:1.15rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.job-companyname{color:#00f}.job-images-thumbnails{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.job-thumbnail{width:80px;height:80px;object-fit:cover;border-radius:4px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.job-thumbnail:hover{transform:scale(1.05);box-shadow:0 2px 6px #0000004d}.image-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:2000}.image-modal-content{position:relative;max-width:95%;max-height:95%;background:#111;border-radius:8px;overflow:hidden;padding:16px}.zoom-container{display:flex;justify-content:center;align-items:center;overflow:hidden;max-height:80vh;transition:transform .1s ease}.zoomed-image{max-width:100%;max-height:80vh;-webkit-user-select:none;user-select:none;pointer-events:none}.modal-close-button{position:absolute;top:8px;right:8px;background:#00000080;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:4px;z-index:10}.image-nav-button{position:absolute;top:50%;transform:translateY(-50%);background:#00000080;border:none;color:#fff;cursor:pointer;padding:10px;border-radius:50%;font-size:20px;z-index:10}.image-nav-button.left{left:10px}.image-nav-button.right{right:10px}.carousel-thumbnails{display:flex;gap:6px;margin-top:12px;justify-content:center;flex-wrap:wrap}.carousel-thumbnail{width:50px;height:50px;object-fit:cover;border-radius:4px;opacity:.7;cursor:pointer;transition:opacity .2s ease,transform .2s ease}.carousel-thumbnail.active,.carousel-thumbnail:hover{opacity:1;transform:scale(1.05)}.zoom-slider{position:absolute;top:8px;left:8px;background:#0009;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;z-index:10}.zoom-slider input[type=range]{width:100px}.results-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.3);border-top:3px solid #fff;border-radius:50%;animation:spin .8s linear infinite;margin:10px auto}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.login-form .form-group{margin-bottom:1rem}.login-form label{display:block;margin-bottom:.5rem;font-size:.95rem;font-weight:500;color:#374151}.login-form input[type=email],.login-form input[type=password]{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;color:#1f2937;background-color:#f9fafb;box-shadow:inset 0 1px 2px #0000000d;transition:border-color .2s,box-shadow .2s}.login-form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #3b82f640}.login-form .error-message{color:#dc2626;font-size:.875rem;margin-bottom:1rem;text-align:center}.register-link{text-align:center;margin-top:1rem;font-size:.875rem}.register-link a{color:#2563eb;text-decoration:none;transition:color .2s}.register-link a:hover{color:#1d4ed8;text-decoration:underline}.forgot-password-link{text-align:center;margin-top:1rem;font-size:.875rem}.forgot-password-link a{color:#2563eb;text-decoration:none;transition:color .2s}.forgot-password-link a:hover{color:#1d4ed8;text-decoration:underline}.register-link{text-align:center;margin-top:1rem;font-size:.875rem;color:#000}.modal-content{background-color:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 4px 12px #0003;position:relative;width:95%;max-width:600px;max-height:90vh;overflow-y:auto;box-sizing:border-box;animation:fadeInScale .3s ease-out;margin:1rem auto}.review-form .form-group{margin-bottom:1rem}.review-form label{display:block;margin-bottom:.5rem;font-size:.95rem;font-weight:500;color:#374151}.review-form input[type=text],.review-form input[type=email],.review-form input[type=password],.review-form textarea{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;color:#1f2937;background-color:#f9fafb;box-shadow:inset 0 1px 2px #0000000d;transition:border-color .2s,box-shadow .2s}.review-form input:focus,.review-form textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #3b82f640}.review-form textarea{resize:vertical}.review-form .form-group-inline{display:flex;gap:1rem;margin-bottom:1rem}.review-form .form-group-inline>div{flex:1}.star-rating{display:flex;gap:.25rem;margin-top:.5rem;justify-content:center;margin-bottom:1rem}.star-empty{color:#d1d5db;cursor:pointer;transition:color .2s}.star-filled{color:#facc15;cursor:pointer;transition:color .2s}.star-empty:hover,.star-filled:hover{color:#fbbf24}@media (max-width: 400px){.modal-content{padding:1rem}.modal-title{font-size:1.5rem}.review-form .form-group-inline{flex-direction:column;gap:0}}.dropzone{border:2px dashed #d1d5db;border-radius:.375rem;padding:2rem;text-align:center;color:#6b7280;cursor:pointer;transition:border-color .3s,background-color .3s;display:flex;flex-direction:column;align-items:center;gap:.75rem;background-color:#f9fafb}.dropzone.dragging,.dropzone:hover{border-color:#2563eb;background-color:#eff6ff}.dropzone p{margin:0;font-size:1rem}.browse-button{background-color:#e5e7eb;color:#374151;border:1px solid #d1d5db;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.browse-button:hover{background-color:#d1d5db}.file-preview-list{margin-top:1.5rem;width:100%}.file-preview-list h4{margin-bottom:.75rem;font-size:.9rem;color:#374151;font-weight:500}.file-preview-item{display:flex;justify-content:space-between;align-items:center;background-color:#f9fafb;padding:.5rem .75rem;border-radius:.375rem;border:1px solid #e5e7eb;margin-bottom:.5rem;font-size:.9rem}.file-preview-item span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:1rem;color:#1f2937}.remove-file-button{background:none;border:none;color:#ef4444;cursor:pointer;padding:.25rem;display:flex;align-items:center;border-radius:50%;transition:color .2s,background-color .2s}.remove-file-button:hover{color:#dc2626;background-color:#fee2e2}.upload-spinner{border:4px solid rgba(0,0,0,.1);border-left-color:#3498db;border-radius:50%;width:28px;height:28px;animation:spin 1s linear infinite;margin-bottom:10px}.upload-status-container{display:flex;flex-direction:column;align-items:center;margin-bottom:1rem}.upload-status-text{color:#4b5563;font-size:.9rem}.reviews-list-container{display:flex;flex-direction:column;gap:1rem;padding-top:.5rem}.review-card{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.25rem;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column}.review-card-title{font-size:1.15rem;font-weight:600;color:#000;margin:0rem}.review-card-companyname{font-size:1.5rem;font-weight:600;color:#2563eb;margin-bottom:.5rem}.review-label{font-size:.95rem;color:#1f2937;font-weight:600;margin-top:.75rem;margin-bottom:0;display:block}.review-value{font-size:.9rem;color:#4b5563;margin-top:0;margin-bottom:.5rem;line-height:1.4}.review-value.star-rating-display{display:flex;align-items:center;gap:.5rem;margin-top:0}.star-rating-display .star-empty,.star-rating-display .star-filled{flex-shrink:0}.star-rating-display{display:flex;align-items:center;gap:.1rem;margin-left:0rem}.star-empty{color:#d1d5db;fill:none;stroke:#d1d5db;stroke-width:1.5px}.star-filled{color:#facc15;fill:#facc15;stroke:#facc15}.review-info{align-items:center;display:flex;gap:20px;margin-bottom:1rem;color:#000}.review-info-color{color:#2563eb}@media (max-width: 400px){.modal-content{padding:1rem}.modal-title{font-size:1.5rem}.review-label{font-size:.9rem}.review-value{font-size:.85rem}}.change-password-form .form-group{margin-bottom:1rem}.change-password-form label{display:block;margin-bottom:.5rem;font-size:.95rem;font-weight:500;color:#374151}.change-password-form input[type=password]{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;color:#1f2937;background-color:#f9fafb;box-shadow:inset 0 1px 2px #0000000d;transition:border-color .2s,box-shadow .2s}.change-password-form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #3b82f640}.user-info-display{padding:1rem;line-height:1.6}.user-info-display p{margin-bottom:.5rem;color:#374151;font-size:1rem}.user-info-display p strong{color:#1f2937;min-width:120px;display:inline-block}.register-form .form-group{margin-bottom:1rem}.register-form label{display:block;margin-bottom:.5rem;font-size:.95rem;font-weight:500;color:#374151}.register-form input[type=text],.register-form input[type=email],.register-form input[type=tel],.register-form input[type=password]{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;color:#1f2937;background-color:#f9fafb;box-shadow:inset 0 1px 2px #0000000d;transition:border-color .2s,box-shadow .2s}.register-form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #3b82f640}.register-form .form-group-inline{display:flex;gap:1rem;margin-bottom:1rem}.register-form .form-group-inline>div{flex:1}.go-to-login-link{text-align:center;margin-top:1rem;font-size:.875rem}.go-to-login-link a{color:#2563eb;text-decoration:none;transition:color .2s}.go-to-login-link a:hover{color:#1d4ed8;text-decoration:underline}@media (max-width: 400px){.modal-content{padding:1rem}.modal-title{font-size:1.5rem}.register-form .form-group-inline{flex-direction:column;gap:0}}.modal-content{background-color:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 4px 12px #0003;position:relative;width:90%;max-width:400px;animation:fadeInScale .3s ease-out;box-sizing:border-box;max-height:90vh}.contact-info-display{text-align:center;padding:1rem 0}.contact-detail{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.75rem;font-size:1rem;color:#374151}.contact-detail a{color:#2563eb;text-decoration:none}.contact-detail a:hover{text-decoration:underline}.contact-message{margin-top:1.5rem;font-size:.9rem;color:#6b7280}@media (max-width: 600px){.modal-content{margin:.5rem;padding:1.5rem}.modal-title{font-size:1.5rem}}.modal-content{background-color:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 4px 12px #0003;position:relative;width:95%;max-width:500px;max-height:90vh;overflow-y:auto;box-sizing:border-box;animation:fadeInScale .3s ease-out;margin:1rem auto}.forgot-password-form .form-group{margin-bottom:1rem}.forgot-password-form label{display:block;margin-bottom:.5rem;font-size:.95rem;font-weight:500;color:#374151}.forgot-password-form input[type=email]{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;color:#1f2937;background-color:#f9fafb;box-shadow:inset 0 1px 2px #0000000d;transition:border-color .2s,box-shadow .2s}.forgot-password-form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #3b82f640}.submit-button{width:100%;padding:.75rem 1rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;box-shadow:0 2px 4px #0000001a}.submit-button:hover:not(:disabled){background-color:#1d4ed8}.submit-button:disabled{background-color:#9ca3af;cursor:not-allowed}.error-message{color:#dc2626;font-size:.875rem;margin-bottom:1rem;text-align:center}.success-message{color:#059669;font-size:.875rem;margin-bottom:1rem;text-align:center}.go-to-login-link{text-align:center;margin-top:1rem;font-size:.875rem;color:#000}@media (max-width: 400px){.modal-content{padding:1rem}.modal-title{font-size:1.5rem}}.modal-content{background-color:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 4px 12px #0003;position:relative;width:95%;max-width:800px;animation:fadeInScale .3s ease-out;box-sizing:border-box;max-height:90vh}.modal-title{display:flex;align-items:center;gap:.5rem;font-size:1.75rem;font-weight:700;color:#1f2937;margin-bottom:1.5rem;justify-content:center}.latest-jobs-list-container{display:flex;flex-direction:column;gap:1rem;padding-top:.5rem}.job-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;margin-bottom:.75rem;box-shadow:0 1px 2px #0000000d;display:flex;flex-direction:column}.job-card-title{font-size:1.125rem;font-weight:600;color:#2563eb;margin-bottom:.25rem}.job-detail-label{font-size:.9rem;color:#1f2937;font-weight:600;margin:0;margin-top:.5rem;display:block}.job-detail-value{font-size:.85rem;color:#4b5563;margin:0;margin-bottom:.5rem;line-height:1.4}.job-detail-value.star-rating-display{display:flex;align-items:center;gap:.5rem;margin-top:0}.star-rating-display{display:flex;align-items:center;gap:.1rem}.star-empty{fill:none;stroke:#d1d5db;stroke-width:1.5px}.star-filled{fill:#facc15;stroke:#facc15}.results-loading-container,.results-error-container,.results-no-data-container{text-align:center;padding:2rem;font-size:1.125rem;color:#4b5563;margin:1rem auto}.results-spinner{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:30px;height:30px;animation:spin 1s linear infinite;margin:0 auto 15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.results-error{color:#ef4444;font-weight:600}@media (max-width: 600px){.modal-content{padding:1.5rem}.modal-title{font-size:1.5rem}.job-detail-label{font-size:.85rem}.job-detail-value{font-size:.8rem}}.loading-row{display:flex;align-items:center;gap:.5rem;padding:.5rem 0 1rem}.spinner{width:24px;height:24px;border:4px solid rgba(0,0,0,.1);border-left-color:#1976d2;border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:.95rem;color:#4b5563;opacity:.9}@keyframes spin{to{transform:rotate(360deg)}}.results-error{color:#b00020}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;overflow-y:auto;padding:1rem}.modal-content{background-color:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 4px 12px #0003;position:relative;width:95%;max-width:700px;box-sizing:border-box;max-height:90vh;animation:fadeInScale .3s ease-out}.modal-close-button{position:absolute;top:1rem;right:1rem;background:none;border:none;cursor:pointer;color:#6b7280;padding:.5rem;border-radius:.375rem;transition:color .2s}.modal-close-button:hover{color:#374151}.modal-title{display:flex;align-items:center;gap:.5rem;font-size:1.75rem;font-weight:700;color:#1f2937;margin-bottom:1.5rem;justify-content:center;text-align:center}.faq-list{list-style:none;padding:0;margin:0}.faq-item{margin-bottom:.5rem;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.faq-question{display:flex;align-items:center;width:100%;padding:1rem .5rem;background-color:#f9fafb;border:none;text-align:left;font-size:1rem;font-weight:600;color:#2563eb;cursor:pointer;transition:background-color .2s,color .2s;border-radius:.375rem;position:relative}.faq-question:hover{background-color:#e0f2f7;color:#1d4ed8}.faq-question.expanded{background-color:#e0f2f7;color:#1d4ed8;border-bottom-left-radius:0;border-bottom-right-radius:0}.faq-question:after{content:"▼";position:absolute;right:1rem;top:50%;transform:translateY(-50%);transition:transform .2s}.faq-question.expanded:after{content:"▲";transform:translateY(-50%) rotate(180deg)}.faq-answer-container{max-height:0;overflow:hidden;transition:max-height .3s ease-out;background-color:#f0f8ff;border-bottom-left-radius:.375rem;border-bottom-right-radius:.375rem;box-shadow:inset 0 2px 4px #0000000d}.faq-answer-container.expanded{max-height:500px}.faq-answer-text{padding:1rem 1rem 1rem 1.5rem;font-size:.95rem;color:#4b5563;line-height:1.5;margin:0}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width: 600px){.modal-content{padding:1.5rem}.modal-title{font-size:1.5rem}.faq-question{font-size:.9rem;padding:.75rem .5rem}.faq-answer-text{font-size:.85rem;padding:.75rem .75rem .75rem 1rem}}.faq-answer-text{line-height:1.5}.faq-answer-text .faq-paragraph{margin:0 0 .75rem}
