/* 株式会社〇〇レンタル機工 — Heavy Equipment Rental / Catalog Tile UI */
*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden}
:root{
  --yellow:#ffd400;
  --yellow-2:#ffb800;
  --black:#0a0a0a;
  --black-2:#1a1a1a;
  --black-3:#2a2a2a;
  --white:#ffffff;
  --gray-50:#f7f7f7;
  --gray-100:#f0f0f0;
  --gray-200:#e4e4e4;
  --gray-300:#d4d4d4;
  --gray-500:#737373;
  --gray-700:#3a3a3a;
  --line:rgba(10,10,10,.08);
  --line-2:rgba(10,10,10,.14);
  --stripe:repeating-linear-gradient(135deg,var(--yellow) 0 12px,var(--black) 12px 24px);
}
body{background:var(--white);color:var(--black);font-family:'Inter','Noto Sans JP',sans-serif;font-size:15px;line-height:1.7;-webkit-font-smoothing:antialiased;font-weight:400}
a{color:inherit;text-decoration:none;transition:color .2s}
img{max-width:100%;display:block}
.container{max-width:1440px;margin:0 auto;padding:0 32px}
.mono{font-family:'Roboto Mono',monospace;letter-spacing:.02em}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.reveal.show{opacity:1;transform:translateY(0)}

/* ===== DEMO BAR ===== */
#demo-bar{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,10,10,0.97);backdrop-filter:blur(12px);padding:7px 0;border-bottom:1px solid rgba(255,212,0,.2)}
.demo-bar-inner{display:flex;align-items:center;justify-content:center;gap:10px;font-size:0.7rem;color:rgba(255,255,255,0.4);font-family:'Roboto Mono',monospace}
.demo-badge{font-size:0.54rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;background:rgba(255,212,0,.18);color:var(--yellow);padding:3px 10px}
.demo-link{color:var(--yellow);font-weight:700;text-decoration:underline;text-underline-offset:2px}
.demo-copy{color:rgba(255,255,255,0.18);font-size:0.62rem;margin-left:4px}
@media(max-width:640px){.demo-copy{display:none}}

/* ===== HEADER — 上部固定+検索バー併設 ===== */
.site-header{position:fixed;top:36px;left:0;right:0;z-index:100;background:var(--white);border-bottom:1px solid var(--line)}
.header-top{display:flex;justify-content:space-between;align-items:center;padding:14px 32px;max-width:1600px;margin:0 auto;gap:32px}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo-mark{width:42px;height:42px;background:var(--yellow);color:var(--black);font-family:'Roboto Mono',monospace;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;clip-path:polygon(0 0,100% 0,100% 75%,85% 100%,0 100%)}
.logo-text{display:flex;flex-direction:column;line-height:1.05}
.logo-en{font-family:'Roboto Mono',monospace;font-size:14px;font-weight:700;letter-spacing:.06em;color:var(--black);text-transform:uppercase}
.logo-jp{font-family:'Noto Sans JP',sans-serif;font-size:10px;font-weight:600;color:var(--gray-500);letter-spacing:.14em;margin-top:2px}
.header-nav{display:flex;list-style:none;gap:28px;align-items:center}
.header-nav a{font-family:'Roboto Mono',monospace;font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--black);text-transform:uppercase;padding:8px 0;position:relative;transition:color .2s}
.header-nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--yellow);transition:width .25s}
.header-nav a:hover{color:var(--black)}
.header-nav a:hover::after,.header-nav a.active::after{width:100%}
.header-cta{display:inline-flex;align-items:center;gap:6px;background:var(--yellow);color:var(--black);font-family:'Roboto Mono',monospace;font-size:12px;font-weight:700;letter-spacing:.08em;padding:12px 22px;text-transform:uppercase;transition:all .25s;flex-shrink:0}
.header-cta:hover{background:var(--black);color:var(--yellow)}
.mobile-toggle{display:none;width:48px;height:48px;background:var(--yellow);border:none;cursor:pointer;align-items:center;justify-content:center}
.mobile-toggle span{display:block;width:22px;height:2px;background:var(--black);position:relative}
.mobile-toggle span::before,.mobile-toggle span::after{content:"";position:absolute;width:22px;height:2px;background:var(--black);left:0}
.mobile-toggle span::before{top:-7px}
.mobile-toggle span::after{top:7px}

