/*
Theme Name: TRANQUILO Theme
Theme URI: https://tranquilo-co.com
Author: TRANQUILO Co., Ltd.
Description: 株式会社トランキロ カスタムテーマ v2.12 - 採用に革命を。
Version: 2.12.0
Text Domain: tranquilo
*/

/* ===== BASE ===== */
:root{--cyan:#00CFFF;--cyan-d:#0098C8;--cyan-l:#7EE8FF;--cyan-p:#E8F8FF;--w:#FFF;--snow:#F4F7F9;--g1:#EDF0F3;--g2:#DCE1E6;--g3:#B8C0C8;--g5:#7A8490;--g6:#5A6370;--g8:#2A2F36;--dk:#0B1117}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;background:var(--w);color:var(--g8);overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.8}
img{max-width:100%;height:auto;display:block}a{text-decoration:none;color:inherit;transition:color .3s}
[id]{scroll-margin-top:90px}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 60px;height:76px;display:flex;align-items:center;justify-content:space-between;transition:all .5s}
.site-header.top{background:transparent}
.site-header.scrolled{background:rgba(255,255,255,.96);backdrop-filter:blur(20px);border-bottom:1px solid var(--g1)}
.site-header.solid{background:rgba(255,255,255,.96);backdrop-filter:blur(20px);border-bottom:1px solid var(--g1)}
.logo-img{height:44px;transition:filter .4s}
.site-header.top .logo-img{filter:brightness(0) invert(1)}
.site-header.scrolled .logo-img,.site-header.solid .logo-img{filter:none}
.main-nav{list-style:none;display:flex;gap:32px;align-items:center}
.main-nav li{list-style:none}
.main-nav a{font-size:13px;font-weight:500;letter-spacing:.5px;transition:all .3s;white-space:nowrap}
.site-header.top .main-nav a{color:rgba(255,255,255,.7)}
.site-header.scrolled .main-nav a,.site-header.solid .main-nav a{color:var(--g6)}
.main-nav a:hover{color:var(--cyan)!important}
.nav-job-btn{padding:8px 18px;font-weight:600!important;letter-spacing:.5px!important;font-size:12px!important;border:1px solid var(--cyan);color:var(--cyan)!important;transition:all .3s}
.nav-job-btn:hover{background:var(--cyan);color:var(--w)!important}
.site-header.top .nav-job-btn{border-color:rgba(0,207,255,.6);color:var(--cyan)!important}
.nav-cta-btn{background:var(--cyan);color:var(--w)!important;padding:10px 24px;font-weight:700!important;letter-spacing:.5px!important;font-size:12px!important;transition:all .3s}
.nav-cta-btn:hover{background:var(--g8)}

/* Mobile nav */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;margin:5px 0;background:var(--g8);transition:all .3s}
.site-header.top .nav-toggle span{background:var(--w)}

