﻿*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;scroll-padding-top:72px}body{font-family:"Noto Sans JP",sans-serif;font-size:1rem;line-height:1.8;color:#333;background-color:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none;transition:opacity .3s ease}a:hover{opacity:.75}ul,ol{list-style:none}button{cursor:pointer;border:none;background:none;font-family:inherit}.section{padding:80px 0}@media(max-width: 767px){.section{padding:56px 0}}.section__inner{max-width:1200px;margin:0 auto;padding:0 40px}@media(max-width: 767px){.section__inner{padding:0 20px}}.section-heading{font-size:1.75rem;font-weight:700;color:#333;margin-bottom:2rem;line-height:1.4}.section-heading--accent{position:relative;padding-left:1rem}.section-heading--accent::before{content:"";position:absolute;left:0;top:.1em;bottom:.1em;width:4px;background-color:#d97229;border-radius:2px}.section-heading--center{text-align:center}.section-heading--white{color:#fff}@media(max-width: 767px){.section-heading{font-size:1.375rem;margin-bottom:1.5rem}}.btn{display:inline-block;padding:.8125rem 2.5rem;font-size:.9375rem;font-weight:700;border-radius:4px;transition:background-color .3s ease,color .3s ease,border-color .3s ease,opacity .3s ease;cursor:pointer;letter-spacing:.04em}.btn--primary{background-color:#17a09e;color:#fff;border:2px solid #17a09e}.btn--primary:hover{background-color:#0f7a78;border-color:#0f7a78;opacity:1}.btn--outline{background-color:rgba(0,0,0,0);color:#fff;border:2px solid #fff}.btn--outline:hover{background-color:#fff;color:#17a09e;opacity:1}.fade-in{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.fade-in.is-visible{opacity:1;transform:translateY(0)}.back-to-top{position:fixed;right:24px;bottom:24px;width:48px;height:48px;background-color:#17a09e;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease,background-color .3s ease;z-index:100}.back-to-top.is-visible{opacity:1;visibility:visible}.back-to-top:hover{background-color:#0f7a78;opacity:1}.header{position:fixed;top:0;left:0;right:0;height:72px;background-color:#fff;z-index:1000;box-shadow:0 2px 12px rgba(0,0,0,.08);transition:background-color .3s ease}@media(max-width: 767px){.header{height:60px}}.header__inner{max-width:1200px;margin:0 auto;padding:0 40px}@media(max-width: 767px){.header__inner{padding:0 20px}}.header__inner{display:flex;align-items:center;justify-content:space-between;height:100%}.header__logo{flex-shrink:0}.header__logo img{height:38px;width:auto}@media(max-width: 767px){.header__logo img{height:30px}}@media(max-width: 767px){.header__nav{position:fixed;top:0;right:-100%;width:280px;height:100vh;background-color:#fff;padding:90px 40px 40px;transition:right .3s ease;box-shadow:-4px 0 20px rgba(0,0,0,.12);z-index:1001}.header__nav.is-open{right:0}}.header__nav-list{display:flex;align-items:center;gap:2.25rem}@media(max-width: 767px){.header__nav-list{flex-direction:column;align-items:flex-start;gap:2rem}}.header__nav-link{font-size:.9375rem;font-weight:500;color:#333;position:relative}.header__nav-link::after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background-color:#17a09e;transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.header__nav-link:hover{color:#17a09e;opacity:1}.header__nav-link:hover::after{transform:scaleX(1)}@media(max-width: 767px){.header__nav-link{font-size:1.0625rem}}.header__menu-btn{display:none;flex-direction:column;justify-content:center;gap:6px;width:36px;height:36px;padding:4px 2px;z-index:1002;flex-shrink:0}@media(max-width: 767px){.header__menu-btn{display:flex}}.header__menu-btn span{display:block;height:2px;width:100%;background-color:#333;border-radius:2px;transition:transform .3s ease,opacity .3s ease,width .3s ease}.header__menu-btn span:nth-child(2){width:75%}.header__menu-btn.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg);width:100%}.header__menu-btn.is-open span:nth-child(2){opacity:0;width:100%}.header__menu-btn.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);width:100%}.nav-overlay{display:none}@media(max-width: 767px){.nav-overlay{display:block;position:fixed;inset:0;background-color:rgba(0,0,0,.5);z-index:999;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.nav-overlay.is-open{opacity:1;visibility:visible}}.hero{position:relative;width:100%;height:100vh;min-height:560px;padding-top:72px}@media(max-width: 767px){.hero{padding-top:60px;min-height:480px}}.hero__swiper{width:100%;height:100%}.hero__slide{background-image:var(--slide-bg);background-size:cover;background-position:center center;position:relative}.hero__slide::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.5) 100%)}.hero__content{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);text-align:center;color:#fff;z-index:10;width:92%;max-width:800px}.hero__logo{margin-bottom:1.25rem}.hero__logo img{width:160px;height:auto;margin:0 auto;filter:drop-shadow(0 2px 8px rgba(0, 0, 0, 0.4))}@media(max-width: 767px){.hero__logo{margin-bottom:1rem}.hero__logo img{width:120px}}.hero__title{font-size:2.625rem;font-weight:700;line-height:1.6;margin-bottom:1.25rem;text-shadow:0 2px 12px rgba(0,0,0,.4)}@media(min-width: 768px)and (max-width: 1023px){.hero__title{font-size:2.25rem}}@media(max-width: 767px){.hero__title{font-size:1.625rem}}.hero__lead{font-size:1.0625rem;letter-spacing:.08em;text-shadow:0 1px 6px rgba(0,0,0,.4)}@media(max-width: 767px){.hero__lead{font-size:.9375rem}}.hero .swiper-button-prev,.hero .swiper-button-next{color:#fff;width:44px;height:44px;background-color:hsla(0,0%,100%,.2);border-radius:50%;transition:background-color .3s ease}.hero .swiper-button-prev::after,.hero .swiper-button-next::after{font-size:1.125rem;font-weight:700}.hero .swiper-button-prev:hover,.hero .swiper-button-next:hover{background-color:hsla(0,0%,100%,.35)}@media(max-width: 767px){.hero .swiper-button-prev,.hero .swiper-button-next{display:none}}.hero .swiper-pagination{bottom:20px}.hero .swiper-pagination-bullet{width:10px;height:10px;background-color:hsla(0,0%,100%,.6);opacity:1;transition:background-color .3s ease,transform .3s ease}.hero .swiper-pagination-bullet-active{background-color:#17a09e;transform:scale(1.25)}.intro__layout{display:grid;grid-template-columns:1fr 1fr}@media(max-width: 1023px){.intro__layout{grid-template-columns:1fr}}.intro__text{background-color:#17a09e;padding:80px 64px;display:flex;flex-direction:column;justify-content:center}@media(min-width: 768px)and (max-width: 1023px){.intro__text{padding:60px 40px}}@media(max-width: 767px){.intro__text{padding:56px 20px}}.intro__desc{font-size:.9375rem;color:hsla(0,0%,100%,.92);margin-bottom:2rem;line-height:2}.intro__philosophy{border-left:3px solid hsla(0,0%,100%,.8);padding-left:1.25rem;display:flex;flex-direction:column;gap:.75rem}.intro__philosophy li{font-size:.9375rem;color:hsla(0,0%,100%,.95);position:relative;padding-left:1rem}.intro__philosophy li::before{content:"─";position:absolute;left:-0.75rem;color:hsla(0,0%,100%,.8);font-size:.75rem;top:.25em}.intro__image{position:relative;overflow:hidden;min-height:480px}.intro__image img{width:100%;height:100%;object-fit:cover;display:block;height:100%;position:absolute;inset:0}@media(max-width: 1023px){.intro__image{min-height:280px;position:relative;order:-1}}.message{background-color:#f7f7f7}.message__layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}@media(max-width: 1023px){.message__layout{grid-template-columns:1fr;gap:40px}}.message__image{position:relative;border-radius:4px;overflow:hidden}.message__image img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:3/4;border-radius:4px}@media(max-width: 1023px){.message__image{max-width:480px;margin:0 auto}.message__image img{aspect-ratio:4/3}}.message__body{font-size:.9375rem;color:#333;line-height:2;margin-bottom:2rem}.message__signature{font-size:1rem;font-weight:700;color:#333;text-align:right;padding-top:1rem;border-top:1px solid #dcdcdc}.culture__layout{display:grid;grid-template-columns:1fr 1fr}@media(max-width: 1023px){.culture__layout{grid-template-columns:1fr}}.culture__image{position:relative;overflow:hidden;min-height:480px}.culture__image img{width:100%;height:100%;object-fit:cover;display:block;height:100%;position:absolute;inset:0}@media(max-width: 1023px){.culture__image{min-height:280px;position:relative}}.culture__text{background-color:#17a09e;padding:80px 64px;display:flex;flex-direction:column;justify-content:center}@media(min-width: 768px)and (max-width: 1023px){.culture__text{padding:60px 40px}}@media(max-width: 767px){.culture__text{padding:56px 20px}}.culture__body{font-size:.9375rem;color:hsla(0,0%,100%,.92);line-height:2}.company{background-color:#fff}.company .section-heading{margin-bottom:2.5rem}.company .section-heading::after{content:"";display:block;width:48px;height:3px;background-color:#17a09e;margin:.75rem auto 0}.company__table{width:100%;border-collapse:collapse;font-size:.9375rem}.company__table tr{border-bottom:1px solid #dcdcdc}.company__table tr:first-child{border-top:1px solid #dcdcdc}.company__table th{width:200px;padding:1.25rem 1rem 1.25rem 0;font-weight:700;color:#333;vertical-align:top;white-space:nowrap;line-height:1.8}.company__table th small{font-weight:400;font-size:.75rem;color:#666;display:block}@media(max-width: 767px){.company__table th{width:auto;display:block;padding:1rem 0 .25rem;white-space:normal;border-bottom:none}}.company__table td{padding:1.25rem 1rem 1.25rem 2rem;color:#333;vertical-align:top;line-height:1.9}@media(max-width: 767px){.company__table td{display:block;padding:0 0 1rem;border-bottom:1px solid #dcdcdc}}@media(max-width: 767px){.company__table tr{display:block;padding:0;border-bottom:none}.company__table tr:first-child{border-top:none}}.business{background-color:#f7f7f7}.business__layout{display:block}.business__header{margin-bottom:2.5rem;text-align:center}.business__header .section-heading{margin-bottom:.75rem}.business__header .section-heading::after{content:"";display:block;width:48px;height:3px;background-color:#17a09e;margin:.75rem auto 0}.business__items{display:grid;grid-template-columns:repeat(4, 1fr);gap:24px;margin-top:2rem}@media(min-width: 768px)and (max-width: 1023px){.business__items{grid-template-columns:repeat(2, 1fr)}}@media(max-width: 767px){.business__items{grid-template-columns:1fr;gap:20px}}.business__item{background:#fff;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.05);overflow:hidden;display:flex;flex-direction:column}.business__item-image{width:100%;aspect-ratio:16/9;overflow:hidden}.business__item-image img{width:100%;height:100%;object-fit:cover;display:block;width:100%;height:100%}.business__item-title{font-size:1.125rem;font-weight:700;color:#17a09e;margin:1.25rem 1.25rem .75rem;border-bottom:2px solid #f7f7f7;padding-bottom:.5rem}.business p{font-size:.9375rem;color:#666;line-height:1.8;padding:0 1.25rem 1.5rem;margin:0}.works{background-color:#fff}.works__header{margin-bottom:2.5rem;text-align:center}.works__header .section-heading{margin-bottom:.75rem}.works__header .section-heading::after{content:"";display:block;width:48px;height:3px;background-color:#17a09e;margin:.75rem auto 0}.works__sub{font-size:.9375rem;color:#666}.works__grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:20px}@media(min-width: 768px)and (max-width: 1023px){.works__grid{grid-template-columns:repeat(2, 1fr)}}@media(max-width: 767px){.works__grid{grid-template-columns:repeat(2, 1fr);gap:12px}}.works__item{border-radius:4px;overflow:hidden;background-color:#fff;box-shadow:0 2px 12px rgba(0,0,0,.08);transition:transform .3s ease,box-shadow .3s ease}.works__item:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.12)}.works__item:hover .works__item-img img{transform:scale(1.05)}.works__item--card{display:flex;align-items:center;justify-content:center;min-height:120px;padding:1.5rem 1rem;border:2px solid #dcdcdc;background-color:#f7f7f7;text-decoration:none}.works__item--card .works__item-name{font-size:1.0625rem;font-weight:700;padding:0}.works__item--card:hover{border-color:#17a09e;background-color:#fff;opacity:1}.works__item--card:hover .works__item-name{color:#17a09e}@media(max-width: 767px){.works__item--card{min-height:80px;padding:1rem}.works__item--card .works__item-name{font-size:.9375rem}}.works__item-img{overflow:hidden}.works__item-img img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/3;transition:transform .5s ease}.works__item-name{padding:.75rem 1rem;font-size:.875rem;font-weight:500;color:#333;text-align:center}.works__more{text-align:center;margin-top:3rem}.works-detail{background-color:#f7f7f7}.works-detail:nth-of-type(even){background-color:#fff}.works-detail__title{font-size:1.375rem;font-weight:700;color:#333;margin-bottom:2rem;padding-bottom:.75rem;border-bottom:2px solid #17a09e;text-align:center}@media(max-width: 767px){.works-detail__title{font-size:1.125rem;margin-bottom:1.5rem}}.works-detail__image{max-width:800px;margin:0 auto 2.5rem;border-radius:4px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.08)}.works-detail__image img{width:100%;height:auto;aspect-ratio:16/9;width:100%;height:100%;object-fit:cover;display:block}.works-detail__list{max-width:640px;margin:0 auto 2rem;list-style:none}.works-detail__list li{position:relative;padding:.625rem 0 .625rem 1.5rem;font-size:.9375rem;border-bottom:1px solid #dcdcdc;color:#333}.works-detail__list li::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background-color:#17a09e}.works-detail__back{text-align:center;font-size:.875rem}.works-detail__back a{color:#17a09e;font-weight:500}.works-detail__back a:hover{opacity:.7}.recruit{background-color:#f7f7f7}.recruit__layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}@media(max-width: 1023px){.recruit__layout{grid-template-columns:1fr;gap:40px}}.recruit__image{border-radius:4px;overflow:hidden}.recruit__image img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/3;border-radius:4px}@media(max-width: 1023px){.recruit__image{max-width:560px;margin:0 auto}}.recruit__body{font-size:.9375rem;color:#333;line-height:2;margin-bottom:2rem}.contact{background-color:#17a09e;text-align:center}.contact__lead{font-size:1.0625rem;color:hsla(0,0%,100%,.9);margin-bottom:1.5rem}.contact__info{margin-bottom:2rem}.contact__address{font-size:.9375rem;color:hsla(0,0%,100%,.85);line-height:1.8}.privacy{padding-top:clamp(100px,15vw,160px);padding-bottom:clamp(60px,10vw,120px)}.privacy__content{max-width:800px;margin:0 auto}.privacy__content h2{font-size:1.5rem;font-weight:700;margin-bottom:2rem;border-bottom:2px solid #17a09e;padding-bottom:.5rem}.privacy__content h3{font-size:1.125rem;font-weight:700;margin-top:2.5rem;margin-bottom:1rem;color:#333}.privacy__content p{font-size:1rem;line-height:1.8;margin-bottom:1.5rem;color:#333}.privacy__content p:last-child{margin-bottom:0}.footer{background-color:#1d1d1d;padding:56px 0 40px}.footer__inner{max-width:1200px;margin:0 auto;padding:0 40px}@media(max-width: 767px){.footer__inner{padding:0 20px}}.footer__inner{display:flex;flex-direction:column;align-items:center;gap:2rem;text-align:center}.footer__logo img{height:32px;width:auto;filter:brightness(0) invert(1);opacity:.85}.footer__nav-list{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1.5rem}.footer__nav-list a{font-size:.875rem;color:hsla(0,0%,100%,.65);transition:color .3s ease}.footer__nav-list a:hover{color:#fff;opacity:1}.footer__copy{font-size:.8125rem;color:hsla(0,0%,100%,.4);letter-spacing:.05em}
