@charset "utf-8";/* =================================RESET================================= */*{margin:0;padding:0;box-sizing:border-box;}img{max-width:100%;height:auto;display:block;}body{font-family:"Noto Sans JP",sans-serif;color:#333;line-height:1.7;font-size:clamp(14px,1.2vw,18px);}a{text-decoration:none;color:inherit;}ul{list-style:none;}/* =================================LAYOUT================================= */.container{width:90%;max-width:1240px;margin:auto;}.section{padding:80px 0;}.section-title{font-size:clamp(22px,3vw,32px);text-align:center;margin-bottom:50px;letter-spacing:2px;}/* =================================HEADER================================= */.header{background:#fff;border-bottom:1px solid #eee;position:sticky;top:0;z-index:100;    padding: 20px 0;}.header-inner{display:flex;justify-content:space-between;align-items:center;height:70px;}.header.small{height:auto;box-shadow:0 2px 10px rgba(0,0,0,0.1);}.logo{font-size:20px;font-weight:bold;}@media screen and (max-width:768px){.logo {  max-width: 200px;}}.nav ul{display:flex;gap:30px;align-items:center;}.nav a{font-size:14px;}.contact-btn a{background:#f39c12;color:#fff;padding:10px 18px;border-radius:4px;}.header-inner{display:flex;align-items:center;}.logo{margin-right:40px;}.nav{margin-left:auto;margin-right:40px;    display: flex;}.nav ul{display:flex;gap:40px;}.nav a{display:flex;flex-direction:column;align-items:center;}.nav .en{font-weight:bold;color:#f39800;letter-spacing:1px;}.nav .jp{color:#666;}.header-contact{display:flex;flex-direction:column;align-items:flex-end;margin-left:40px;}@media screen and (max-width:768px){.header-contact{margin-top:30px;border-top:1px solid #eee;padding-top:20px;align-items:flex-start;    margin-left: 0;}.header-contact .tel{font-size:20px;margin-bottom:10px;}.contact-btn{display:block;width:100%;text-align:center;}}.contact-btn{background:#f39800;color:#fff;padding:12px 20px;margin-bottom:6px;}.tel{font-size:clamp(18px,2vw,24px);color:#333;    font-weight: 600;}/* =================================MV================================= */.mv{height:820px;background:url("../images/mv.jpg") center / cover no-repeat;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;}.mv h2{font-size:36px;letter-spacing:3px;font-weight:700;}/* =================================ABOUT================================= */.about{    background: url("../images/about-bg.png")center / cover no-repeat;}.about-inner{display:flex;gap:50px;align-items:center;}.about-text h2{font-size:clamp(20px,2.2vw,26px);margin-bottom:20px;    position: relative;    padding-bottom: 15px;}.about-text h2::after{    content: "";    position: absolute;    bottom: 0;    left: 0;    height: 3px;    width: 100px;    background: #F39800;}.about-text p{margin-bottom:20px;}.about-text ul li{margin-bottom:8px;}/* =================================GREETING================================= */.greeting{background:url("../images/greeting_bg.png") center / cover no-repeat;}.greeting h2{    text-align: center;    position: relative;    margin-bottom: 20px;    font-size: 32px;    padding-bottom: 15px;}.greeting h2::after{    content: "";    position: absolute;    bottom: 0;    left: 50%;    transform: translateX(-50%);    height: 3px;    width: 100px;    background: #F39800;}.greeting-inner{display:flex;gap:50px;align-items:center;}.greeting-text {  max-width: 600px;}@media screen and (min-width:768px){.greeting-image {  width: 50%;}}/* =================================NEWS================================= */.news-list{max-width:700px;margin:auto;}.news-list li{display:flex;gap:20px;padding:15px 0;border-bottom:1px solid #ddd;}.news-list .date{font-weight:bold;width:120px;    color: #F39800;}/* =================================RECRUIT================================= */.recruit{background:url("../images/recruit.jpg") center / cover no-repeat;color:#fff;text-align:center;padding:120px 20px;position:relative;}.recruit::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,0.5);}.recruit-inner{position:relative;z-index:2;}.recruit h2{font-size:clamp(22px,3vw,32px);margin-bottom:20px;}.btn{display:inline-block;margin-top:20px;background:#000;color:#fff;padding:14px 30px;}/* =================================BUSINESS================================= */.business-intro{  background:url("../images/greeting_bg.png") center / cover no-repeat;    padding: 10% 2%}.business-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}.business-item{background:#fff;border:1px solid #eee;transition:0.3s;}.business-item:hover{transform:translateY(-5px);box-shadow:0 10px 20px rgba(0,0,0,0.1);}.business-item h3{padding:15px;}.business-item p{    padding: 0 15px 15px;}/* =================================MAP================================= */.map iframe{width:100%;height:400px;border:0;}/* =================================FOOTER================================= */.footer-main{background:#f5f5f5;padding:40px 0;}.footer-inner{display:flex;align-items:center;justify-content:space-between;}/* 左 */.footer-left{text-align:center;}.footer-left img{margin-bottom:5px;}/* 中央 */.footer-center{text-align:center;}.footer-address{margin-bottom:5px;}.footer-tel{margin-bottom:8px;}.footer-contact{background:#f39800;color:#fff;padding:8px 18px;display:inline-block;}/* 右 */.footer-right{text-align:center;}.pagetop{position:fixed;right:30px;bottom:30px;z-index:999;text-align:center;}.pagetop-icon{display:block;background:#f39800;color:#fff;width:50px;height:50px;border-radius:50%;line-height:50px;font-size:18px;margin:0 auto 5px;box-shadow:0 5px 15px rgba(0,0,0,0.15);}.pagetop-text{font-size:11px;color:#f39800;font-weight:600;}/* コピー */.footer-copy{background:#f39800;color:#fff;text-align:center;padding:8px;}/* =================================TABLET================================= */@media screen and (max-width:1024px){.section{padding:70px 0;}.business-grid{grid-template-columns:repeat(2,1fr);}.mv{height:420px;}.mv h2{font-size:clamp(22px,4vw,36px);}.about-inner{gap:30px;}.greeting-inner{gap:30px;}}/* =================================SMARTPHONE================================= */@media screen and (max-width:768px){.section{padding:60px 0;}.section-title{font-size:26px;}.mv{height:320px;padding:0 20px;}.mv h2{font-size:24px;}.about-inner{flex-direction:column;}.about-image{order:-1;}.greeting-inner{flex-direction:column;}.news-list li{flex-direction:column;gap:5px;}.news-list .date{width:auto;}.business-grid{grid-template-columns:1fr;}.recruit{padding:80px 20px;}.map iframe{height:300px;}}/* =================================SMALL MOBILE================================= */@media screen and (max-width:480px){.mv h2{font-size:24px;}.container{width:92%;}.section-title{font-size:26px;}}/* =========================HAMBURGER========================= */.hamburger{display:none;width:30px;height:22px;flex-direction:column;justify-content:space-between;background:none;border:none;cursor:pointer;}.hamburger span{display:block;height:3px;background:#333;border-radius:2px;}/* mobile */@media screen and (max-width:768px){.hamburger{display:flex;}.nav{position:fixed;top:0;right:-100%;width:260px;height:100vh;background:#fff;padding:80px 30px;transition:0.3s;    z-index: 99;}.nav ul{flex-direction:column;gap:20px;}.nav.active{right:0;    display: flex;    flex-direction: column;}}.menu-open{overflow:hidden;}/* =========================HAMBURGER ANIMATION========================= */.hamburger span{transition:0.3s;}.hamburger.active span:nth-child(1){transform:translateY(9px) rotate(45deg);}.hamburger.active span:nth-child(2){opacity:0;}.hamburger.active span:nth-child(3){transform:translateY(-9px) rotate(-45deg);}@media screen and (max-width:768px){.nav {  margin-right: 0;}    .header {  padding: 5px 0;}}/* =========================OVERLAY========================= */.overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);opacity:0;visibility:hidden;transition:0.3s;z-index:98;}.overlay.active{opacity:1;visibility:visible;}.overlay{z-index:90;}.nav{z-index:100;}.header{z-index:200;}.hamburger{position:relative;z-index:300;}/* =========================下層MV共通========================= */.page-mv{background:#f5f5f5;padding:80px 0;text-align:center;}.page-mv .en{display:block;color:#f39800;font-weight:bold;letter-spacing:2px;}.page-mv .jp{font-size:clamp(24px,3vw,32px);}/* =========================パンくず========================= */.breadcrumb{font-size:13px;padding:15px 0;background:#fafafa;}/* =========================会社概要========================= */.company-table{width:100%;border-top:1px solid #ddd;}.message-inner{display:flex;gap:60px;align-items:flex-start;}.message .section-title{text-align:center;margin-bottom:40px;}.message-image{width:40%;}.message-text{width:60%;}.message-image img{width:100%;height:auto;}.company-table th,.company-table td{padding:20px;border-bottom:1px solid #ddd;}.company-table th{width:200px;background:#fafafa;text-align:left;}.message-sign{margin-top:20px;font-weight:600;text-align:right;}@media screen and (max-width:768px){.message-inner{flex-direction:column;}.message-image,.message-text{width:100%;}}/* =========================BUSINESS PAGE========================= */.business-lead{max-width:800px;margin:auto;text-align:center;line-height:1.8;}.business-row{display:flex;gap:60px;align-items:center;}.business-image{width:45%;}.business-text{width:55%;}.business-text h2{font-size:clamp(22px,2.5vw,28px);margin-bottom:15px;}.business-text p{line-height:1.8;}.reverse{flex-direction:row-reverse;}.business-btn{display:inline-block;margin-top:20px;padding:12px 30px;background:#f39800;color:#fff;font-size:14px;letter-spacing:1px;transition:0.3s;}.business-btn::after{content:"→";margin-left:10px;}.business-btn:hover{opacity: .6}@media screen and (max-width:768px){.business-row{flex-direction:column;    gap: 20px;}.business-image,.business-text{width:100%;}}/* =========================RECRUIT========================= */.recruit-intro{  background:url("../images/greeting_bg.png") center / cover no-repeat;    padding: 10% 2%}.recruit-lead{max-width:1240px;margin:0 auto;text-align:center;line-height:1.9;font-size:clamp(15px,1.6vw,17px);color:#444;}.page-recruit .section h2{font-size:clamp(22px,2.5vw,28px);text-align:center;margin-bottom:40px;position:relative;}.page-recruit .section h2::after{content:"";display:block;width:60px;height:3px;background:#f39800;margin:12px auto 0;}.job-box{margin-top:40px;padding:40px;background:#f9f9f9;border-left:5px solid #f39800;}.job-box h3{font-size:24px;margin-bottom:15px;}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px;}.feature-item{padding:30px;border:1px solid #eee;background:#fff;text-align:center;transition:.3s;}.feature-item:hover{transform:translateY(-5px);box-shadow:0 10px 20px rgba(0,0,0,.08);}.feature-item h3{margin-bottom:10px;font-size:20px;}@media screen and (max-width:768px){.feature-grid{grid-template-columns:1fr;}}.recruit-table{width:100%;margin-top:40px;border-collapse:collapse;}.recruit-table th,.recruit-table td{border-bottom:1px solid #eee;padding:16px;text-align:left;}.recruit-table th{width:200px;background:#f7f7f7;font-weight:600;}.flow-list{margin-top:40px;max-width:600px;margin-left:auto;margin-right:auto;}.flow-list li{padding:15px 20px;border-left:4px solid #f39800;margin-bottom:15px;background:#fafafa;}.recruit-cta{background:#f39800;color:#fff;text-align:center;padding:80px 20px;}.recruit-cta h2{font-size:28px;margin-bottom:15px;}.recruit-cta p{margin-bottom:25px;}.cta-btn{display:inline-block;padding:16px 40px;background:#fff;color:#000;font-weight:600;transition:.3s;}.cta-btn:hover{background:#ddd;}/* =========================CONTACT========================= */.contact-lead{max-width:700px;margin:0 auto;text-align:center;line-height:1.9;}.contact-form{max-width:700px;margin:auto;}.form-group{margin-bottom:25px;}.form-group label{display:block;margin-bottom:8px;font-weight:600;}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid #ddd;}.required{color:#e60023;margin-left:8px;}.form-submit{text-align:center;margin-top:30px;}.form-btn{padding:14px 40px;background:#f39800;color:#fff;border:none;cursor:pointer;transition:.3s;}.form-btn:hover{opacity: .6;}/* =========================RECYCLE PAGE========================= */.page-recycle .section h2{font-size:clamp(22px,2.5vw,28px);text-align:center;margin-bottom:40px;position:relative;}.page-recycle .section h2::after{content:"";display:block;width:60px;height:4px;background:var(--main-color);margin:12px auto 0;border-radius:2px;}.recycle-intro{  background:url("../images/greeting_bg.png") center / cover no-repeat;    padding: 10% 2%}.recycle-lead{max-width:1240px;margin:auto;text-align:center;line-height:1.9;}.recycle-row{display:flex;gap:60px;align-items:center;}.recycle-image{width:45%;}.recycle-image img{border-radius:10px;}.recycle-text{width:55%;}.recycle-text h2{margin-bottom:15px;color:var(--main-color);}.recycle-text p{line-height:1.8;}.recycle-cta{background:#f39800;color:#fff;text-align:center;padding:80px 20px;}.recycle-cta h2{margin-bottom:15px;}.recycle-cta p{margin-bottom:20px;}/* =========================RECYCLE FEATURE========================= */.page-recycle .feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px;}.page-recycle .feature-item{padding:30px;border:1px solid #eee;background:#fff;text-align:center;border-radius:8px;transition:.3s;}.page-recycle .feature-item:hover{transform:translateY(-5px);box-shadow:0 10px 25px rgba(0,0,0,.08);}.page-recycle .feature-item h3{color:var(--main-color);margin-bottom:10px;}@media screen and (max-width:768px){.recycle-row{flex-direction:column;}.recycle-image,.recycle-text{width:100%;}}/* =========================SHOP LIST========================= */.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px;}.shop-card{border:1px solid #eee;padding:25px;background:#fff;}.shop-card h3{margin-bottom:15px;font-size:18px;}.shop-card li{margin-bottom:8px;line-height:1.6;}@media (max-width:768px){/* 事業説明 */.page-recycle .recycle-row{flex-direction:column;gap:25px;}.page-recycle .recycle-image,.page-recycle .recycle-text{width:100%;}.page-recycle .recycle-text{text-align:left;}/* 特徴 */.page-recycle .feature-grid{grid-template-columns:1fr;gap:20px;}.page-recycle .feature-item{padding:22px;}/* 店舗一覧 */.page-recycle .shop-grid{grid-template-columns:1fr;gap:20px;}.page-recycle .shop-card{padding:20px;}/* CTA */.page-recycle .recycle-cta{padding:60px 20px;}.page-recycle .recycle-cta h2{font-size:20px;}.page-recycle .recycle-cta p{font-size:14px;}/* リード */.page-recycle .recycle-lead{font-size:15px;line-height:1.8;}}/* =========================EVENT PAGE========================= */.page-event{--main-color:#f39800;}.event-lead{max-width:800px;margin:auto;text-align:center;line-height:1.9;}.event-row{display:flex;gap:60px;align-items:center;}.event-image{width:45%;}.event-text{width:55%;}.event-text h2{color:var(--main-color);margin-bottom:15px;}.event-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px;}.event-feature-item{padding:30px;border:1px solid #eee;border-radius:8px;text-align:center;}.event-feature-item h3{color:var(--main-color);margin-bottom:10px;}.event-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px;}.event-card{border:1px solid #eee;border-radius:8px;overflow:hidden;background:#fff;}.event-card h3{padding:15px;}.event-card p{padding:0 15px 15px;}.event-cta{background:var(--main-color);color:#fff;text-align:center;padding:80px 20px;}.event-cta p    {        margin-bottom: 25px;    }@media (max-width:768px){.page-event .event-row{flex-direction:column;gap:25px;}.page-event .event-image,.page-event .event-text{width:100%;}.page-event .event-feature-grid{grid-template-columns:1fr;}.page-event .event-grid{grid-template-columns:1fr;}}/* =========================FITNESS PAGE========================= */.page-fitness{--main-color:#f39800;}.fitness-lead{max-width:800px;margin:auto;text-align:center;line-height:1.9;}.fitness-row{display:flex;gap:60px;align-items:center;}.fitness-image{width:45%;}.fitness-text{width:55%;}.fitness-text h2{color:var(--main-color);margin-bottom:15px;}.fitness-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px;}.fitness-feature-item{padding:30px;border:1px solid #eee;border-radius:8px;text-align:center;}.fitness-feature-item h3{color:var(--main-color);margin-bottom:10px;}.fitness-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px;}.fitness-card{border:1px solid #eee;border-radius:8px;overflow:hidden;background:#fff;}.fitness-card h3{padding:15px;}.fitness-card p{padding:0 15px 15px;}.fitness-cta{background:var(--main-color);color:#fff;text-align:center;padding:80px 20px;}@media (max-width:768px){.page-fitness .fitness-row{flex-direction:column;gap:25px;}.page-fitness .fitness-image,.page-fitness .fitness-text{width:100%;}.page-fitness .fitness-feature-grid{grid-template-columns:1fr;}.page-fitness .fitness-grid{grid-template-columns:1fr;}}