/* ===== HERO (front page) ===== */
.hero{height:100vh;position:relative;overflow:hidden;display:flex;align-items:center;background:var(--dk)}
.hero-has-bg{background-size:cover;background-position:center;background-repeat:no-repeat}
#particleCanvas{position:absolute;inset:0;z-index:1}
.hero-gradient{position:absolute;inset:0;z-index:0}
.hero-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.4}
.hero-orb-1{width:600px;height:600px;background:rgba(0,207,255,.12);top:-10%;right:-5%;animation:orbFloat 18s ease-in-out infinite}
.hero-orb-2{width:400px;height:400px;background:rgba(126,232,255,.08);bottom:10%;left:5%;animation:orbFloat 22s ease-in-out infinite reverse}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-30px) scale(1.1)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,17,23,.3) 0%,rgba(11,17,23,.1) 40%,rgba(11,17,23,.5) 100%);z-index:2}
.hero-content{position:relative;z-index:3;padding:0 60px}
.hero-tag{display:inline-block;padding:6px 18px;border:1px solid rgba(0,207,255,.4);font-family:'Space Mono',monospace;font-size:10px;color:var(--cyan);letter-spacing:4px;text-transform:uppercase;margin-bottom:32px;opacity:0;animation:fadeUp .7s .2s forwards}
.hero h1{font-size:clamp(48px,8vw,110px);font-weight:900;line-height:1.1;color:var(--w);letter-spacing:6px}
.hero-line{display:block;overflow:hidden}
.hero-line-in{display:block;opacity:0;transform:translateY(110%);animation:revealUp 1s cubic-bezier(.16,1,.3,1) forwards}
.hero-line:nth-child(1) .hero-line-in{animation-delay:.4s}
.hero h1 .cyan{color:var(--cyan)}
.hero-sub{font-size:15px;color:rgba(255,255,255,.45);font-weight:300;letter-spacing:2px;margin-top:24px;opacity:0;animation:fadeUp .7s .9s forwards}
.hero-cta-row{display:flex;gap:16px;margin-top:40px;opacity:0;animation:fadeUp .7s 1.1s forwards}
.hero-btn{padding:18px 48px;font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;transition:all .4s;display:inline-block}
.hero-btn-primary{background:var(--cyan);color:var(--w)}.hero-btn-primary:hover{background:var(--w);color:var(--g8)}
.hero-btn-ghost{border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.7)}.hero-btn-ghost:hover{border-color:var(--cyan);color:var(--cyan)}
.hero-scroll{position:absolute;bottom:32px;left:60px;z-index:4;display:flex;align-items:center;gap:14px;opacity:0;animation:fadeUp .7s 1.5s forwards}
.hero-scroll-line{width:36px;height:1px;background:var(--cyan)}
.hero-scroll-text{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.3)}
@keyframes revealUp{to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ===== JOB BANNER ===== */
.job-banner{display:grid;grid-template-columns:1fr 1fr;gap:0}
.job-banner-card{padding:56px 60px;display:flex;align-items:center;justify-content:space-between;transition:all .4s;cursor:pointer;position:relative;overflow:hidden}
.job-banner-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.job-banner-card:hover::after{transform:scaleX(1)}
.job-banner-biz{background:var(--dk);color:var(--w)}.job-banner-biz:hover{background:#141b24}
.job-banner-stu{background:var(--cyan);color:var(--w)}.job-banner-stu:hover{background:var(--cyan-d)}
.job-banner-text h3{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:3px;text-transform:uppercase;margin-bottom:6px}
.job-banner-text p{font-size:12px;font-weight:300;opacity:.7;letter-spacing:1px}
.job-banner-arrow{font-family:'Bebas Neue',sans-serif;font-size:28px;opacity:.5;transition:all .3s}
.job-banner-card:hover .job-banner-arrow{opacity:1;transform:translateX(6px)}

/* ===== PAGE HERO ===== */
.page-hero{padding:180px 60px 100px;background:var(--dk);position:relative;overflow:hidden}
.page-hero-glow{position:absolute;inset:0;background:radial-gradient(ellipse 50% 50% at 50% 40%,rgba(0,207,255,.06) 0%,transparent 60%)}
.page-hero-content{position:relative;z-index:2}
.page-hero h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(40px,7vw,80px);letter-spacing:4px;color:var(--w);text-transform:uppercase;line-height:1;margin-bottom:12px}
.page-hero h1 .cyan{color:var(--cyan)}
.page-hero-jp{font-size:13px;color:rgba(255,255,255,.35);letter-spacing:4px;font-weight:300}
.page-hero-wave{position:absolute;bottom:-2px;left:0;width:100%;z-index:3}
.page-hero-wave svg{display:block;width:100%;height:80px}

/* ===== SECTIONS ===== */
.sec{padding:120px 60px}
.sec-en{font-family:'Bebas Neue',sans-serif;font-size:clamp(32px,4.5vw,56px);letter-spacing:4px;line-height:1;color:var(--g8);text-transform:uppercase}
.sec-jp{font-size:12px;color:var(--g5);letter-spacing:3px;margin-top:8px;font-weight:300}
.bg-white{background:var(--w)}.bg-snow{background:var(--snow)}.bg-dark{background:var(--dk)}

/* ===== SERVICE CARD ===== */
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:60px}
.srv{display:block;padding:52px 40px;background:var(--snow);border-right:1px solid var(--g1);position:relative;overflow:hidden;transition:all .4s;cursor:pointer;color:inherit;text-decoration:none}
.srv:last-child{border-right:none}
.srv::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.srv:hover::after{transform:scaleX(1)}.srv:hover{background:var(--cyan-p)}
.srv-num{font-family:'Bebas Neue',sans-serif;font-size:48px;color:var(--g1);letter-spacing:2px;margin-bottom:20px;transition:color .4s}
.srv:hover .srv-num{color:rgba(0,207,255,.25)}
.srv h3{font-size:18px;font-weight:700;margin-bottom:14px}.srv p{font-size:13px;color:var(--g5);line-height:2;font-weight:300}
.srv-link{display:inline-flex;align-items:center;gap:8px;margin-top:24px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--cyan-d);font-weight:500;transition:gap .3s}
.srv:hover .srv-link{gap:16px}