/* ===== Search Bar (Hero下に常駐風) ===== */
.search-bar{background:var(--gray-100);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.search-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr auto;gap:1px;background:var(--line-2);max-width:1600px;margin:0 auto}
.search-cell{background:var(--gray-100);padding:14px 20px;display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:background .2s;position:relative}
.search-cell:hover{background:var(--white)}
.search-label{font-family:'Roboto Mono',monospace;font-size:9px;font-weight:600;letter-spacing:.16em;color:var(--gray-500);text-transform:uppercase}
.search-value{font-family:'Inter',sans-serif;font-size:14px;font-weight:600;color:var(--black);display:flex;align-items:center;justify-content:space-between;gap:8px}
.search-value::after{content:"▾";font-size:10px;color:var(--gray-500)}
.search-cell:last-child::after{display:none}
.search-btn{background:var(--black);color:var(--yellow);border:none;padding:0 36px;font-family:'Roboto Mono',monospace;font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}
.search-btn:hover{background:var(--yellow);color:var(--black)}

/* ===== HERO — カタログタイル ===== */
.hero{padding:188px 0 0;background:var(--white);min-height:auto}
.hero-head{padding:48px 0 36px;border-bottom:2px solid var(--black)}
.hero-meta{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap}
.hero-meta-left{flex:1;min-width:280px}
.hero-tag{display:inline-flex;align-items:center;gap:10px;font-family:'Roboto Mono',monospace;font-size:11px;font-weight:600;letter-spacing:.18em;color:var(--gray-500);text-transform:uppercase;margin-bottom:18px}
.hero-tag::before{content:"";width:32px;height:2px;background:var(--yellow)}
.hero h1{font-family:'Roboto Mono',monospace;font-size:clamp(44px,8vw,118px);line-height:.95;letter-spacing:-.02em;font-weight:700;color:var(--black);text-transform:uppercase}
.hero h1 em{font-style:normal;color:var(--black);background:var(--yellow);padding:0 .12em;display:inline-block}
.hero-jp{font-family:'Noto Sans JP',sans-serif;font-size:clamp(20px,2.6vw,32px);font-weight:700;color:var(--black);margin-top:18px;letter-spacing:.02em}
.hero-meta-right{flex:0 0 auto;text-align:right}
.hero-meta-row{font-family:'Roboto Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--gray-500);text-transform:uppercase;line-height:1.9}
.hero-meta-row strong{color:var(--black);font-weight:700}

/* Hero下*/
.catalog-tiles{padding:32px 0 80px;background:var(--white)}
.catalog-tiles-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}
.catalog-title{font-family:'Roboto Mono',monospace;font-size:14px;font-weight:700;letter-spacing:.16em;color:var(--black);text-transform:uppercase;display:flex;align-items:center;gap:12px}
.catalog-title::before{content:"//";color:var(--yellow);font-weight:700}
.catalog-meta{font-family:'Roboto Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--gray-500);text-transform:uppercase}
.catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat-tile{background:var(--white);border:1px solid var(--line-2);overflow:hidden;cursor:pointer;transition:all .35s cubic-bezier(.2,.8,.2,1);position:relative;perspective:1000px}
.cat-tile-inner{display:block;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.cat-tile:hover .cat-tile-inner{transform:rotateY(2deg) translateY(-3px)}
.cat-tile:hover{border-color:var(--yellow);box-shadow:0 14px 40px -16px rgba(10,10,10,.4)}
.cat-tile-img{aspect-ratio:4/3;background:var(--gray-100) center/cover;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.cat-tile-img::after{content:attr(data-cat);position:absolute;top:14px;left:14px;background:var(--yellow);color:var(--black);font-family:'Roboto Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.12em;padding:5px 10px;text-transform:uppercase}
.cat-tile-body{padding:20px 22px;display:flex;flex-direction:column;gap:10px}
.cat-tile-name{font-family:'Inter',sans-serif;font-size:17px;font-weight:700;color:var(--black);letter-spacing:.01em}
.cat-tile-spec{font-family:'Roboto Mono',monospace;font-size:11px;color:var(--gray-500);letter-spacing:.04em}
.cat-tile-price{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid var(--line);padding-top:14px;margin-top:auto}
.cat-tile-price-label{font-family:'Roboto Mono',monospace;font-size:9px;letter-spacing:.16em;color:var(--gray-500);text-transform:uppercase}
.cat-tile-price-value{font-family:'Roboto Mono',monospace;font-size:20px;font-weight:700;color:var(--black);letter-spacing:.01em}
.cat-tile-price-value span{font-size:12px;color:var(--gray-500);margin-left:2px}

@media(max-width:980px){
  .header-top{padding:12px 20px;gap:16px}
  .header-nav{display:none}
  .header-cta{display:none}
  .mobile-toggle{display:flex}
  .header-nav.is-open{display:flex;position:fixed;inset:0;background:var(--white);z-index:1000;flex-direction:column;align-items:center;justify-content:center;gap:32px;padding:80px 24px}
  .header-nav.is-open a{font-family:'Roboto Mono',monospace;font-size:20px;letter-spacing:.08em;padding:12px 0}
  .site-header.menu-active{background:var(--white)!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  /* 検索バー：タブレット幅では2カラム+ボタンで圧縮 */
  .search-bar{padding:0}
  .search-inner{grid-template-columns:1fr 1fr;gap:1px}
  .search-cell{padding:12px 16px}
  .search-btn{grid-column:span 2;padding:16px 24px;justify-content:center}
  .catalog-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .hero-meta{flex-direction:column;align-items:flex-start}
  .hero-meta-right{text-align:left}
}
@media(max-width:640px){
  .catalog-grid{grid-template-columns:1fr}
  .hero{padding:160px 0 0}
  .container{padding:0 20px}

  /* 🔴 スマホでは装飾的な検索バー(機能なし)を、カタログへCTAバーに置き換え */
  .search-bar{background:var(--black);border:none;padding:0}
  .search-inner{display:block;grid-template-columns:none;background:transparent;max-width:none;margin:0}
  .search-cell{display:none}
  .search-btn{display:flex;width:100%;grid-column:auto;padding:16px 22px;background:var(--yellow);color:var(--black);font-size:0;justify-content:center;align-items:center;border-top:2px solid var(--black);border-bottom:2px solid var(--black);position:relative}
  .search-btn::before{content:"▼ カタログから機材を探す";font-family:'Inter','Noto Sans JP',sans-serif;font-size:14px;font-weight:700;letter-spacing:.04em;color:var(--black)}
  .search-btn::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:6px;background:repeating-linear-gradient(135deg, var(--yellow) 0 8px, var(--black) 8px 16px);opacity:.85}
  .search-btn:hover{background:var(--black);color:var(--yellow)}
  .search-btn:hover::before{color:var(--yellow)}
}

/* ===== STRIPE BAR (区切り装飾) ===== */
.stripe-bar{height:14px;background:var(--stripe)}

/* ===== ABOUT ===== */
.about-section{padding:120px 0;background:var(--gray-50)}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.about-img{aspect-ratio:4/5;background:var(--gray-200) center/cover;border:1px solid var(--line-2);position:relative}
.about-img::after{content:"01 / ABOUT";position:absolute;left:-1px;bottom:-1px;background:var(--yellow);color:var(--black);font-family:'Roboto Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.16em;padding:8px 16px}
.section-label{font-family:'Roboto Mono',monospace;font-size:11px;font-weight:600;letter-spacing:.2em;color:var(--gray-500);text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.section-label::before{content:"";width:24px;height:2px;background:var(--yellow)}
.section-title{font-family:'Roboto Mono',monospace;font-size:clamp(30px,4.5vw,52px);font-weight:700;color:var(--black);line-height:1.05;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:24px}
.section-title em{font-style:normal;background:var(--yellow);padding:0 .1em}
.section-jp{font-family:'Noto Sans JP',sans-serif;font-size:clamp(18px,2.2vw,26px);font-weight:700;color:var(--black);margin-bottom:28px}
.about-lead{font-size:15px;line-height:1.95;color:var(--gray-700);margin-bottom:24px}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);margin-top:32px}
.about-stat{padding:20px 0;border-right:1px solid var(--line);text-align:left}
.about-stat:last-child{border-right:none}
.about-stat-num{font-family:'Roboto Mono',monospace;font-size:32px;font-weight:700;color:var(--black);line-height:1;letter-spacing:-.02em}
.about-stat-num em{font-style:normal;color:var(--yellow-2);font-size:18px}
.about-stat-label{font-family:'Roboto Mono',monospace;font-size:10px;letter-spacing:.16em;color:var(--gray-500);text-transform:uppercase;margin-top:8px}

@media(max-width:900px){
  .about-grid{grid-template-columns:1fr;gap:48px}
  .about-section{padding:80px 0}
}

/* ===== SERVICE — Tile Grid ===== */
.service-section{padding:120px 0;background:var(--white)}
.service-head{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;margin-bottom:56px;align-items:flex-end}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line-2)}
.service-card{padding:36px 32px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:all .35s cubic-bezier(.2,.8,.2,1);cursor:pointer;background:var(--white);position:relative;overflow:hidden}
.service-card:nth-child(3n){border-right:none}
.service-card:nth-last-child(-n+3){border-bottom:none}
.service-card:hover{background:var(--yellow)}
.service-card:hover .service-num{color:var(--black)}
.service-num{font-family:'Roboto Mono',monospace;font-size:13px;font-weight:700;letter-spacing:.16em;color:var(--gray-500);margin-bottom:18px;transition:color .25s}
.service-icon{width:54px;height:54px;background:var(--gray-100);display:flex;align-items:center;justify-content:center;font-family:'Roboto Mono',monospace;font-size:22px;font-weight:700;color:var(--black);margin-bottom:24px;transition:background .25s}
.service-card:hover .service-icon{background:var(--white)}
.service-name{font-family:'Inter',sans-serif;font-size:19px;font-weight:700;color:var(--black);letter-spacing:.01em;margin-bottom:10px}
.service-jp{font-family:'Noto Sans JP',sans-serif;font-size:13px;font-weight:600;color:var(--gray-500);margin-bottom:14px}
.service-desc{font-size:14px;color:var(--gray-700);line-height:1.85;margin-bottom:18px}
.service-spec{display:flex;flex-direction:column;gap:6px;padding-top:18px;border-top:1px solid var(--line);font-family:'Roboto Mono',monospace;font-size:11px;color:var(--gray-500);letter-spacing:.04em}
.service-spec span{display:flex;justify-content:space-between}
.service-spec strong{color:var(--black);font-weight:700}

@media(max-width:900px){
  .service-head{grid-template-columns:1fr;gap:24px}
  .service-grid{grid-template-columns:1fr}
  .service-card{border-right:none!important;border-bottom:1px solid var(--line)!important}
  .service-card:last-child{border-bottom:none!important}
  .service-section{padding:80px 0}
}

/* ===== WORKS — Card grid ===== */
.works-section{padding:120px 0;background:var(--black);color:var(--white)}
.works-section .section-title{color:var(--white)}
.works-section .section-title em{color:var(--black)}
.works-section .section-label{color:rgba(255,255,255,.5)}
.works-head{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;margin-bottom:56px;align-items:flex-end}
.works-lead{font-size:15px;line-height:1.95;color:rgba(255,255,255,.7)}
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.work-card{background:var(--black-2);border:1px solid rgba(255,255,255,.08);overflow:hidden;cursor:pointer;transition:all .35s cubic-bezier(.2,.8,.2,1);transform-style:preserve-3d}
.work-card:hover{border-color:var(--yellow);transform:translateY(-4px)}
.work-img{aspect-ratio:3/2;background:var(--black-3) center/cover;position:relative;overflow:hidden}
.work-img::after{content:attr(data-num);position:absolute;top:16px;left:16px;background:var(--yellow);color:var(--black);font-family:'Roboto Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.12em;padding:5px 11px}
.work-body{padding:24px}
.work-cat{font-family:'Roboto Mono',monospace;font-size:10px;letter-spacing:.18em;color:var(--yellow);text-transform:uppercase;margin-bottom:10px}
.work-title{font-family:'Inter',sans-serif;font-size:18px;font-weight:700;color:var(--white);margin-bottom:8px;line-height:1.4}
.work-desc{font-size:13px;color:rgba(255,255,255,.55);line-height:1.7}
.work-meta{display:flex;justify-content:space-between;margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);font-family:'Roboto Mono',monospace;font-size:10px;letter-spacing:.12em;color:rgba(255,255,255,.5);text-transform:uppercase}

@media(max-width:900px){
  .works-head{grid-template-columns:1fr;gap:24px}
  .works-grid{grid-template-columns:1fr;gap:16px}
  .works-section{padding:80px 0}
}

/* ===== NEWS — 上部寄り配置 ===== */
.news-section{padding:90px 0;background:var(--gray-50);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.news-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:32px;flex-wrap:wrap;gap:16px}
.news-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line-2)}
.news-item{display:grid;grid-template-columns:140px 110px 1fr auto;gap:24px;padding:22px 8px;border-bottom:1px solid var(--line);align-items:center;transition:all .25s;cursor:pointer}
.news-item:hover{background:var(--white);padding-left:18px}
.news-item:hover .news-arrow{color:var(--yellow);transform:translateX(4px)}
.news-date{font-family:'Roboto Mono',monospace;font-size:12px;letter-spacing:.06em;color:var(--gray-500)}
.news-cat{display:inline-block;font-family:'Roboto Mono',monospace;font-size:10px;letter-spacing:.14em;color:var(--black);background:var(--yellow);padding:4px 10px;text-transform:uppercase;font-weight:700;text-align:center;justify-self:start}
.news-title-text{font-size:14px;color:var(--black);font-weight:500;line-height:1.6}
.news-arrow{font-family:'Roboto Mono',monospace;font-size:14px;color:var(--gray-500);transition:all .25s}
.news-more{display:inline-flex;align-items:center;gap:8px;font-family:'Roboto Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.16em;color:var(--black);text-transform:uppercase;padding:14px 26px;border:1px solid var(--black);transition:all .25s;margin-top:24px}
.news-more:hover{background:var(--yellow);border-color:var(--yellow)}

@media(max-width:760px){
  .news-item{grid-template-columns:1fr;gap:8px;padding:18px 8px}
  .news-cat{justify-self:start}
}

/* ===== CTA Block ===== */
.cta-block{padding:100px 0;background:var(--yellow);position:relative;overflow:hidden}
.cta-block::before{content:"";position:absolute;left:0;right:0;top:0;height:14px;background:repeating-linear-gradient(135deg,var(--black) 0 12px,transparent 12px 24px)}
.cta-block::after{content:"";position:absolute;left:0;right:0;bottom:0;height:14px;background:repeating-linear-gradient(135deg,var(--black) 0 12px,transparent 12px 24px)}
.cta-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.cta-title{font-family:'Roboto Mono',monospace;font-size:clamp(32px,4.5vw,56px);line-height:1;font-weight:700;color:var(--black);text-transform:uppercase;letter-spacing:-.01em}
.cta-jp{font-family:'Noto Sans JP',sans-serif;font-size:clamp(18px,2vw,24px);font-weight:700;color:var(--black);margin-top:18px;line-height:1.6}
.cta-actions{display:flex;flex-direction:column;gap:14px}
.btn{display:inline-flex;align-items:center;justify-content:space-between;gap:24px;padding:22px 28px;font-family:'Roboto Mono',monospace;font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border:none;cursor:pointer;transition:all .25s;width:100%;max-width:380px}
.btn-primary{background:var(--black);color:var(--yellow)}
.btn-primary:hover{background:var(--white);color:var(--black)}
.btn-outline{background:transparent;color:var(--black);border:2px solid var(--black)}
.btn-outline:hover{background:var(--black);color:var(--yellow)}
.btn .arrow{font-family:'Roboto Mono',monospace}

@media(max-width:900px){
  .cta-grid{grid-template-columns:1fr;gap:32px}
  .cta-block{padding:72px 0}
}

/* ===== FOOTER ===== */
footer.site-footer{background:var(--black);color:rgba(255,255,255,.7);padding:80px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
.footer-logo{font-family:'Roboto Mono',monospace;font-size:18px;font-weight:700;color:var(--white);letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
.footer-jp{font-family:'Noto Sans JP',sans-serif;font-size:11px;color:rgba(255,255,255,.5);margin-bottom:18px;letter-spacing:.08em}
.footer-desc{font-size:13px;line-height:1.85;color:rgba(255,255,255,.55);max-width:340px}
.footer-section h4{font-family:'Roboto Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.18em;color:var(--yellow);text-transform:uppercase;margin-bottom:18px}
.footer-section ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-section a{font-size:13px;color:rgba(255,255,255,.6);transition:color .2s}
.footer-section a:hover{color:var(--yellow)}
.footer-info{font-family:'Roboto Mono',monospace;font-size:11px;letter-spacing:.04em;color:rgba(255,255,255,.5);line-height:2}
.footer-info strong{color:var(--white);font-weight:700}
.footer-bottom{padding-top:28px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-family:'Roboto Mono',monospace;font-size:10px;letter-spacing:.12em;color:rgba(255,255,255,.4);text-transform:uppercase}
.footer-bottom .links{display:flex;gap:20px}
.footer-bottom a:hover{color:var(--yellow)}

@media(max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:560px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}

/* ===== Page Hero (sub pages) ===== */
.page-hero{padding:200px 0 80px;background:var(--gray-50);border-bottom:1px solid var(--line)}
.page-hero h1{font-family:'Roboto Mono',monospace;font-size:clamp(48px,7vw,96px);line-height:.95;font-weight:700;color:var(--black);text-transform:uppercase;letter-spacing:-.02em}
.page-hero h1 em{font-style:normal;background:var(--yellow);padding:0 .12em}
.page-hero-jp{font-family:'Noto Sans JP',sans-serif;font-size:clamp(16px,2vw,22px);font-weight:700;color:var(--gray-700);margin-top:14px}
.page-crumbs{font-family:'Roboto Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--gray-500);text-transform:uppercase;margin-bottom:20px}
.page-crumbs a{color:var(--gray-500);transition:color .2s}
.page-crumbs a:hover{color:var(--black)}
.page-crumbs span{margin:0 10px;color:var(--yellow-2)}

/* ===== About page sub ===== */
.about-detail{padding:100px 0;background:var(--white)}
.about-msg{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;margin-bottom:90px;align-items:flex-start}
.about-msg-img{aspect-ratio:3/4;background:var(--gray-200) center/cover;border:1px solid var(--line-2)}
.about-msg-body{padding-top:8px}
.about-msg p{font-size:15px;line-height:1.95;color:var(--gray-700);margin-bottom:18px}
.about-msg .signature{font-family:'Roboto Mono',monospace;font-size:13px;letter-spacing:.06em;color:var(--black);font-weight:700;margin-top:24px}

/* History / Timeline */
.history-list{margin-top:48px;border-top:1px solid var(--line-2)}
.history-item{display:grid;grid-template-columns:160px 1fr;gap:24px;padding:24px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.history-year{font-family:'Roboto Mono',monospace;font-size:18px;font-weight:700;color:var(--black);letter-spacing:.04em}
.history-text{font-size:14px;color:var(--gray-700);line-height:1.85}

/* Company Info Table */
.info-table{width:100%;border-top:2px solid var(--black);margin-top:32px}
.info-table tr{border-bottom:1px solid var(--line)}
.info-table th{text-align:left;padding:18px 0;width:200px;font-family:'Roboto Mono',monospace;font-size:11px;font-weight:600;letter-spacing:.12em;color:var(--gray-500);text-transform:uppercase;vertical-align:top}
.info-table td{padding:18px 0;font-size:14px;color:var(--black);line-height:1.7}

@media(max-width:760px){
  .about-msg{grid-template-columns:1fr;gap:32px}
  .history-item{grid-template-columns:90px 1fr;gap:14px}
  .info-table th{width:120px;font-size:10px}
}

/* ===== Process ===== */
.process-section{padding:100px 0;background:var(--gray-50)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line-2);background:var(--white)}
.process-step{padding:36px 28px;border-right:1px solid var(--line);position:relative}
.process-step:last-child{border-right:none}
.process-num{font-family:'Roboto Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.16em;color:var(--gray-500);text-transform:uppercase;margin-bottom:14px}
.process-num em{font-style:normal;color:var(--yellow-2);font-size:14px;background:var(--black);padding:2px 8px;margin-right:8px;font-weight:700}
.process-step h4{font-family:'Inter',sans-serif;font-size:17px;font-weight:700;color:var(--black);margin-bottom:10px}
.process-step p{font-size:13px;color:var(--gray-700);line-height:1.8}
@media(max-width:900px){
  .process-grid{grid-template-columns:1fr}
  .process-step{border-right:none;border-bottom:1px solid var(--line)}
  .process-step:last-child{border-bottom:none}
}

/* ===== Recruit ===== */
.recruit-jobs{padding:90px 0;background:var(--white)}
.job-card{display:grid;grid-template-columns:200px 1fr auto;gap:32px;padding:32px;border:1px solid var(--line-2);margin-bottom:18px;align-items:center;transition:all .25s;cursor:pointer}
.job-card:hover{border-color:var(--yellow);background:var(--gray-50)}
.job-tag{font-family:'Roboto Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--gray-500);text-transform:uppercase;font-weight:600}
.job-tag em{font-style:normal;background:var(--yellow);color:var(--black);padding:4px 10px;margin-bottom:8px;display:inline-block;font-weight:700}
.job-name{font-family:'Inter',sans-serif;font-size:19px;font-weight:700;color:var(--black);margin-bottom:8px}
.job-summary{font-size:13px;color:var(--gray-700);line-height:1.8}
.job-arrow{font-family:'Roboto Mono',monospace;font-size:24px;color:var(--gray-500);transition:all .25s}
.job-card:hover .job-arrow{color:var(--yellow-2);transform:translateX(4px)}

@media(max-width:760px){
  .job-card{grid-template-columns:1fr;gap:14px;padding:24px}
}

/* Benefits / Persona */
.persona-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
.persona-card{padding:32px;background:var(--white);border:1px solid var(--line-2);text-align:left}
.persona-num{font-family:'Roboto Mono',monospace;font-size:42px;font-weight:700;color:var(--yellow-2);line-height:1;margin-bottom:14px;letter-spacing:-.02em}
.persona-card h4{font-family:'Inter',sans-serif;font-size:17px;font-weight:700;color:var(--black);margin-bottom:10px}
.persona-card p{font-size:13px;color:var(--gray-700);line-height:1.85}

@media(max-width:900px){.persona-grid{grid-template-columns:1fr}}

/* ===== Contact ===== */
.contact-section{padding:100px 0;background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:flex-start}
.contact-info-block{background:var(--gray-50);padding:36px;border-left:4px solid var(--yellow)}
.contact-info-block h3{font-family:'Roboto Mono',monospace;font-size:14px;font-weight:700;letter-spacing:.16em;color:var(--black);text-transform:uppercase;margin-bottom:18px}
.contact-info-block dl{display:grid;grid-template-columns:80px 1fr;gap:14px 16px;font-size:13px;line-height:1.7}
.contact-info-block dt{font-family:'Roboto Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.16em;color:var(--gray-500);text-transform:uppercase;padding-top:3px}
.contact-info-block dd{color:var(--black)}
.contact-info-block dd strong{font-weight:700;font-size:18px;font-family:'Roboto Mono',monospace;letter-spacing:.02em}
.contact-form{display:flex;flex-direction:column;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-family:'Roboto Mono',monospace;font-size:11px;font-weight:600;letter-spacing:.16em;color:var(--gray-500);text-transform:uppercase}
.form-group label em{font-style:normal;color:var(--yellow-2);background:var(--black);padding:1px 6px;font-size:10px;margin-left:6px;font-weight:700}
.form-group input,.form-group select,.form-group textarea{padding:14px 16px;border:1px solid var(--line-2);background:var(--white);font-family:'Inter',sans-serif;font-size:14px;color:var(--black);transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--yellow);outline:none}
.form-group textarea{min-height:140px;resize:vertical;font-family:'Inter',sans-serif}
.contact-form .btn{margin-top:8px;max-width:none}

@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .form-row{grid-template-columns:1fr}
}

/* ===== Privacy / Article ===== */
.article{padding:80px 0 100px;background:var(--white)}
.article-body{max-width:820px;margin:0 auto}
.article-body h2{font-family:'Roboto Mono',monospace;font-size:18px;font-weight:700;letter-spacing:.06em;color:var(--black);text-transform:uppercase;margin:36px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--yellow)}
.article-body h3{font-family:'Inter',sans-serif;font-size:16px;font-weight:700;color:var(--black);margin:24px 0 10px}
.article-body p{font-size:14.5px;line-height:1.95;color:var(--gray-700);margin-bottom:16px}
.article-body ul{margin:14px 0 14px 24px}
.article-body li{font-size:14px;line-height:1.95;color:var(--gray-700)}
.article-meta{font-family:'Roboto Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--gray-500);text-transform:uppercase;margin-bottom:32px}

/* ===== Tile stagger (initial) ===== */
.cat-tile{opacity:0;transform:translateY(30px) rotateY(-6deg);transform-origin:left top;transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1)}
.cat-tile.show{opacity:1;transform:translateY(0) rotateY(0)}
.cat-tile.show:nth-child(1){transition-delay:.05s}
.cat-tile.show:nth-child(2){transition-delay:.12s}
.cat-tile.show:nth-child(3){transition-delay:.19s}
.cat-tile.show:nth-child(4){transition-delay:.26s}
.cat-tile.show:nth-child(5){transition-delay:.33s}
.cat-tile.show:nth-child(6){transition-delay:.4s}
.work-card{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.work-card.show{opacity:1;transform:translateY(0)}
.work-card.show:nth-child(1){transition-delay:.06s}
.work-card.show:nth-child(2){transition-delay:.14s}
.work-card.show:nth-child(3){transition-delay:.22s}
.work-card.show:nth-child(4){transition-delay:.3s}
.work-card.show:nth-child(5){transition-delay:.38s}
.work-card.show:nth-child(6){transition-delay:.46s}
.service-card{opacity:0;transform:translateY(20px);transition:opacity .65s ease,transform .65s ease,background .25s,color .25s}
.service-card.show{opacity:1;transform:translateY(0)}
.service-card.show:nth-child(1){transition-delay:.05s}
.service-card.show:nth-child(2){transition-delay:.12s}
.service-card.show:nth-child(3){transition-delay:.19s}
.service-card.show:nth-child(4){transition-delay:.26s}
.service-card.show:nth-child(5){transition-delay:.33s}
.service-card.show:nth-child(6){transition-delay:.4s}

.force-anim-end .reveal,.force-anim-end .cat-tile,.force-anim-end .work-card,.force-anim-end .service-card{opacity:1!important;transform:none!important}


/* ====================================================
   Visual safety override (2026-05-04 一括強制表示化)
   feedback_pre_upload_visual_check ルール準拠
   JS未発火時/画像非表示を防ぐため、すべての
   reveal系クラスを初期表示OKに強制
==================================================== */
.reveal, .reveal-up, .reveal-fade, .reveal-clip, .reveal-noren,
.scrub-item, .reveal-left, .reveal-right { 
  opacity: 1 !important; 
  transform: none !important; 
  clip-path: inset(0 0 0% 0) !important;
  -webkit-clip-path: inset(0 0 0% 0) !important;
}



/* ====================================================
   スマホ時 contact フォーム強制1カラム化（2026-05-05）
   2カラム表示で入力欄が狭くなる問題
==================================================== */
@media (max-width: 767px) {
    .form-row,
    .form-grid,
    .form-2col,
    .form-pair,
    .input-row,
    .input-grid,
    [class*="form-row"],
    [class*="form-grid"],
    [class*="two-col"] {
        display: block !important;
        grid-template-columns: 1fr !important;
    }
    form input[type="text"],
    form input[type="email"],
    form input[type="tel"],
    form input[type="number"],
    form textarea,
    form select,
    .form-row > input,
    .form-row > textarea,
    .form-row > select,
    .form-row > div,
    .form-grid > * {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
    }
    .form-row, .form-grid {
        margin-bottom: 1rem;
    }
}



/* ====================================================
   contact 1カラム化 強化版（2026-05-05・全クラス網羅）
==================================================== */
@media (max-width: 767px) {
    .contact-grid,
    .contact-form,
    .ct-grid,
    .ct-form,
    .booking-form,
    .reserve-form,
    .form-card,
    .form-wrap,
    .form-box,
    [class*="contact-grid"],
    [class*="contact-form"],
    [class*="ct-grid"],
    [class*="ct-form"] {
        display: block !important;
        grid-template-columns: 1fr !important;
    }
    .contact-grid > *,
    .contact-form > *,
    .ct-grid > *,
    .ct-form > *,
    .booking-form > *,
    .reserve-form > *,
    .form-card > *,
    .form-wrap > *,
    .form-box > * {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
    }
    .ct-budget-grid,
    .ct-field {
        grid-template-columns: 1fr !important;
        display: block !important;
    }
}

/* ====================================================
   横スクロール防止（2026-05-14 一括追加）
   CLAUDE.md ルール「html/body 両方に overflow-x:hidden」準拠
==================================================== */
html { overflow-x: hidden; }
body { overflow-x: hidden; }

/* ====================================================
   スマホ時 2カラム→1カラム化（2026-05-15）
   右文章が縦長になる時
==================================================== */
@media (max-width: 768px) {
  .form-row { grid-template-columns: 1fr !important; gap: 24px !important; }
  .search-inner { grid-template-columns: 1fr !important; gap: 24px !important; }
}

/* ====================================================
   多カラムgrid スマホ最適化（2026-05-15 千尋）
==================================================== */
@media (max-width: 768px) {
  /* 2カラム化（情報密度を保つ） */
  .about-stats { grid-template-columns: repeat(2, 1fr) !important; gap: 18px !important; }
  .service-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 18px !important; }
  .works-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 18px !important; }
}

/* ====================================================
   process-grid（4STEPS）スマホ1カラム化（2026-05-16 一括追加）
==================================================== */
@media(max-width:640px){
  .process-grid{grid-template-columns:1fr !important;margin-top:32px}
  .process-step{padding:26px 20px;border-right:none !important;border-bottom:1px solid var(--line) !important}
  .process-step:nth-child(2){border-right:none !important;border-bottom:1px solid var(--line) !important}
  .process-step:last-child{border-bottom:none !important}
  .process-step .step-num{margin-bottom:14px}
  .process-step h4{font-size:22px;margin-bottom:10px}
  .process-step p{font-size:13px;line-height:1.78}
}
