:root{--navy:#002D5C;--navy-mid:#003B75;--steel:#0054A6;--steel-light:#1A72D4;--blue:#0054A6;--blue-glow:rgba(0, 84, 166, 0.18);--gray-50:#F0F4F8;--gray-100:#D0DCEE;--gray-400:#7A99BB;--gray-600:#3A5A80;--white:#FFFFFF;--font-main:'Noto Sans JP',sans-serif;--font-mono:'Share Tech Mono',monospace;--radius:8px;--radius-lg:16px;--shadow:0 4px 24px rgba(0, 42, 92, 0.14);--shadow-lg:0 12px 48px rgba(0, 42, 92, 0.22);--transition:0.28s cubic-bezier(0.4, 0, 0.2, 1)}*,::after,::before{box-sizing:border-box;margin:0;padding:0}.hidden{display:none}html{scroll-behavior:smooth;font-size:16px}body{padding-bottom:env(safe-area-inset-bottom);font-family:var(--font-main);background:var(--white);color:var(--navy);line-height:1.7;overflow-x:hidden}img{display:block;max-width:100%}a{color:inherit;text-decoration:none}ul{list-style:none}button{cursor:pointer;font-family:inherit;border:none;background:0 0}.container{width:min(1140px,92vw);margin-inline:auto}.section{padding-block:96px}.section-label{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.2em;color:#ff8c42;margin-bottom:12px}.section-title{font-size:clamp(1.75rem, 3.5vw, 2.75rem);font-weight:700;line-height:1.25;margin-bottom:16px;color:var(--navy)}.section-lead{font-size:1.05rem;color:var(--gray-600);margin-bottom:56px;line-height:1.8}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border-radius:var(--radius);font-size:.95rem;font-weight:500;letter-spacing:.02em;transition:var(--transition);white-space:nowrap}.btn--primary{background:var(--blue);color:var(--white);box-shadow:0 0 0 0 var(--blue-glow)}.btn--primary:hover{background:#004a94;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,84,166,.35)}.btn--outline{border:1.5px solid rgba(255,255,255,.5);color:var(--white)}.btn--outline:hover{background:rgba(255,255,255,.1);border-color:var(--white)}.btn--full{width:100%}.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding-block:18px;transition:var(--transition)}.nav::before{content:'';position:absolute;inset:0;background:rgba(0,45,92,.96);backdrop-filter:blur(12px);box-shadow:0 2px 20px rgba(0,0,0,.3);opacity:0;transition:var(--transition);pointer-events:none}.nav.scrolled{padding-block:12px}.nav.scrolled::before{opacity:1}.nav__inner{position:relative;z-index:1;width:min(1140px,92vw);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:24px}.nav__logo{display:flex;align-items:center;gap:10px;flex-shrink:0}.nav__logo-img{height:25px;width:auto;display:block;filter:brightness(0) invert(1)}.nav__logo-text{font-family:'Noto Serif JP',serif;font-size:1.25rem;color:var(--white);letter-spacing:.08em}.nav__links{display:flex;align-items:center;gap:32px}.nav__links a{font-size:.85rem;color:rgba(255,255,255,.8);letter-spacing:.03em;transition:color var(--transition);position:relative}.nav__links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--blue);transition:width var(--transition)}.nav__links a:hover{color:#fff}.nav__links a:hover::after{width:100%}.nav__hamburger{display:none;flex-direction:column;gap:5px;padding:4px}.nav__hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:var(--transition)}.hero{position:relative;min-height:100svh;background:linear-gradient(to bottom,rgba(40,40,40,.72) 0,rgba(40,40,40,.6) 50%,rgba(40,40,40,.8) 100%),image-set(url('./img/Main.webp') type('image/webp'),url('./img/Main.jpg') type('image/jpeg')) center center/cover no-repeat;display:flex;align-items:center;overflow:hidden}.hero__content{position:relative;z-index:2;width:100%;max-width:1140px;margin-left:auto;margin-right:auto;padding-left:4vw;padding-right:4vw;padding-top:140px;padding-bottom:80px;box-sizing:border-box}.hero__eyebrow{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.22em;color:rgba(255,255,255,.72);margin-bottom:24px;opacity:0;animation:fadeUp .8s .2s forwards}.hero__title{font-size:clamp(2.2rem, 6vw, 5rem);font-weight:900;line-height:1.18;color:var(--white);margin-bottom:28px;opacity:0;animation:fadeUp .8s .4s forwards}.hero__title--accent{color:#ff8c42;position:relative}.hero__sub{font-size:clamp(.9rem, 1.5vw, 1.1rem);color:rgba(255,255,255,.72);margin-bottom:48px;line-height:1.9;opacity:0;animation:fadeUp .8s .6s forwards}.hero__cta{display:flex;flex-wrap:wrap;gap:16px;opacity:0;animation:fadeUp .8s .8s forwards}.hero__scroll-indicator{position:absolute;bottom:40px;right:48px;display:flex;flex-direction:column;align-items:center;gap:10px;z-index:2;opacity:0;animation:fadeIn 1s 1.2s forwards}.hero__scroll-indicator span{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.2em;color:rgba(255,255,255,.45);writing-mode:vertical-rl}.hero__scroll-line{width:1px;height:64px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:scrollPulse 2.4s ease-in-out infinite}.services{background:var(--white)}.services__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.service-card{border:1.5px solid var(--gray-100);border-radius:var(--radius-lg);padding:32px;position:relative;overflow:hidden;transition:var(--transition);background:var(--white)}.service-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:0;background:var(--blue);transition:height .4s ease}.service-card:hover{border-color:rgba(0,84,166,.3);box-shadow:var(--shadow);transform:translateY(-4px)}.service-card:hover::before{height:100%}.service-card__header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}.service-card__num{font-family:var(--font-mono);font-size:1.8rem;font-weight:700;color:var(--gray-100);line-height:1;flex-shrink:0}.service-card__title{font-size:1.05rem;font-weight:700;line-height:1.5;color:var(--navy)}.service-card__title small{font-size:.78rem;font-weight:400;color:var(--gray-400);display:block;margin-top:2px;font-family:var(--font-mono)}.service-card__list{margin-bottom:20px}.service-card__list li{font-size:.875rem;color:var(--gray-600);line-height:1.7;padding-left:16px;position:relative;margin-bottom:6px}.service-card__list li::before{content:'▸';position:absolute;left:0;color:var(--blue);font-size:.7rem;top:3px}.service-card__tag{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;color:var(--blue);border:1px solid rgba(0,84,166,.3);padding:4px 10px;border-radius:4px;display:inline-block}.devices{background:var(--navy);padding-block:72px}.devices .section-label{color:#ff8c42}.devices .section-title{color:var(--white)}.devices__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}.device-group{border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);overflow:hidden}.device-group__brand{background:var(--steel);color:var(--white);font-weight:700;font-size:1rem;padding:16px 24px;letter-spacing:.04em}.device-group__items{padding:20px 24px;display:flex;flex-direction:column;gap:16px;background:#fff}.device-item{display:flex;align-items:baseline;gap:12px}.device-item__type{font-family:var(--font-mono);font-size:.72rem;background:rgba(0,84,166,.2);color:var(--blue);padding:3px 8px;border-radius:4px;flex-shrink:0;letter-spacing:.05em}.device-item__models{font-size:.9rem;font-family:var(--font-mono)}.works{background:var(--gray-50)}.works__grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:48px}.work-card{background:var(--white);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow);transition:var(--transition);position:relative;border-top:4px solid var(--blue)}.work-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.work-card__badge{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;color:var(--blue);margin-bottom:12px}.work-card__title{font-size:1.25rem;font-weight:700;color:var(--navy);line-height:1.4;margin-bottom:20px}.work-card__spec{display:flex;gap:24px;margin-bottom:20px;padding:16px 20px;background:var(--gray-50);border-radius:var(--radius)}.work-card__spec-item{display:flex;flex-direction:column;gap:4px}.work-card__spec-item .label{font-size:.72rem;color:var(--gray-400);font-family:var(--font-mono);letter-spacing:.05em}.work-card__spec-item .value{font-size:1.05rem;font-weight:700;color:var(--navy);font-family:var(--font-mono)}.work-card__desc{font-size:.9rem;color:var(--gray-600);line-height:1.85;margin-bottom:20px}.work-card__tags{display:flex;flex-wrap:wrap;gap:8px}.work-card__tags span{font-size:.75rem;padding:4px 12px;background:rgba(30,77,140,.08);color:var(--steel);border-radius:20px;font-weight:500}.inquiry{background:var(--white)}.inquiry__lead{max-width:720px;margin-bottom:56px}.inquiry__lead p{font-size:1rem;color:var(--gray-600);line-height:1.9}.inquiry__lead strong{color:var(--navy);font-weight:700}.inquiry__grid{display:grid;grid-template-columns:1fr 2fr;gap:48px;align-items:start}.inquiry__info h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--blue)}.inquiry__device-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:24px}.inquiry__device{display:flex;flex-direction:column;gap:2px;padding:12px 16px;background:var(--gray-50);border-radius:var(--radius);border-left:3px solid var(--steel)}.inquiry__device strong{font-size:.875rem;color:var(--navy);font-weight:700}.inquiry__device span{font-family:var(--font-mono);font-size:.78rem;color:var(--gray-600)}.inquiry__form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.875rem;font-weight:500;color:var(--navy)}.required{color:#ff8c42;margin-left:2px}.form-group input,.form-group textarea{padding:12px 16px;border:1.5px solid var(--gray-100);border-radius:var(--radius);font-family:var(--font-main);font-size:.9rem;color:var(--navy);background:var(--gray-50);transition:border-color var(--transition),box-shadow var(--transition);outline:0;resize:vertical}.form-group input:focus,.form-group textarea:focus{border-color:var(--steel);box-shadow:0 0 0 3px rgba(30,77,140,.12);background:var(--white)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--gray-400);font-size:.85rem}.inquiry__success{display:none;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:60px 40px;text-align:center;background:var(--gray-50);border-radius:var(--radius-lg);border:2px solid rgba(30,77,140,.2)}.inquiry__success.show{display:flex}.inquiry__success-icon{width:56px;height:56px;background:var(--steel);color:var(--white);border-radius:50%;display:grid;place-items:center;font-size:1.6rem}.inquiry__success p{font-size:.95rem;color:var(--gray-600);line-height:1.9}.form-group--privacy{margin-top:4px}.privacy-check{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--gray-600);cursor:pointer}.privacy-check input[type=checkbox]{width:16px;height:16px;flex-shrink:0;accent-color:var(--blue);cursor:pointer}.privacy-check a{color:var(--blue);text-decoration:underline}.privacy-policy{margin-top:64px;padding:40px;background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--gray-100);box-shadow:var(--shadow)}.privacy-policy h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:16px;letter-spacing:.04em;padding-bottom:12px;border-bottom:1px solid var(--gray-100)}.privacy-policy p{font-size:.85rem;color:var(--gray-600);line-height:1.8;margin-bottom:16px}.privacy-policy ol{list-style:decimal;padding-left:1.4em;display:flex;flex-direction:column;gap:10px}.privacy-policy ol li{font-size:.85rem;color:var(--gray-600);line-height:1.8}.privacy-policy ol li a{color:var(--blue);text-decoration:underline}@media (max-width:600px){.privacy-policy{padding:24px 20px}}.recruit{background:var(--navy-mid)}.recruit .section-label{color:#ff8c42}.recruit .section-title{color:var(--white)}.recruit__lead{font-size:1rem;color:#fff;margin-bottom:48px;line-height:1.9}.recruit__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:56px}.recruit-item{display:flex;align-items:center;gap:14px;padding:20px 20px;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);background:rgba(255,255,255,.04);transition:var(--transition)}.recruit-item:hover{background:rgba(255,255,255,.08);border-color:rgba(0,84,166,.4)}.recruit-item__icon{width:32px;height:32px;color:#ff8c42;flex-shrink:0}.recruit-item span{font-size:.875rem;color:#fff;line-height:1.5;font-weight:500}.recruit-item span small{display:block;font-size:.72rem;font-family:var(--font-mono);color:rgba(255,255,255,.45);margin-top:2px}.recruit__cta{display:flex;align-items:center;gap:32px;padding:40px;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);background:rgba(255,255,255,.04);flex-wrap:wrap}.recruit__cta p{font-size:.95rem;color:#fff;flex:1;min-width:200px}.access__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:stretch}.access__info{display:flex;flex-direction:column;justify-content:center}.access__list{display:grid;grid-template-columns:auto 1fr;border:1px solid var(--gray-100);border-radius:var(--radius-lg);overflow:hidden}.access__item{display:contents}.access__item:not(:last-child) dd,.access__item:not(:last-child) dt{border-bottom:1px solid var(--gray-100)}.access__item dt{display:flex;align-items:center;gap:8px;padding:18px 20px;background:var(--gray-50);font-size:.82rem;font-weight:500;color:var(--gray-600);letter-spacing:.04em;height:100%;white-space:nowrap}.access__item dt svg{width:16px;height:16px;color:var(--steel);flex-shrink:0}.access__item dd{padding:18px 24px;font-size:.92rem;color:var(--navy);line-height:1.7}.access__item dd a{color:var(--steel);transition:color var(--transition)}.access__item dd a:hover{color:var(--steel-light);text-decoration:underline}.access__map{border-radius:var(--radius-lg);overflow:hidden;min-height:320px;box-shadow:var(--shadow);border:1px solid var(--gray-100)}.access__map iframe{display:block;width:100%;height:100%;min-height:320px}.footer{background:var(--navy);padding-block:48px 24px}.footer__inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:24px}.footer__logo{display:flex;align-items:center;gap:10px}.footer__tagline{font-size:.82rem;color:rgba(255,255,255,.45);flex:1;text-align:center;min-width:200px}.footer__nav{display:flex;flex-wrap:wrap;gap:20px}.footer__nav a{font-size:.82rem;color:rgba(255,255,255,.55);transition:color var(--transition)}.footer__nav a:hover{color:var(--blue)}.footer__bottom{text-align:center}.footer__bottom p{font-size:.75rem;color:rgba(255,255,255,.3);font-family:var(--font-mono)}.company-info{background:var(--navy-mid)}.company-info .section-label{color:#ff8c42}.company-info .section-title{color:var(--white)}.company-info__table-wrap{max-width:760px;margin-inline:auto}.facility-photos{background:var(--white)}.company-info__list{display:grid;grid-template-columns:1fr;border-top:1px solid rgba(255,255,255,.2)}.company-info__item{display:grid;grid-template-columns:160px 1fr;border-bottom:1px solid rgba(255,255,255,.2)}.company-info__item dd,.company-info__item dt{padding:20px 16px;font-size:.95rem;line-height:1.7}.company-info__item dt{font-weight:600;color:var(--white);background:rgba(255,255,255,.08);white-space:nowrap}.company-info__item dd{color:rgba(255,255,255,.85)}@media (max-width:480px){.company-info__item{grid-template-columns:120px 1fr}.company-info__item dd,.company-info__item dt{padding:14px 12px;font-size:.9rem}}.slider{position:relative;margin-top:48px;margin-inline:auto;max-width:680px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--gray-50);aspect-ratio:4/3}.slider__track{display:flex;width:100%;height:100%;transition:transform .6s cubic-bezier(.4, 0, .2, 1)}.slider__slide{position:relative;flex:0 0 100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.slider__slide img{width:100%;height:100%;object-fit:contain;display:block}.slider__btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);color:var(--white);font-size:1.6rem;line-height:1;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:1px solid rgba(255,255,255,.3);transition:background var(--transition);z-index:10}.slider__btn:hover{background:rgba(255,255,255,.35)}.slider__btn--prev{left:16px}.slider__btn--next{right:16px}.slider__dots{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:10}.slider__dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);border:none;cursor:pointer;padding:0;transition:background var(--transition),transform var(--transition)}.slider__dot.active{background:var(--white);transform:scale(1.25)}@media (max-width:600px){.slider{aspect-ratio:4/3}.slider__btn{width:36px;height:36px;font-size:1.3rem}.slider__caption{display:none}}@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes scrollPulse{0%,100%{transform:scaleY(1);opacity:.4}50%{transform:scaleY(1.15);opacity:.9}}.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal--delay-1{transition-delay:0.1s}.reveal--delay-2{transition-delay:0.2s}.reveal--delay-3{transition-delay:0.3s}.reveal--delay-4{transition-delay:0.4s}.reveal--delay-5{transition-delay:0.5s}@media (max-width:1024px){.inquiry__grid{grid-template-columns:1fr}.recruit__grid{grid-template-columns:repeat(2,1fr)}.works__grid{grid-template-columns:1fr}}@media (max-width:768px){.section{padding-block:56px}.nav{padding-block:14px}.nav__links{display:none;position:fixed;inset:0;background:rgba(0,45,92,.98);flex-direction:column;justify-content:center;align-items:center;gap:40px;z-index:99}.nav__links.open{display:flex}.nav__links a{font-size:1.2rem}.nav__hamburger{display:flex;z-index:100}.hero__content{padding-block:120px 60px}.hero__sub{font-size:.88rem}.hero__scroll-indicator{display:none}.services__grid{grid-template-columns:1fr}.service-card{padding:24px}.devices__grid{grid-template-columns:1fr}.works__grid{grid-template-columns:1fr}.work-card{padding:28px 24px}.work-card__spec{flex-wrap:wrap;gap:16px}.inquiry__grid{grid-template-columns:1fr}.recruit__grid{grid-template-columns:1fr}.recruit__cta{flex-direction:column;align-items:flex-start;gap:20px}.recruit-item{padding:16px}.access__grid{grid-template-columns:1fr;gap:28px}.access__item{grid-template-columns:auto 1fr}.footer__inner{flex-direction:column;align-items:flex-start}.footer__tagline{text-align:left}.footer__nav{gap:14px}}@media (max-width:430px){.section{padding-block:48px}.hero__title{font-size:2rem;line-height:1.25}.hero__eyebrow{font-size:.7rem;letter-spacing:.15em}.hero__sub{font-size:.85rem}.hero__cta{flex-direction:column}.hero__cta .btn{width:100%;text-align:center}.btn{padding:13px 24px;font-size:.9rem}.section-title{font-size:1.5rem}.section-lead{font-size:.9rem}.service-card{padding:20px 18px}.service-card__list li{font-size:.83rem}.work-card{padding:24px 18px}.work-card__title{font-size:1.05rem}.work-card__spec{flex-direction:column;gap:10px}.form-group input,.form-group textarea{font-size:16px}.inquiry__lead p{font-size:.88rem}.recruit-item{gap:10px}.recruit-item span{font-size:.82rem}.recruit__cta{padding:24px 20px}.device-group__brand{font-size:.92rem;padding:14px 18px}.device-item__models{font-size:.8rem}.footer__nav{gap:10px}.footer__nav a{font-size:.78rem}}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:0s!important;transition-duration:0s!important}}