/* ===== CEO SECTION ===== */
.ceo-section{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:600px}
.ceo-img{overflow:hidden}
.ceo-img img{width:100%;height:100%;object-fit:cover}
.ceo-text{padding:80px 60px;display:flex;flex-direction:column;justify-content:center;background:var(--dk);color:var(--w)}
.ceo-name{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:4px;margin-top:24px}
.ceo-role{font-family:'Space Mono',monospace;font-size:10px;color:var(--cyan);letter-spacing:3px;text-transform:uppercase;margin-bottom:28px}
.ceo-text blockquote{font-size:14px;color:rgba(255,255,255,.6);line-height:2.2;font-weight:300;font-style:normal;border-left:2px solid var(--cyan);padding-left:20px;margin-bottom:24px}
.ceo-link{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--cyan);display:inline-flex;align-items:center;gap:12px;transition:gap .3s}
.ceo-link:hover{gap:20px}

/* ===== TEAM SLIDER ===== */
.team-slider-wrap{margin-top:60px;overflow:hidden;position:relative}
.team-slider-track{display:flex;animation:teamSlide 30s linear infinite;width:max-content;will-change:transform}
.team-slider-track:hover{animation-play-state:paused}
.team-slider-track.is-paused{animation-play-state:paused}
.team-slider-track.is-dragging{cursor:grabbing;animation-play-state:paused}
@keyframes teamSlide{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.team-slide{min-width:320px;flex-shrink:0;border-right:1px solid var(--g1);transition:background .3s;cursor:pointer;user-select:none}
.team-slide:hover{background:var(--cyan-p)}
.team-slide-photo{aspect-ratio:4/5;overflow:hidden;background:var(--snow)}
.team-slide-photo img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transition:transform .5s;-webkit-user-drag:none;pointer-events:none}
.team-slide:hover .team-slide-photo img{transform:scale(1.05)}
.team-slide-info{padding:24px 28px}
.team-slide-role{font-family:'Space Mono',monospace;font-size:9px;color:var(--cyan);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}
.team-slide-name{font-size:18px;font-weight:700;margin-bottom:4px}
.team-slide-desc{font-size:12px;color:var(--g5);line-height:1.8;font-weight:300;margin-top:8px}
.team-slider-btn{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.95);border:1px solid var(--g1);font-size:24px;font-weight:300;color:var(--g8);cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .25s;box-shadow:0 4px 16px rgba(0,0,0,.08);line-height:1}
.team-slider-btn:hover{background:var(--cyan);color:var(--w);border-color:var(--cyan);box-shadow:0 6px 20px rgba(0,0,0,.15)}
.team-slider-prev{left:16px}
.team-slider-next{right:16px}

