*{margin:0;padding:0;box-sizing:border-box}body,html{width:100%;max-width:100%}:root{--primary-color:#7be1e8;--primary-hover:#5dd9e1;--secondary-color:#64748b;--bg-color:#f8fafc;--card-bg:#ffffff;--text-primary:#1e293b;--text-secondary:#64748b;--border-color:#e2e8f0;--success-color:#10b981}body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Hiragino Kaku Gothic ProN','Hiragino Sans',Meiryo,sans-serif;background-color:var(--bg-color);color:var(--text-primary);line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:0 20px;overflow-x:clip}.header{background-color:var(--card-bg);box-shadow:0 2px 4px rgba(0,0,0,.1);padding:20px 0}@media (max-width:768px){.header{padding:10px 0;margin-bottom:0}}.logo a{display:inline-block;line-height:0}.logo img{height:40px;width:auto}@media (max-width:768px){.logo img{height:32px}}.header-inner{display:flex;justify-content:space-between;align-items:center}.hamburger-btn{display:flex;flex-direction:column;justify-content:center;align-items:center;width:40px;height:40px;padding:8px;background:0 0;border:none;cursor:pointer;gap:5px;border-radius:4px;transition:background-color .2s}.hamburger-btn:hover{background-color:rgba(0,0,0,.05)}.hamburger-line{display:block;width:22px;height:2px;background-color:#17858f;border-radius:1px;transition:transform .3s,opacity .3s}.hamburger-btn.active .hamburger-line:first-child{transform:translateY(7px) rotate(45deg)}.hamburger-btn.active .hamburger-line:nth-child(2){opacity:0}.hamburger-btn.active .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.side-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;visibility:hidden;pointer-events:none}.side-menu.active{visibility:visible;pointer-events:auto}.side-menu-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-color:rgba(0,0,0,.5);opacity:0;transition:opacity .3s}.side-menu.active .side-menu-overlay{opacity:1}.side-menu-content{position:absolute;top:0;right:0;bottom:0;width:280px;max-width:85vw;background-color:#fff;transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;box-shadow:-4px 0 20px rgba(0,0,0,.15)}.side-menu.active .side-menu-content{transform:translateX(0)}.side-menu-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;background-color:#17858f;color:#fff}.side-menu-title{font-size:16px;font-weight:600}.side-menu-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:0 0;border:none;font-size:28px;color:#fff;cursor:pointer;border-radius:4px;transition:background-color .2s;line-height:1}.side-menu-close:hover{background-color:rgba(255,255,255,.2)}.side-menu-body{flex:1;overflow-y:auto;padding:0}.side-menu-section{padding:0}.side-menu-section-title{font-size:12px;font-weight:400;color:#374151;padding:12px 20px;background-color:#e0f7f9;margin:0}.side-menu-links{padding:12px 16px}.side-menu-link{display:flex;align-items:center;gap:12px;padding:12px 8px;color:#374151;text-decoration:none;font-size:14px;border-bottom:1px solid #e5e7eb;transition:background-color .2s}.side-menu-link:last-child{border-bottom:none}.side-menu-link:hover{background-color:#f3f4f6}.side-menu-link svg{color:#17858f;flex-shrink:0}.side-menu-link span{color:#374151}.hero-slider-section{background:0 0;padding:20px 0}@media (max-width:768px){.hero-slider-section{padding:0}.hero-slider-section .container{padding:0}}.hero-slider{position:relative;max-width:900px;margin:0 auto;border-radius:12px;overflow:visible;box-shadow:0 8px 24px rgba(0,0,0,.15)}@media (max-width:768px){.hero-slider{border-radius:0;box-shadow:none}}.slider-container{position:relative;width:100%;aspect-ratio:3/2;touch-action:pan-x pan-y;border-radius:12px;overflow:hidden}.slide{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;transition:opacity .5s ease-in-out;pointer-events:none}.slide.active{opacity:1;pointer-events:auto}.slide a{display:block;width:100%;height:100%}.slide img{width:100%!important;height:100%!important;object-fit:cover;display:block}.slider-nav{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:10px;padding:0 20px}.slider-btn{position:relative;top:auto;left:auto;right:auto;transform:none;background-color:rgba(23,133,143,.8);color:#fff;border:none;width:28px;height:28px;border-radius:50%;font-size:16px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 1px 4px rgba(0,0,0,.15);flex-shrink:0}.slider-btn:hover{background-color:#17858f;transform:scale(1.1)}.slider-btn.prev{left:auto}.slider-btn.next{right:auto}.slider-dots{position:relative;bottom:auto;left:auto;transform:none;display:flex;gap:6px;z-index:10}.dot{width:8px;height:8px;border-radius:50%;background-color:rgba(23,133,143,.3);cursor:pointer;transition:all .3s ease}.dot:hover{background-color:rgba(23,133,143,.6)}.dot.active{background-color:#17858f;width:20px;border-radius:4px}.search-section{background:linear-gradient(135deg,#7be1e8 0,#5dd9e1 100%);padding:40px 0}@media (max-width:768px){.search-section{padding:2px 0}}.search-box{background-color:var(--card-bg);border-radius:16px;padding:32px 40px;box-shadow:0 10px 30px rgba(0,0,0,.15);max-width:900px;margin:0 auto 32px auto}@media (max-width:768px){.search-box{margin:0 auto 20px auto}}.search-box-title{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:20px;text-align:center}.search-form{display:flex;flex-direction:column;gap:20px}@media (max-width:768px){.search-form{gap:0}}.search-form .search-buttons{margin-top:4px;gap:12px}@media (max-width:768px){.search-form .search-buttons{margin-top:0}}.search-field{display:flex;flex-direction:column;gap:12px}.search-field label{font-weight:600;color:var(--text-primary);font-size:16px}.search-field-label{flex-shrink:0}.search-field-input{flex:1;min-width:0}.search-field-input-group{display:flex;flex-direction:column;gap:12px;flex:1}.search-select{padding:14px 16px;border:2px solid var(--border-color);border-radius:8px;font-size:16px;background-color:#fff;color:var(--text-primary);transition:all .3s ease;cursor:pointer}.search-select:focus{outline:0;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(123,225,232,.1)}.search-select:hover{border-color:var(--primary-color)}.modal-open-btn{width:100%;padding:14px 16px;background-color:#fff;border:2px solid var(--border-color);border-radius:8px;font-size:16px;color:var(--text-primary);cursor:pointer;transition:all .3s ease;text-align:left}.modal-open-btn:hover{border-color:var(--primary-color);background-color:var(--bg-color)}.selected-features{display:none}.feature-tag{display:none}.remove-btn{display:none}.search-buttons{display:grid;grid-template-columns:auto 1fr;gap:12px;margin-top:0;align-items:stretch}.btn-wrapper{display:flex;align-items:stretch}.btn-wrapper-grow{flex:1}.clear-button,.search-button{border:2px solid;padding:0 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-sizing:border-box;height:52px;width:100%}.search-button{background-color:#e53935;color:#fff;border-color:#e53935;font-size:18px}.search-button:hover{background-color:#c62828;border-color:#c62828}.clear-button{background-color:var(--bg-color);color:var(--text-primary);border-color:var(--border-color);font-size:14px;white-space:nowrap}.clear-button:hover{background-color:var(--border-color);border-color:var(--text-secondary)}.main-accordion-container{max-width:800px;margin:0 auto}.main-accordion-item{border:3px solid var(--primary-color);border-radius:12px;overflow:hidden;background-color:#fff;box-shadow:0 4px 6px rgba(0,0,0,.1)}.main-accordion-header{padding:20px 24px;background-color:var(--primary-color);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:18px;color:#fff;transition:all .3s ease;border:none;width:100%;text-align:left}.main-accordion-header:hover{background-color:var(--primary-hover)}.main-accordion-icon{transition:transform .3s ease;font-size:24px;color:#fff}.main-accordion-header.active .main-accordion-icon{transform:rotate(180deg)}.main-accordion-content{max-height:0;overflow:hidden;transition:max-height .4s ease}.main-accordion-content.active{max-height:5000px}.main-accordion-content .area-accordion-container,.main-accordion-content .features-accordion-container{padding:20px}.popular-features{max-width:1000px;margin:0 auto}@media (max-width:768px){.popular-features{background-color:#fff;padding:16px;border-radius:12px;margin-bottom:16px}}.popular-features .section-title{color:#fff;font-size:16px;margin-bottom:10px;text-align:center}@media (max-width:768px){.popular-features .section-title{color:var(--text-primary)}}.popular-features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-width:1000px;margin:0 auto}.popular-feature-btn{padding:8px 10px;background-color:var(--bg-color);border:2px solid var(--border-color);border-radius:8px;font-size:clamp(10px, 2.8vw, 14px);font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s ease;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:36px;display:flex;align-items:center;justify-content:center;min-width:0;box-shadow:0 2px 0 0 var(--border-color)}.popular-features .popular-feature-btn{background-color:#f5f5f5;border:2px solid rgba(0,0,0,.1);color:var(--text-primary);box-shadow:0 2px 8px rgba(0,0,0,.1)}.popular-features .popular-feature-btn:hover{background-color:#fff;border-color:rgba(0,0,0,.15);box-shadow:0 4px 12px rgba(0,0,0,.15);transform:translateY(1px)}.popular-feature-btn:hover{border-color:var(--primary-color);background-color:rgba(123,225,232,.05);transform:translateY(1px);box-shadow:0 1px 0 0 var(--border-color)}.popular-feature-btn.active{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff;box-shadow:0 2px 0 0 var(--primary-hover)}.popular-feature-btn.active:hover{background-color:var(--primary-hover);border-color:var(--primary-hover);transform:translateY(1px);box-shadow:0 1px 0 0 var(--primary-hover)}.search-conditions-section{background-color:#fff;padding:60px 0}.search-conditions-section .section-title{color:var(--text-primary);font-size:28px;margin-bottom:32px;text-align:center;font-weight:700}.search-conditions-container{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.area-accordion-container{max-width:800px;margin:0 auto}.area-accordion-item{margin-bottom:12px;border:2px solid var(--border-color);border-radius:8px;overflow:hidden;background-color:#fff}.area-accordion-header{padding:16px 20px;background-color:var(--bg-color);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:16px;color:var(--text-primary);transition:all .2s ease;border:none;width:100%;text-align:left}.area-accordion-header:hover{background-color:rgba(123,225,232,.05)}.area-accordion-header.active{background-color:rgba(123,225,232,.1);border-bottom:2px solid var(--border-color)}.area-accordion-icon{transition:transform .3s ease;font-size:20px;color:var(--text-secondary)}.area-accordion-header.active .area-accordion-icon{transform:rotate(180deg)}.area-accordion-content{max-height:0;overflow:hidden;transition:max-height .3s ease}.area-accordion-content.active{max-height:1000px}.area-accordion-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:20px}.area-accordion-btn{padding:12px 16px;background-color:#fff;border:2px solid var(--border-color);border-radius:8px;font-size:14px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s ease;text-align:center;min-height:48px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 0 0 var(--border-color)}.area-accordion-btn:hover{border-color:var(--primary-color);background-color:rgba(123,225,232,.05);transform:translateY(1px);box-shadow:0 1px 0 0 var(--border-color)}.recommended-jobs-section{padding:10px 0;background:linear-gradient(135deg,#fff5e6 0,#ffe6cc 100%);position:relative}.recommended-jobs-section::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,gold,#ffed4e,gold)}.recommended-jobs-section .section-title{color:#ff6b00;font-size:28px;font-weight:700;text-align:center;margin-bottom:15px;position:relative;display:inline-block;width:100%}.recommended-jobs-section .section-title::before{content:none}.recommended-jobs-section .section-title::after{content:none}.jobs-slider-wrapper{position:relative;max-width:1200px;margin:0 auto;padding:0 60px}.jobs-slider{overflow:hidden;border-radius:12px;touch-action:pan-x pan-y}.jobs-slider-track{display:flex;transition:transform .4s ease;gap:24px;touch-action:pan-x pan-y}.job-card{min-width:calc((100% - 48px)/ 3);background-color:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:0 4px 12px rgba(255,107,0,.2);transition:all .3s ease;display:flex;flex-direction:column;border:2px solid gold;position:relative}.job-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,gold,#ffed4e,gold)}.job-card:hover{box-shadow:0 8px 24px rgba(255,107,0,.3);transform:translateY(-4px);border-color:#ff6b00}.job-image{position:relative;width:100%;overflow:hidden;background-color:#f0f0f0;aspect-ratio:4/3}.job-image img{width:100%;height:100%;object-fit:cover;display:block}.job-badge{position:absolute;top:12px;left:12px;background-color:var(--primary-color);color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600}.job-content{padding:20px;display:flex;flex-direction:column;flex-grow:1}.job-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:8px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.job-company{font-size:14px;color:var(--text-secondary);margin-bottom:12px}.job-details{display:flex;flex-direction:row;flex-wrap:wrap;gap:4px 12px;margin-bottom:8px}.job-location,.job-salary{font-size:14px;color:var(--text-primary)}.job-location::before{content:'📍 '}.job-salary{font-weight:600;color:#17858f}.job-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px;max-height:52px;overflow:hidden}.job-tag{padding:2px 6px;background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:4px;font-size:10px;color:var(--text-secondary)}.job-link-btn{display:block;width:100%;padding:12px;background:linear-gradient(135deg,#ff6b00 0,#ff8c00 100%);color:#fff;text-align:center;text-decoration:none;border-radius:8px;font-weight:600;font-size:14px;transition:all .2s ease;margin-top:auto;box-shadow:0 3px 0 0 #d45a00}.job-link-btn:hover{background:linear-gradient(135deg,#ff8c00 0,orange 100%);transform:translateY(1px);box-shadow:0 2px 0 0 #d45a00}.jobs-slider-btn{position:absolute;top:50%;transform:translateY(-50%);background-color:rgba(255,255,255,.95);color:var(--text-primary);border:2px solid var(--border-color);width:48px;height:48px;border-radius:50%;font-size:32px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 2px 8px rgba(0,0,0,.15)}.jobs-slider-btn:hover{background-color:#fff;border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-50%) scale(1.1)}.jobs-slider-btn.jobs-prev{left:0}.jobs-slider-btn.jobs-next{right:0}.features-accordion-container{max-width:800px;margin:0 auto}.features-accordion-item{margin-bottom:12px;border:2px solid var(--border-color);border-radius:8px;overflow:hidden;background-color:#fff}.features-accordion-header{padding:16px 20px;background-color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:16px;color:var(--text-primary);transition:all .2s ease;border:none;width:100%;text-align:left}.features-accordion-header:hover{background-color:rgba(123,225,232,.05)}.features-accordion-header.active{background-color:rgba(123,225,232,.1);border-bottom:2px solid var(--border-color)}.features-accordion-icon{transition:transform .3s ease;font-size:20px;color:var(--text-secondary)}.features-accordion-header.active .features-accordion-icon{transform:rotate(180deg)}.features-accordion-content{max-height:0;overflow:hidden;transition:max-height .3s ease}.features-accordion-content.active{max-height:2000px}.features-accordion-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:20px;background-color:var(--bg-color)}.features-accordion-btn{padding:16px 20px;background-color:#fff;border:2px solid var(--border-color);border-radius:8px;font-size:15px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s ease;text-align:center;min-height:56px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 0 0 var(--border-color)}.features-accordion-btn:hover{border-color:var(--primary-color);background-color:rgba(123,225,232,.05);transform:translateY(1px);box-shadow:0 1px 0 0 var(--border-color)}.faq-section{padding:60px 0;background-color:#fff}.section-title{font-size:32px;font-weight:700;margin-bottom:40px;text-align:center}.faq-category{max-width:800px;margin:0 auto 32px}.faq-category-title{font-size:20px;font-weight:700;color:var(--primary-color);margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--primary-color)}.faq-item{background-color:#fff;border-radius:8px;margin-bottom:12px;border:1px solid var(--border-color);overflow:hidden}.faq-question{padding:16px 20px;font-size:16px;font-weight:600;color:var(--text-primary);cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;transition:background-color .2s ease;position:relative}.faq-question::-webkit-details-marker{display:none}.faq-question::after{content:'+';font-size:24px;font-weight:700;color:var(--primary-color);transition:transform .3s ease}.faq-item[open] .faq-question::after{transform:rotate(45deg)}.faq-question:hover{background-color:rgba(123,225,232,.05)}.faq-answer{padding:0 20px 20px;color:var(--text-primary);line-height:1.8;font-size:14px}.faq-answer p{margin-bottom:12px}.faq-answer p:last-child{margin-bottom:0}.footer{background-color:var(--text-primary);color:#fff;padding:40px 0;text-align:center;font-size:14px}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);overflow:hidden}.modal.active{display:flex;align-items:center;justify-content:center;padding:20px}@media (max-width:768px){.modal.active{align-items:flex-end;padding:0}}.modal-content{background-color:#fff;border-radius:16px;width:100%;max-width:900px;height:90vh;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px rgba(0,0,0,.2);overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:2px solid var(--border-color)}.modal-header h3{margin:0;font-size:24px;color:var(--text-primary)}.modal-close{background:0 0;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.modal-close:hover{color:var(--text-primary)}.modal-body{flex:1;overflow-y:auto;padding:24px;padding-bottom:180px;overscroll-behavior:contain}.modal-selected-summary{padding:16px 24px;background-color:var(--bg-color);border-top:2px solid var(--border-color)}.modal-selected-summary h4{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.modal-selected-list{font-size:14px;color:var(--text-secondary);line-height:1.8}.modal-selected-list.empty{color:var(--text-secondary);font-style:italic}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:2px solid var(--border-color)}.btn-cancel,.btn-confirm{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel{background-color:var(--bg-color);color:var(--text-primary)}.btn-cancel:hover{background-color:var(--border-color)}.btn-confirm{background-color:#b0eef3;color:#fff;transition:all .3s ease}.btn-confirm:hover{background-color:#9de8ee}.btn-confirm.has-selection{background-color:#17858f;box-shadow:0 2px 8px rgba(23,133,143,.4)}.btn-confirm.has-selection:hover{background-color:#126a72}.accordion-container{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.accordion-item{border:2px solid var(--border-color);border-radius:8px;overflow:hidden}.accordion-header{padding:16px 20px;background-color:var(--bg-color);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:16px;color:var(--text-primary);transition:background-color .2s ease}.accordion-header:hover{background-color:rgba(123,225,232,.05)}.accordion-header.active{background-color:rgba(123,225,232,.1);border-bottom:2px solid var(--border-color)}.accordion-icon{transition:transform .3s ease;font-size:20px;color:var(--text-secondary)}.accordion-header.active .accordion-icon{transform:rotate(180deg)}.accordion-content{max-height:0;overflow:hidden;transition:max-height .3s ease}.accordion-content.active{max-height:1000px}.accordion-body{padding:20px;background-color:#fff}.checkbox-group{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 16px}.modal-popular-section{background-color:rgba(123,225,232,.1);border:2px solid var(--primary-color);border-radius:12px;padding:20px;margin-bottom:16px;grid-column:1/-1}.modal-popular-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.modal-popular-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 16px}.checkbox-label{display:flex;align-items:center;gap:6px;cursor:pointer;padding:6px;border-radius:6px;transition:background-color .2s ease;font-weight:400}.checkbox-label:hover{background-color:rgba(123,225,232,.05)}.checkbox-label input[type=checkbox]{width:16px;height:16px;min-width:16px;cursor:pointer;accent-color:var(--primary-color)}.checkbox-label span{font-size:13px;color:var(--text-primary);user-select:none;line-height:1.3}@media (max-width:1024px) and (min-width:769px){.container{padding:0 24px}.slider-container{aspect-ratio:3/2}.search-box{padding:32px}.popular-features-grid{grid-template-columns:repeat(4,1fr);gap:12px}.features-grid{grid-template-columns:repeat(2,1fr)}.jobs-slider-wrapper{padding:0 60px}.job-card{min-width:calc((100% - 24px)/ 2)}}@media (max-width:768px){.slider-container{height:auto;aspect-ratio:3/2;border-radius:0}.slide{position:static;display:none;width:100%;height:auto;opacity:1}.slide.active{display:block}.slide a{height:auto}.slide img{height:100%!important;width:100%!important;object-fit:cover}.slider-nav{margin-top:6px;gap:6px}.slider-btn{width:20px;height:20px;font-size:12px;box-shadow:none}.slider-dots{gap:3px}.dot{width:5px;height:5px}.dot.active{width:12px;border-radius:3px}.area-accordion-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:16px}.area-accordion-btn{font-size:13px;padding:10px 12px;min-height:44px}.features-accordion-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:16px}.features-accordion-btn{font-size:13px;padding:12px 16px;min-height:52px}.modal-content{max-width:100%;height:80vh;max-height:80vh;border-radius:16px 16px 0 0;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}.modal-body{padding:16px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.accordion-container{grid-template-columns:1fr}.checkbox-group{grid-template-columns:1fr}.accordion-header{padding:12px 16px;font-size:14px}}@media (max-width:480px){.container{padding:0 16px}.checkbox-group{grid-template-columns:1fr}.checkbox-container{max-height:250px}.search-box{padding:16px;margin:0 auto 16px auto}.search-field{flex-direction:row;align-items:flex-start;gap:12px}.search-field label{width:80px;flex-shrink:0;font-size:13px;margin:0;padding-top:14px;line-height:1.4;word-break:keep-all;overflow-wrap:break-word}.search-field-input-group,.search-select{flex:1;min-width:0}.modal-open-btn{width:100%}.popular-features-grid{grid-template-columns:repeat(4,1fr);gap:5px}.popular-feature-btn{font-size:11px;padding:8px 6px;white-space:nowrap;min-height:36px;line-height:1.2;letter-spacing:-1px}.popular-feature-btn span{display:inline-block;transform:scale(.8);transform-origin:center}.modal-header{padding:16px}.modal-header h3{font-size:20px}.jobs-slider-wrapper{padding:0;margin:0 -20px;width:calc(100% + 40px)}.jobs-slider{padding:0 20px}.job-card{min-width:100%}.jobs-slider-btn{width:40px;height:40px;font-size:24px}.jobs-slider-btn.jobs-prev{left:10px}.jobs-slider-btn.jobs-next{right:10px}.modal-selected-summary{position:absolute;bottom:60px;left:0;right:0;background-color:var(--bg-color);border-top:2px solid var(--border-color);padding:12px 16px;z-index:10;box-shadow:0 -4px 12px rgba(0,0,0,.1);display:none}.modal-selected-summary.has-selection{display:block}.modal-selected-summary h4{font-size:13px;margin-bottom:6px}.modal-selected-list{font-size:13px;max-height:50px;overflow-y:auto;margin-bottom:12px}.modal-footer{padding:12px 16px 12px 16px;flex-direction:row;position:absolute;bottom:0;left:0;right:0;background-color:var(--bg-color);z-index:10;gap:8px;border-top:none}.btn-cancel{width:30%;padding:12px 16px}.btn-confirm{width:70%;padding:12px 16px}.modal-body{padding:16px;padding-bottom:80px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;transition:padding-bottom .2s ease}.modal-content:has(.modal-selected-summary.has-selection) .modal-body{padding-bottom:180px}.checkbox-group{grid-template-columns:repeat(2,1fr);gap:6px 12px}.modal-popular-section{padding:16px;margin-bottom:12px}.modal-popular-title{font-size:14px;margin-bottom:12px}.modal-popular-grid{grid-template-columns:repeat(2,1fr);gap:6px 12px}.checkbox-group .checkbox-label,.modal-popular-grid .checkbox-label{padding:6px;font-size:13px}.checkbox-group .checkbox-label span,.modal-popular-grid .checkbox-label span{font-size:13px}.accordion-container{grid-template-columns:1fr}}.badge-jobs-section{padding:40px 0;margin:20px 0}.badge-jobs-section.badge-ichioshi{background-color:#fff0f0}.badge-jobs-section.badge-pickup{background-color:#fff5d9}.badge-jobs-section.badge-osusume{background-color:#ebf7ff}.badge-jobs-list{display:flex;flex-direction:column;gap:20px;margin-top:20px}.badge-job-card{display:flex;flex-direction:row;background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.1);transition:transform .3s ease,box-shadow .3s ease;text-decoration:none;color:inherit;height:200px}.badge-ichioshi .badge-job-card{border:2px solid #fcc}.badge-pickup .badge-job-card{border:2px solid #ffe599}.badge-osusume .badge-job-card{border:2px solid #b3d9ff}.badge-job-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px rgba(0,0,0,.15)}.badge-job-image{width:300px;height:200px;flex-shrink:0}.badge-job-image img{width:100%;height:100%;object-fit:cover}.badge-job-info{flex:1;padding:20px;display:flex;flex-direction:column;gap:10px;justify-content:center}.badge-job-detail{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.6}.badge-job-detail strong{color:var(--text-primary);font-weight:600}.badge-job-salary{font-size:18px;font-weight:700;color:#e63946;margin:0;line-height:1.4;padding:4px 0}.badge-job-title{font-size:13px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.badge-job-location-salary{display:flex;gap:16px;align-items:center;margin:0;font-size:13px;flex-wrap:wrap}.badge-location{color:var(--text-secondary)}.badge-salary{font-weight:700;color:#e63946}@media (max-width:768px){.badge-job-card{flex-direction:row;height:135px}.badge-job-image{width:180px;height:135px}.badge-job-info{padding:12px;gap:6px}.badge-job-detail{font-size:12px;line-height:1.4}.badge-job-salary{font-size:16px}.badge-job-title{font-size:12px}.badge-job-location-salary{font-size:11px;gap:12px}}@media (max-width:480px){.badge-jobs-section{padding:30px 0}.badge-job-card{flex-direction:row;height:105px}.badge-job-image{width:140px;height:105px;flex-shrink:0}.badge-job-info{padding:8px;gap:2px}.badge-job-detail{font-size:12px;line-height:1.3}.badge-job-detail strong{display:inline-block;min-width:40px}.badge-job-salary{font-size:13px}.badge-job-title{font-size:12px}.badge-job-location-salary{font-size:11px;gap:8px}}.floating-search-btn{display:none;position:fixed;bottom:24px;right:24px;width:56px;height:56px;background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%);color:#fff;border:none;border-radius:50%;box-shadow:0 4px 12px rgba(123,225,232,.4),0 2px 4px rgba(0,0,0,.1);cursor:pointer;z-index:999;transition:all .3s ease;opacity:0;transform:translateY(100px)}.floating-search-btn.visible{opacity:1;transform:translateY(0)}.floating-search-btn:hover{background:linear-gradient(135deg,var(--primary-hover) 0,var(--primary-color) 100%);box-shadow:0 6px 16px rgba(123,225,232,.5),0 3px 6px rgba(0,0,0,.15);transform:translateY(-2px)}.floating-search-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(123,225,232,.3)}.floating-search-btn svg{width:24px;height:24px}@media (max-width:768px){.floating-search-btn{display:block}}

/* パンくずリスト */
.breadcrumb{padding:8px 0;background-color:var(--card-bg)}
.breadcrumb-list{display:flex;gap:8px;list-style:none;flex-wrap:wrap;font-size:13px;align-items:center}
.breadcrumb-list li{display:flex;align-items:center}
.breadcrumb-list li::after{content:'>';margin-left:8px;color:var(--text-secondary);font-size:11px}
.breadcrumb-list li:last-child::after{content:''}
.breadcrumb-list a{color:var(--text-secondary);text-decoration:none}
.breadcrumb-list a:hover{text-decoration:underline;color:var(--text-primary)}
.breadcrumb-list li:last-child{color:var(--text-primary)}
@media (max-width:768px){.breadcrumb{display:none}}
@media (max-width:480px){.breadcrumb-list{font-size:12px}}

/* 検索ページ導線 */
.search-page-link-wrapper{text-align:center;margin-top:24px}
.search-page-link-btn{display:inline-block;padding:14px 32px;background:#17858f;color:#fff;border-radius:8px;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s ease;box-shadow:0 2px 8px rgba(23,133,143,.3)}
.search-page-link-btn:hover{background:#126a72;transform:translateY(-2px);box-shadow:0 4px 12px rgba(23,133,143,.4)}
@media (max-width:480px){.search-page-link-btn{font-size:14px;padding:12px 24px}}

/* ページ下部CTA */
.bottom-cta-section{background:linear-gradient(135deg,#17858f 0%,#1a9ca7 100%);padding:48px 0;text-align:center}
.bottom-cta-title{color:#fff;font-size:22px;font-weight:700;margin-bottom:12px}
.bottom-cta-text{color:rgba(255,255,255,.9);font-size:15px;margin-bottom:24px;line-height:1.7}
.bottom-cta-btn{display:inline-block;background:#e53935;color:#fff;padding:16px 48px;border-radius:8px;font-size:18px;font-weight:700;text-decoration:none;box-shadow:0 4px 12px rgba(0,0,0,.2);transition:all .2s ease}
.bottom-cta-btn:hover{background:#c62828;transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.3)}
@media (max-width:480px){.bottom-cta-section{padding:36px 0}.bottom-cta-title{font-size:20px}.bottom-cta-text{font-size:14px}.bottom-cta-btn{padding:14px 36px;font-size:16px}}

/* 検索セクション リード文 */
.search-lead-text{text-align:center;font-size:14px;color:var(--text-secondary);margin-bottom:20px;line-height:1.7}
.search-lead-text strong{color:var(--text-primary);font-size:18px}
@media (max-width:480px){.search-lead-text{font-size:13px;margin-bottom:16px}.search-lead-text strong{font-size:16px}}

/* フッター */
.footer-brand{margin-bottom:20px}
.footer-brand img{margin-bottom:8px}
.footer-description{color:rgba(255,255,255,.8);font-size:14px;margin-bottom:4px}
.footer-company{color:rgba(255,255,255,.6);font-size:13px}
.footer-links{display:flex;justify-content:center;gap:24px;margin-bottom:16px;flex-wrap:wrap}
.footer-links a{color:#999;text-decoration:none;font-size:14px;transition:color .2s}
.footer-links a:hover{color:#fff;text-decoration:underline}
@media (max-width:480px){.footer-links{gap:12px}.footer-links a{font-size:12px}}

/* CLS対策: スライダー */
.slider-container{background:#f5f5f5}
@media (min-width:768px){.slider-container{min-height:280px}}

/* スライダーナビ非表示（1枚運用時） */
.slider-nav{display:none}

/* 新着求人セクション */
.new-jobs-section{padding:32px 0;background:#fff}
.new-jobs-list{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow-y:auto;padding-right:8px}
.new-jobs-list::-webkit-scrollbar{width:6px}
.new-jobs-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}
.new-jobs-list::-webkit-scrollbar-thumb{background:#17858f;border-radius:3px}
.new-jobs-list::-webkit-scrollbar-thumb:hover{background:#126a72}
.new-job-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8f9fa;border-radius:8px;text-decoration:none;color:#333;transition:background .2s;flex-shrink:0}
.new-job-item:hover{background:#e9f7f8}
.new-job-location{flex-shrink:0;padding:4px 8px;background:#17858f;color:#fff;font-size:12px;border-radius:4px;min-width:60px;text-align:center}
.new-job-title{flex:1;font-size:12px;font-weight:500}
.new-job-salary{flex-shrink:0;font-size:13px;color:#e74c3c;font-weight:600}
@media (max-width:768px){.new-jobs-list{max-height:320px}.new-job-item{flex-wrap:wrap;gap:8px}.new-job-title{flex-basis:100%;order:-1;line-height:1.4}.new-job-location{font-size:12px;min-width:auto}.new-job-salary{font-size:12px}}

/* 検索ボタン改行防止 */
.search-button{white-space:nowrap;flex-wrap:nowrap;overflow:hidden}
@media (max-width:480px){.search-button{font-size:14px;padding:0 12px}}
@media (max-width:360px){.search-button{font-size:13px;padding:0 10px}}

/* 機能1: ボタン内求人数表示（検索ボタン） */
.job-count-inline{margin-left:4px;font-size:14px;font-weight:700;flex-shrink:0}
.job-count-inline:empty{display:none}
@media (max-width:480px){.job-count-inline{font-size:12px;margin-left:2px}}
@media (max-width:360px){.job-count-inline{font-size:11px;margin-left:1px}}

/* モーダルガイドテキスト */
.modal-guide-text{text-align:center;padding:10px 16px;background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border:1px solid #c8e6c9;border-radius:8px;color:#2e7d32;font-size:14px;font-weight:600;margin-bottom:16px}
@media (max-width:480px){.modal-guide-text{font-size:12px;padding:8px 12px;margin-bottom:12px}}

/* 機能3: こだわり条件チェックボックス無効化 */
.checkbox-label.disabled{opacity:0.4;pointer-events:none}
.checkbox-label.disabled input[type=checkbox]{cursor:not-allowed}
.feature-limit-message{text-align:center;padding:8px 16px;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;font-size:13px;font-weight:600;margin:0 24px 12px}
@media (max-width:480px){.feature-limit-message{margin:0 16px 8px;font-size:12px;padding:6px 12px}}

/* モーダル確定ボタン内求人数表示 */
.modal-job-count-inline{margin-left:6px;font-size:13px;font-weight:700}
.modal-job-count-inline:empty{display:none}
@media (max-width:480px){.modal-job-count-inline{font-size:11px;margin-left:4px}}