/* ===== TEAM PAGE GRID (社員紹介ページ専用) ===== */
.team-page-wrap{padding:80px 60px!important}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:48px;max-width:1100px;margin:0 auto}
.team-card{background:var(--w);border:1px solid var(--g1);overflow:hidden;display:flex;flex-direction:column;transition:all .4s}
.team-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.06);transform:translateY(-4px)}
.team-card-photo{aspect-ratio:4/5;overflow:hidden;background:var(--snow)}
.team-card-photo img{width:100%;height:100%;display:block;object-fit:cover;object-position:center 30%;transition:transform .5s}
.team-card:hover .team-card-photo img{transform:scale(1.04)}
.team-card-body{padding:32px 32px 36px}
.team-card-role{font-family:'Space Mono',monospace;font-size:10px;color:var(--cyan);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:10px}
.team-card-name{font-size:22px;font-weight:700;color:var(--g8);margin-bottom:18px;letter-spacing:.5px}
.team-card-text{font-size:14px;color:var(--g6);line-height:2;font-weight:300}
.team-card-text p{margin-bottom:12px}
.team-card-text p:last-child{margin-bottom:0}
@media(max-width:1024px){
  .team-page-wrap{padding:60px 20px!important}
  .team-grid{grid-template-columns:1fr;gap:32px}
  .team-card-body{padding:24px}
  .team-card-name{font-size:20px}
}

/* ===== CTA BAND ===== */
.cta-band{padding:100px 60px;background:var(--cyan);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'CONTACT';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Bebas Neue',sans-serif;font-size:clamp(100px,15vw,220px);color:rgba(255,255,255,.08);letter-spacing:10px;white-space:nowrap;pointer-events:none}
.cta-band h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(32px,4vw,56px);color:var(--w);letter-spacing:6px;text-transform:uppercase;position:relative;z-index:2}
.cta-band p{color:rgba(255,255,255,.7);font-size:14px;font-weight:300;margin:20px 0 40px;position:relative;z-index:2}
.cta-band-btn{display:inline-block;padding:20px 64px;background:var(--w);color:var(--g8);font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;transition:all .4s;position:relative;z-index:2}
.cta-band-btn:hover{background:var(--dk);color:var(--w)}

/* CTA BAND - LINE 応募版（採用情報ページ専用） */
.cta-band-line{background:#06C755}
.cta-band-line::before{content:'ENTRY'}
.cta-band-line .cta-band-btn-line{background:var(--w);color:#06C755}
.cta-band-line .cta-band-btn-line:hover{background:var(--g8);color:var(--w)}

/* ===== NEWS ROW ===== */
.news-row{display:grid;grid-template-columns:100px 80px 1fr auto;gap:28px;align-items:center;padding:24px 0;border-bottom:1px solid var(--g1);transition:all .3s;cursor:pointer}
.news-row:hover{padding-left:16px}
.news-date{font-family:'Space Mono',monospace;font-size:11px;color:var(--g3)}
.news-tag{font-family:'Space Mono',monospace;font-size:9px;padding:4px 10px;background:rgba(0,207,255,.08);color:var(--cyan);letter-spacing:1px;text-transform:uppercase;text-align:center}
.news-title{font-size:14px;font-weight:300;color:var(--g6);transition:color .3s}
.news-row:hover .news-title{color:var(--g8)}
.news-arrow{font-size:18px;color:var(--g1);transition:all .3s}
.news-row:hover .news-arrow{color:var(--cyan);transform:translateX(4px)}
.view-all{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--g5);display:inline-flex;align-items:center;gap:12px;transition:color .3s}
.view-all:hover{color:var(--cyan)}
.view-all::after{content:'';width:30px;height:1px;background:currentColor;transition:width .3s}
.view-all:hover::after{width:50px}

/* ===== BLOG CARD ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:48px}
.blog-card{overflow:hidden;transition:all .4s;cursor:pointer;display:block;border-right:1px solid var(--g1)}
.blog-card:nth-child(3n){border-right:none}
.blog-card:hover{background:var(--cyan-p)}
.blog-thumb{height:200px;position:relative;overflow:hidden}
.blog-thumb img{width:100%;height:100%;object-fit:cover}
.blog-thumb-tag{position:absolute;top:16px;left:16px;font-family:'Space Mono',monospace;font-size:9px;padding:4px 12px;background:var(--cyan);color:var(--w);letter-spacing:1px;text-transform:uppercase}
.blog-body{padding:24px 24px 28px}
.blog-date{font-family:'Space Mono',monospace;font-size:11px;color:var(--g3);margin-bottom:10px}
.blog-title{font-size:16px;font-weight:500;color:var(--g8);margin-bottom:10px;line-height:1.6}
.blog-excerpt{font-size:12.5px;color:var(--g5);line-height:1.8;font-weight:300}
.blog-read{font-size:11px;color:var(--cyan-d);margin-top:14px;display:inline-block;letter-spacing:2px;text-transform:uppercase}

/* ===== PLACEHOLDER ===== */
.img-placeholder{width:100%;height:100%;min-height:280px;background:linear-gradient(135deg,#0f1a26,#162232);display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-size:12px;color:var(--cyan);letter-spacing:3px;text-transform:uppercase;opacity:.8}

/* ===== FORM ===== */
.contact-form{background:var(--snow);padding:48px;border:1px solid var(--g1)}
.form-group{margin-bottom:24px}
.form-label{display:block;font-size:13px;font-weight:500;color:var(--g8);margin-bottom:8px}
.form-label .req{font-family:'Space Mono',monospace;font-size:9px;color:var(--cyan);margin-left:6px;letter-spacing:1px;text-transform:uppercase}
.form-input,.form-textarea,.form-select{width:100%;padding:14px 18px;border:1px solid var(--g2);font-size:14px;font-family:'Noto Sans JP',sans-serif;color:var(--g8);background:var(--w);transition:border-color .3s;outline:none}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--cyan)}
.form-textarea{min-height:140px;resize:vertical}
.form-select{appearance:none;cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.btn-submit{width:100%;padding:18px;background:var(--cyan);color:var(--w);border:none;font-size:14px;font-weight:700;font-family:'Noto Sans JP',sans-serif;letter-spacing:2px;cursor:pointer;transition:all .4s}
.btn-submit:hover{background:var(--g8)}

/* ===== WP CONTENT ===== */
.wp-content{color:var(--g6);line-height:2.2;font-size:15px;font-weight:300}
.wp-content h2{font-family:'Bebas Neue',sans-serif;font-size:32px;letter-spacing:3px;color:var(--g8);margin:48px 0 16px;text-transform:uppercase}
.wp-content h3{font-size:20px;font-weight:700;color:var(--g8);margin:32px 0 12px}
.wp-content p{margin-bottom:16px}
.wp-content img{margin:24px 0}
.wp-content ul,.wp-content ol{margin:16px 0 16px 24px}

/* ===== FOOTER ===== */
.site-footer{padding:72px 60px 36px;background:var(--dk);color:var(--w)}
.ft-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;margin-bottom:56px}
.ft-logo{height:40px;filter:brightness(0) invert(1);margin-bottom:16px}
.ft-brand p{font-size:12px;color:var(--g5);line-height:1.9;font-weight:300}
.ft-addr{font-size:11px;color:var(--g5);margin-top:14px;line-height:1.9;font-weight:300}
.ft-col h4{font-family:'Noto Sans JP',sans-serif;font-size:13px;font-weight:600;letter-spacing:1px;color:rgba(255,255,255,.55);margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08)}
.ft-col a{display:block;color:rgba(255,255,255,.45);font-size:12px;padding:4px 0;transition:color .3s;font-weight:300}
.ft-col a:hover{color:var(--cyan)}
.ft-btm{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;display:flex;justify-content:space-between;font-size:10px;color:var(--g5);letter-spacing:1px}
.ft-btm a{color:var(--g5);margin-left:20px;transition:color .3s}
.ft-btm a:hover{color:var(--cyan)}
.ft-sns{margin-top:24px}
.ft-sns-label{font-size:10px;color:rgba(255,255,255,.4);letter-spacing:2px;margin-bottom:10px;font-family:'Space Mono',monospace;text-transform:uppercase}
.ft-sns-icons{display:flex;gap:10px}
.ft-sns-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:#fff;border-radius:8px;transition:transform .25s ease, box-shadow .25s ease}
.ft-sns-icon:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.25)}
.ft-sns-icon svg{display:block}

/* ===== PAGINATION ===== */
.pagination .nav-links{display:flex;justify-content:center;gap:8px;margin-top:60px}
.pagination .page-numbers{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid var(--g2);font-family:'Space Mono',monospace;font-size:13px;color:var(--g6);transition:all .3s}
.pagination .page-numbers.current,.pagination .page-numbers:hover{background:var(--cyan);color:var(--w);border-color:var(--cyan)}

/* ===== PAGE CONTENT WIDTH FIX (固定ページのwp-content用) ===== */
.sec .wp-content{max-width:100%!important}
.page .sec{padding:120px 80px!important;max-width:none!important}
.page .sec > *{max-width:none!important}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .site-header{padding:0 20px;height:64px}
  .main-nav{display:none}
  .nav-toggle{display:block}
  .main-nav.active{display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:var(--w);padding:24px;gap:16px;border-bottom:1px solid var(--g1)}
  .main-nav.active a{color:var(--g6)!important;font-size:14px}
  .hero-content{padding:0 20px}.hero-scroll{left:20px}
  .hero h1{font-size:clamp(36px,10vw,70px)}
  .page-hero{padding:140px 20px 80px}
  .sec{padding:80px 20px}
  .srv-grid{grid-template-columns:1fr}.srv{border-right:none;border-bottom:1px solid var(--g1)}
  .ceo-section{grid-template-columns:1fr}.ceo-img{height:300px}.ceo-text{padding:60px 20px}
  /* スマホでは team-slider をグリッドに切り替え */
  .team-slider-wrap{overflow:visible}
  .team-slider-btn{display:none}
  .team-slider-track{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--g1);width:100%;animation:none}
  .team-slide{min-width:0;border-right:none;background:var(--w)}
  .team-slide.is-clone{display:none}
  .team-slide-photo{height:auto;aspect-ratio:4/5}
  .team-slide-info{padding:14px 12px}
  .team-slide-role{font-size:8px;letter-spacing:1.5px;margin-bottom:4px}
  .team-slide-name{font-size:13px;margin-bottom:2px;font-weight:600}
  .team-slide-desc{display:none}
  .blog-grid{grid-template-columns:1fr}.blog-card{border-right:none;border-bottom:1px solid var(--g1)}
  .job-banner{grid-template-columns:1fr}.job-banner-card{padding:40px 20px}
  .cta-band{padding:80px 20px}
  .news-row{grid-template-columns:80px 60px 1fr}.news-arrow{display:none}
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:28px 20px}
  .site-footer{padding:48px 20px 28px}
  .ft-top{grid-template-columns:1fr 1fr;gap:28px}
  /* 固定ページ wp-content 内のレスポンシブ */
  .page .sec{padding:80px 20px!important}
  .sec .wp-content div[style*="grid-template-columns:repeat(3"],
  .sec .wp-content div[style*="grid-template-columns: repeat(3"]{grid-template-columns:1fr!important}
  .sec .wp-content div[style*="grid-template-columns:repeat(4"],
  .sec .wp-content div[style*="grid-template-columns: repeat(4"]{grid-template-columns:1fr!important}
  .sec .wp-content div[style*="grid-template-columns:1fr 1fr"],
  .sec .wp-content div[style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important}
  .sec .wp-content div[style*="grid-template-columns:1fr 1.4fr"],
  .sec .wp-content div[style*="grid-template-columns: 1fr 1.4fr"]{grid-template-columns:1fr!important}
  .sec .wp-content div[style*="grid-template-columns:180px"],
  .sec .wp-content div[style*="grid-template-columns: 180px"]{grid-template-columns:130px 1fr!important}
  .sec .wp-content div[style*="padding:60px"],
  .sec .wp-content div[style*="padding: 60px"]{padding:40px 20px!important}
  .sec .wp-content div[style*="padding:80px"],
  .sec .wp-content div[style*="padding: 80px"]{padding:40px 20px!important}
  .sec .wp-content div[style*="margin:0 -60px"],
  .sec .wp-content div[style*="margin: 0 -60px"]{margin-left:-20px!important;margin-right:-20px!important;padding-left:20px!important;padding-right:20px!important}
  .sec .wp-content div[style*="height:400px"],
  .sec .wp-content div[style*="height: 400px"]{height:250px!important}
  .sec .wp-content div[style*="height:350px"],
  .sec .wp-content div[style*="height: 350px"]{height:250px!important}
  .sec .wp-content div[style*="gap:80px"],
  .sec .wp-content div[style*="gap: 80px"]{gap:32px!important}
}

/* ========================================
   Brand Message Section
   ======================================== */
.brand-msg-sec{padding:140px 24px;background:linear-gradient(135deg,var(--g8) 0%,#1a2530 100%);color:var(--w);position:relative;overflow:hidden}
.brand-msg-sec::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 30% 20%,rgba(0,201,255,.08) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(0,201,255,.05) 0%,transparent 50%);pointer-events:none}
.brand-msg-inner{max-width:1000px;margin:0 auto;text-align:center;position:relative;z-index:1}
.brand-msg-question{font-size:18px;font-weight:300;letter-spacing:.15em;color:var(--cyan);margin-bottom:48px;font-feature-settings:'palt'}
.brand-msg-divider{width:60px;height:1px;background:rgba(255,255,255,.3);margin:0 auto 56px}
.brand-msg-headline{font-size:88px;font-weight:900;letter-spacing:.05em;line-height:1.2;margin-bottom:64px;font-feature-settings:'palt';background:linear-gradient(135deg,#fff 0%,var(--cyan) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.brand-msg-body{font-size:16px;line-height:2.4;font-weight:300;color:rgba(255,255,255,.85);max-width:680px;margin:0 auto;letter-spacing:.05em}

/* ========================================
   Why TRANQUILO Section
   ======================================== */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px}
.why-card{background:var(--w);border:1px solid var(--g1);padding:48px 32px;text-align:center;transition:all .35s;position:relative;overflow:hidden}
.why-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.why-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.08)}
.why-card:hover::before{transform:scaleX(1)}
.why-num{font-family:'Space Mono',monospace;font-size:11px;color:var(--cyan);letter-spacing:3px;margin-bottom:24px}
.why-icon{font-size:42px;margin-bottom:20px;line-height:1}
.why-title{font-size:22px;font-weight:700;color:var(--g8);margin-bottom:20px;line-height:1.4;letter-spacing:.05em}
.why-desc{font-size:13px;color:var(--g6);line-height:2;font-weight:300;text-align:left}

/* Brand Message - Mobile */
@media(max-width:768px){
  .brand-msg-sec{padding:80px 20px}
  .brand-msg-question{font-size:14px;margin-bottom:32px;letter-spacing:.1em}
  .brand-msg-divider{margin-bottom:36px}
  .brand-msg-headline{font-size:48px;margin-bottom:40px;line-height:1.3}
  .brand-msg-body{font-size:14px;line-height:2.2;text-align:left}
  .sp-only{display:inline}
  /* Why grid - 2 columns on mobile */
  .why-grid{grid-template-columns:1fr 1fr;gap:12px;margin-top:40px}
  .why-card{padding:28px 18px}
  .why-icon{font-size:32px}
  .why-title{font-size:16px;margin-bottom:14px}
  .why-desc{font-size:12px;line-height:1.8}
  .why-num{font-size:10px;margin-bottom:14px}
}
@media(min-width:769px){
  .sp-only{display:none}
}
