/* =========================================================
   ZEST JAPAN 建設 — Plan 4  (Black × Brass / Luxury Corporate)
   Designed for premium corporate architecture firm
   ========================================================= */

:root{
  --c-black:#0a0a0a;
  --c-black-d:#050505;
  --c-charcoal:#161616;
  --c-charcoal-l:#1f1f1f;
  --c-gold:#b8965e;
  --c-gold-l:#d4b378;
  --c-gold-d:#7b6232;
  --c-gold-dim:#a08552;
  --c-ivory:#f2ebdd;
  --c-ivory-d:#e0d5b9;
  --c-text:#cfc6b0;
  --c-text-l:#8e8775;
  --c-text-dim:#65604f;
  --c-line:#262420;
  --c-line-l:#332f28;
  --c-line-gold:rgba(184,150,94,.22);
  --font-min:'Cormorant Garamond','Shippori Mincho','Noto Serif JP','Hiragino Mincho ProN',serif;
  --font-jp:'Noto Serif JP','Shippori Mincho','Hiragino Mincho ProN',serif;
  --font-en:'Cormorant Garamond','Times New Roman',serif;
  --font-sans:'Jost','Helvetica Neue','Hiragino Sans',sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
html{scroll-behavior:smooth;font-size:16px;background:var(--c-black)}
body{font-family:var(--font-jp);color:var(--c-text);background:var(--c-black);line-height:2;font-weight:400;overflow-x:hidden;letter-spacing:.08em;font-feature-settings:"palt"}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .4s,opacity .4s,border-color .4s,background .4s}
a:hover{opacity:.8}
.min{font-family:var(--font-min)}
.en{font-family:var(--font-en)}
.sans{font-family:var(--font-sans)}

::selection{background:var(--c-gold);color:var(--c-black)}

/* =====================================================
   Topbar (info strip)
   ===================================================== */
.topbar{background:var(--c-black-d);color:var(--c-text-l);font-family:var(--font-en);font-size:11px;letter-spacing:.35em;text-align:center;padding:9px 24px;border-bottom:1px solid var(--c-line);font-weight:400}
.topbar span{display:inline-block}
.topbar em{font-style:normal;color:var(--c-gold);margin:0 14px}
@media(max-width:768px){.topbar{font-size:9px;letter-spacing:.2em;padding:8px 12px}.topbar em{margin:0 8px}}

/* =====================================================
   Global Nav (固定上部)
   ===================================================== */
.gnav{position:fixed;top:0;left:0;right:0;z-index:120;background:rgba(8,8,8,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--c-line);transition:background .4s}
.gnav-inner{max-width:1480px;margin:0 auto;padding:0 60px;display:flex;align-items:center;justify-content:space-between;gap:40px;height:72px}
.gnav-brand{display:flex;flex-direction:column;line-height:1.25;flex-shrink:0}
.gnav-brand .name{font-family:var(--font-min);font-weight:600;font-size:18px;letter-spacing:.18em;color:var(--c-ivory)}
.gnav-brand .name em{font-style:normal;color:var(--c-gold);font-weight:500;margin-left:6px;font-size:.7em;letter-spacing:.25em}
.gnav-brand .tag{font-family:var(--font-en);font-size:10px;color:var(--c-gold);letter-spacing:.4em;margin-top:3px;font-weight:400}
.gnav-list{display:flex;align-items:center;gap:32px}
.gnav-list a{font-family:var(--font-min);font-size:13px;font-weight:500;color:var(--c-ivory);letter-spacing:.18em;padding:8px 0;position:relative;display:inline-flex;flex-direction:column;align-items:center;gap:4px}
.gnav-list a small{display:block;font-family:var(--font-en);font-size:9px;color:var(--c-text-dim);letter-spacing:.25em;font-weight:400;text-transform:uppercase;transition:color .4s}
.gnav-list a::after{content:"";position:absolute;left:50%;bottom:-2px;width:0;height:1px;background:var(--c-gold);transition:all .45s ease;transform:translateX(-50%)}
.gnav-list a:hover{opacity:1;color:var(--c-gold)}
.gnav-list a:hover small{color:var(--c-gold-d)}
.gnav-list a:hover::after{width:32px}
.gnav-list a.is-current{color:var(--c-gold)}
.gnav-list a.is-current small{color:var(--c-gold-d)}
.gnav-list a.is-current::after{width:32px;background:var(--c-gold)}
.gnav-cta{font-family:var(--font-min);font-size:13px;color:var(--c-gold);letter-spacing:.18em;padding:12px 28px;border:1px solid var(--c-gold);background:transparent;font-weight:500;transition:all .4s;flex-shrink:0}
.gnav-cta:hover{background:var(--c-gold);color:var(--c-black);opacity:1}

/* ---- Hamburger button (3-line, brass) ---- */
.gnav-toggle{display:none;position:relative;width:42px;height:42px;background:transparent;border:1px solid var(--c-line-gold);cursor:pointer;padding:0;z-index:200;transition:border-color .4s,background .4s}
.gnav-toggle:hover{border-color:var(--c-gold);background:rgba(184,150,94,.06)}
.gnav-toggle span{display:block;position:absolute;left:50%;width:18px;height:1px;background:var(--c-gold);transform:translateX(-50%);transition:transform .45s cubic-bezier(.77,0,.18,1),top .35s ease,opacity .25s ease}
.gnav-toggle span:nth-child(1){top:14px}
.gnav-toggle span:nth-child(2){top:20px}
.gnav-toggle span:nth-child(3){top:26px}
.gnav-toggle.is-open{border-color:var(--c-gold);background:transparent}
.gnav-toggle.is-open span:nth-child(1){top:20px;transform:translateX(-50%) rotate(45deg)}
.gnav-toggle.is-open span:nth-child(2){opacity:0}
.gnav-toggle.is-open span:nth-child(3){top:20px;transform:translateX(-50%) rotate(-45deg)}

/* ---- Drawer overlay (under the drawer) ---- */
.gnav-overlay{display:none;position:fixed;inset:0;background:rgba(5,5,5,.65);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:140;opacity:0;transition:opacity .45s ease;pointer-events:none}
.gnav-overlay.is-open{opacity:1;pointer-events:auto}

@media(max-width:1100px){
  .gnav-list{gap:18px}
  .gnav-list a{font-size:12px;letter-spacing:.12em}
  .gnav-list a small{display:none}
  .gnav-inner{padding:0 30px;gap:18px}
  .gnav-cta{padding:10px 18px;font-size:11px}
}

/* ===== Mobile drawer (<=768px) ===== */
@media(max-width:768px){
  .gnav{height:auto}
  .gnav-inner{height:60px;padding:0 20px;gap:14px}
  .gnav-brand .name{font-size:15px;letter-spacing:.12em}
  .gnav-brand .tag{font-size:9px;letter-spacing:.25em}

  /* hide desktop CTA in topbar — moved into drawer */
  .gnav-inner > .gnav-cta{display:none}

  /* show hamburger + overlay container */
  .gnav-toggle{display:inline-block}
  .gnav-overlay{display:block}

  /* Drawer */
  .gnav-list{
    position:fixed;
    top:0;right:0;
    width:min(86vw,420px);
    height:100vh;height:100dvh;
    background:linear-gradient(180deg,#0a0a0a 0%,#050505 100%);
    border-left:1px solid var(--c-line-gold);
    flex-direction:column;align-items:stretch;gap:0;
    padding:96px 36px 40px;
    transform:translateX(105%);
    transition:transform .55s cubic-bezier(.77,0,.18,1);
    z-index:150;
    overflow-y:auto;
    box-shadow:-30px 0 80px rgba(0,0,0,.6);
  }
  .gnav-list.is-open{transform:translateX(0)}

  /* Decorative top accent inside drawer */
  .gnav-list::before{
    content:"MENU";
    position:absolute;
    top:34px;left:36px;
    font-family:var(--font-en);
    font-size:11px;
    letter-spacing:.5em;
    color:var(--c-gold);
    font-weight:500;
  }
  .gnav-list::after{
    content:"";
    position:absolute;
    top:62px;left:36px;
    width:38px;height:1px;
    background:var(--c-gold);
    opacity:.7;
  }

  .gnav-list li{
    list-style:none;
    opacity:0;
    transform:translateX(20px);
    transition:opacity .5s ease,transform .5s ease;
  }
  .gnav-list.is-open li{opacity:1;transform:translateX(0)}
  .gnav-list.is-open li:nth-child(1){transition-delay:.15s}
  .gnav-list.is-open li:nth-child(2){transition-delay:.22s}
  .gnav-list.is-open li:nth-child(3){transition-delay:.29s}
  .gnav-list.is-open li:nth-child(4){transition-delay:.36s}
  .gnav-list.is-open li:nth-child(5){transition-delay:.43s}
  .gnav-list.is-open li:nth-child(6){transition-delay:.50s}
  .gnav-list.is-open li:nth-child(7){transition-delay:.57s}

  .gnav-list a{
    display:flex;
    flex-direction:column;align-items:flex-start;
    gap:6px;
    padding:22px 0;
    border-bottom:1px solid var(--c-line);
    font-family:var(--font-min);
    font-size:1.55rem;
    font-weight:500;
    letter-spacing:.12em;
    color:var(--c-ivory);
  }
  .gnav-list a small{
    display:inline-block;
    font-family:var(--font-en);
    font-size:10px;
    letter-spacing:.4em;
    color:var(--c-gold);
    font-weight:400;
    text-transform:uppercase;
    opacity:.85;
  }
  .gnav-list a::after{display:none}
  .gnav-list a.is-current{color:var(--c-gold)}
  .gnav-list a.is-current small{color:var(--c-gold-l)}

  /* CTA inside drawer */
  .gnav-list .gnav-drawer-cta{
    display:inline-flex;
    align-items:center;justify-content:center;
    margin-top:36px;
    padding:18px 24px;
    border:1px solid var(--c-gold);
    color:var(--c-gold);
    font-family:var(--font-min);
    font-size:14px;
    letter-spacing:.32em;
    text-transform:uppercase;
    font-weight:500;
    text-align:center;
    transition:all .4s;
  }
  .gnav-list .gnav-drawer-cta:hover,
  .gnav-list .gnav-drawer-cta:active{
    background:var(--c-gold);
    color:var(--c-black);
    opacity:1;
  }

  /* Drawer footer */
  .gnav-drawer-foot{
    list-style:none;
    margin-top:auto;
    padding-top:30px;
    border-top:1px solid var(--c-line);
    font-family:var(--font-en);
    font-size:10px;
    letter-spacing:.35em;
    color:var(--c-text-dim);
    text-align:left;
  }
  .gnav-drawer-foot em{
    display:block;
    font-style:normal;
    color:var(--c-gold);
    margin-top:6px;
    letter-spacing:.4em;
  }
}

/* Lock body scroll when drawer open */
body.no-scroll{overflow:hidden}

body{padding-top:72px}
@media(max-width:768px){body{padding-top:60px}}

/* =====================================================
   Section common
   ===================================================== */
section{padding:160px 0;position:relative}
.container{max-width:1320px;margin:0 auto;padding:0 60px}
.narrow{max-width:880px;margin:0 auto;padding:0 60px}
.chapter{display:inline-flex;align-items:center;gap:18px;font-family:var(--font-en);font-size:12px;letter-spacing:.4em;color:var(--c-gold);margin-bottom:36px;font-weight:500;text-transform:uppercase}
.chapter::before{content:"";width:48px;height:1px;background:var(--c-gold)}
.chapter.center{margin-left:auto;margin-right:auto}
.chapter.center::after{content:"";width:48px;height:1px;background:var(--c-gold)}
.sec-h2{font-family:var(--font-min);font-weight:500;font-size:56px;line-height:1.5;letter-spacing:.08em;color:var(--c-ivory);margin-bottom:28px}
.sec-h2 .em{color:var(--c-gold);font-weight:500;font-style:italic}
.sec-h2 .small{display:block;font-family:var(--font-en);font-size:.32em;font-weight:400;color:var(--c-text-l);letter-spacing:.3em;margin-top:18px;text-transform:uppercase}
.sec-lead{font-family:var(--font-jp);font-size:15px;line-height:2.4;color:var(--c-text);font-weight:400;letter-spacing:.12em;max-width:720px;margin-top:24px}
.sec-lead em{font-style:normal;color:var(--c-gold);font-weight:500}
.sec-h2 + .sec-lead{margin-top:14px}

.sec-divider{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:24px}
.sec-divider span{display:block;width:24px;height:1px;background:var(--c-gold);opacity:.55}
.sec-divider em{font-family:var(--font-en);font-style:italic;color:var(--c-gold);font-size:14px;letter-spacing:.25em}

@media(max-width:900px){
  section{padding:90px 0}
  .container,.narrow{padding:0 22px}
  .sec-h2{font-size:30px;line-height:1.6}
  .sec-h2 .small{font-size:.38em;letter-spacing:.2em;margin-top:12px}
  .chapter{font-size:10px;letter-spacing:.3em;margin-bottom:22px}
  .chapter::before{width:30px}
  .chapter.center::after{width:30px}
  .sec-lead{font-size:13px;line-height:2.2}
}

/* =====================================================
   Hero
   ===================================================== */
.hero{position:relative;min-height:100vh;background:var(--c-black);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:120px 0 100px}
.hero-img{position:absolute;inset:0;background:url('/images/plan4-hero.png') center/cover no-repeat;filter:grayscale(45%) contrast(1.05) brightness(.85);opacity:.85}
.hero-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,.2) 35%,rgba(10,10,10,.55) 65%,rgba(10,10,10,.92) 100%)}
.hero-frame{position:absolute;inset:48px;border:1px solid rgba(184,150,94,.28);pointer-events:none;z-index:2}
.hero-frame::before,.hero-frame::after{content:"";position:absolute;width:22px;height:22px;border:1px solid var(--c-gold)}
.hero-frame::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.hero-frame::after{bottom:-1px;right:-1px;border-left:none;border-top:none}
.hero-content{position:relative;z-index:3;text-align:center;padding:0 40px;max-width:1240px}
.hero-eyebrow{font-family:var(--font-en);font-size:13px;color:var(--c-gold);letter-spacing:.55em;margin-bottom:46px;font-weight:500;text-transform:uppercase}
.hero-eyebrow::before,.hero-eyebrow::after{content:"·";color:var(--c-gold);margin:0 14px}
.hero-title{font-family:var(--font-min);font-weight:500;font-size:88px;line-height:1.35;letter-spacing:.12em;color:var(--c-ivory);margin-bottom:42px;font-feature-settings:"palt"}
.hero-title .amp{color:var(--c-gold);font-weight:500;font-style:italic;display:inline-block;font-family:var(--font-en);margin:0 14px;font-size:.95em}
.hero-title .ja-line{display:block}
.hero-title .en-line{display:block;font-family:var(--font-en);font-style:italic;font-weight:400;font-size:.36em;color:var(--c-gold-l);letter-spacing:.4em;margin-top:30px;opacity:.85}
.hero-jp{font-family:var(--font-jp);font-weight:400;font-size:16px;color:var(--c-ivory-d);letter-spacing:.4em;margin-bottom:70px;opacity:.95;line-height:2.4}
.hero-meta{display:flex;justify-content:center;gap:60px;padding-top:42px;border-top:1px solid rgba(184,150,94,.25);max-width:780px;margin:0 auto;flex-wrap:wrap}
.hero-meta-item{font-family:var(--font-en);font-size:11px;letter-spacing:.3em;color:var(--c-text-l);text-transform:uppercase;text-align:center}
.hero-meta-item strong{display:block;font-family:var(--font-min);font-size:26px;color:var(--c-gold);font-weight:500;letter-spacing:.06em;margin-bottom:6px}
.hero-scroll{position:absolute;bottom:42px;left:50%;transform:translateX(-50%);font-family:var(--font-en);font-size:10px;color:var(--c-ivory);letter-spacing:.4em;text-align:center;opacity:.55;z-index:3;text-transform:uppercase}
.hero-scroll-line{width:1px;height:60px;background:var(--c-gold);margin:12px auto 0;animation:scroll 2.6s ease-in-out infinite;transform-origin:top}
.hero-side{position:absolute;left:36px;top:50%;transform:translateY(-50%) rotate(-90deg);transform-origin:left center;font-family:var(--font-en);font-size:10px;color:var(--c-gold);letter-spacing:.55em;z-index:3;opacity:.85;font-weight:500;text-transform:uppercase}
.hero-side-r{position:absolute;right:36px;top:50%;transform:translateY(-50%) rotate(90deg);transform-origin:right center;font-family:var(--font-en);font-size:10px;color:var(--c-gold);letter-spacing:.55em;z-index:3;opacity:.85;font-weight:500;text-transform:uppercase}
@keyframes scroll{0%{transform:scaleY(0)}50%{transform:scaleY(1)}100%{transform:scaleY(0);transform-origin:bottom}}
@media(max-width:1100px){
  .hero-title{font-size:60px}
  .hero-frame{inset:28px}
}
@media(max-width:768px){
  .hero{min-height:600px;padding:80px 0 80px}
  .hero-frame{inset:16px}
  .hero-frame::before,.hero-frame::after{width:14px;height:14px}
  .hero-title{font-size:34px;letter-spacing:.08em;margin-bottom:24px;line-height:1.45}
  .hero-title .en-line{font-size:.42em;letter-spacing:.25em;margin-top:18px}
  .hero-eyebrow{font-size:10px;letter-spacing:.35em;margin-bottom:24px}
  .hero-jp{font-size:11px;letter-spacing:.25em;margin-bottom:36px;line-height:2.2}
  .hero-meta{gap:24px;padding-top:24px}
  .hero-meta-item{font-size:9px;letter-spacing:.2em}
  .hero-meta-item strong{font-size:18px}
  .hero-side,.hero-side-r{display:none}
  .hero-content{padding:0 24px}
  .hero-scroll{display:none}
}

/* =====================================================
   Philosophy (intro section)
   ===================================================== */
.philosophy{background:var(--c-black);padding:200px 0;position:relative;overflow:hidden}
.philosophy::before{content:"PHILOSOPHY";position:absolute;top:50%;left:-40px;transform:translateY(-50%) rotate(-90deg);transform-origin:left center;font-family:var(--font-en);font-size:200px;line-height:1;font-weight:400;color:rgba(184,150,94,.04);letter-spacing:.05em;pointer-events:none}
.philosophy-inner{max-width:1080px;margin:0 auto;padding:0 60px;text-align:center;position:relative;z-index:2}
.phil-quote{font-family:var(--font-min);font-weight:500;font-size:50px;line-height:1.7;color:var(--c-ivory);letter-spacing:.08em;margin:48px 0 40px;font-feature-settings:"palt"}
.phil-quote .em{color:var(--c-gold);font-style:italic;font-weight:500}
.phil-quote::before,.phil-quote::after{content:"";display:block;width:60px;height:1px;background:var(--c-gold);margin:0 auto 36px}
.phil-quote::after{margin:36px auto 0}
.phil-jp{font-family:var(--font-jp);font-weight:400;font-size:16px;line-height:2.6;color:var(--c-text);letter-spacing:.16em;max-width:700px;margin:0 auto}
.phil-jp em{font-style:normal;color:var(--c-gold);font-weight:500}
.phil-cta{margin-top:80px;display:inline-flex}
.btn-line{font-family:var(--font-en);font-size:13px;color:var(--c-gold);letter-spacing:.3em;padding:6px 0 8px;border-bottom:1px solid var(--c-gold);text-transform:uppercase;font-weight:500;transition:all .4s;display:inline-flex;align-items:center;gap:10px}
.btn-line::after{content:"→";font-family:var(--font-en);font-style:italic;transition:transform .4s}
.btn-line:hover{opacity:1;color:var(--c-gold-l)}
.btn-line:hover::after{transform:translateX(6px)}
.phil-sign{margin-top:80px;padding-top:38px;border-top:1px solid var(--c-line-gold);display:inline-flex;flex-direction:column;align-items:center;gap:6px}
.phil-sign-name{font-family:var(--font-min);font-size:18px;color:var(--c-ivory);letter-spacing:.2em;font-weight:600}
.phil-sign-role{font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.25em;font-weight:500;text-transform:uppercase}
@media(max-width:900px){
  .philosophy{padding:90px 0}
  .philosophy::before{font-size:90px;left:-12px}
  .phil-quote{font-size:22px;line-height:1.9;margin:24px 0}
  .phil-quote::before,.phil-quote::after{width:28px;margin-bottom:18px}
  .phil-quote::after{margin:18px auto 0}
  .phil-jp{font-size:13px;line-height:2.2;letter-spacing:.1em}
  .phil-cta{margin-top:50px}
}

/* =====================================================
   Craftsmanship (about excerpt with gallery)
   ===================================================== */
.craft{background:var(--c-charcoal);padding:200px 0;overflow:hidden;position:relative}
.craft-head{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:90px;max-width:1320px;margin-left:auto;margin-right:auto;padding:0 60px}
.craft-head .sec-body{max-width:520px;font-family:var(--font-jp);font-size:15px;line-height:2.6;color:var(--c-text);font-weight:400;letter-spacing:.1em}
.craft-head .sec-body p+p{margin-top:1.6em}
.craft-gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;height:720px;max-width:1320px;margin:0 auto;padding:0 60px}
.cg{position:relative;overflow:hidden;background:var(--c-black);border:1px solid var(--c-line)}
.cg img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s ease-out;filter:grayscale(20%) contrast(1.05)}
.cg:hover img{transform:scale(1.06)}
.cg-label{position:absolute;bottom:22px;left:24px;font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.25em;line-height:1.5;font-weight:500;text-transform:uppercase;background:linear-gradient(0deg,rgba(10,10,10,.85),transparent);padding:18px 0 0 0;right:24px}
.cg-label strong{display:block;font-family:var(--font-min);font-size:18px;color:var(--c-ivory);letter-spacing:.08em;margin-bottom:4px;font-weight:600;font-style:normal;text-transform:none}
.cg1{grid-column:1/7;grid-row:1/2}
.cg2{grid-column:7/13;grid-row:1/2}
.cg3{grid-column:1/5;grid-row:2/3}
.cg4{grid-column:5/9;grid-row:2/3;background:var(--c-black-d);padding:40px;display:flex;flex-direction:column;justify-content:center;text-align:center;border:1px solid var(--c-line-gold)}
.cg4 .num{font-family:var(--font-en);font-style:italic;font-size:88px;color:var(--c-gold);font-weight:500;line-height:1;letter-spacing:.02em;margin-bottom:14px}
.cg4 .lbl{font-family:var(--font-min);font-size:14px;color:var(--c-ivory);letter-spacing:.15em;line-height:1.7;font-weight:500}
.cg4 .lbl small{display:block;color:var(--c-text-l);font-family:var(--font-jp);font-size:12px;letter-spacing:.12em;margin-top:6px;font-weight:400}
.cg5{grid-column:9/13;grid-row:2/3}
@media(max-width:900px){
  .craft{padding:90px 0}
  .craft-head{grid-template-columns:1fr;gap:24px;margin-bottom:50px;padding:0 22px}
  .craft-gallery{grid-template-columns:1fr;height:auto;gap:14px;padding:0 22px}
  .cg{height:260px}
  .cg1,.cg2,.cg3,.cg4,.cg5{grid-column:1;grid-row:auto}
  .cg4{padding:30px;height:auto}
  .cg4 .num{font-size:54px}
}

/* =====================================================
   Services 6 grid
   ===================================================== */
.services-sec{background:var(--c-black);padding:200px 0}
.services-head{text-align:center;max-width:920px;margin:0 auto 90px;padding:0 60px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;max-width:1320px;margin:0 auto;padding:0 60px;border-top:1px solid var(--c-line);border-left:1px solid var(--c-line)}
.svc-card{padding:50px 38px 46px;border-right:1px solid var(--c-line);border-bottom:1px solid var(--c-line);transition:background .5s;position:relative;display:block;color:inherit}
.svc-card:hover{background:rgba(184,150,94,.05);opacity:1}
.svc-card:hover .svc-jp{color:var(--c-gold-l)}
.svc-no{font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.3em;margin-bottom:14px;font-weight:500;text-transform:uppercase}
.svc-no::before{content:"—  "}
.svc-en{font-family:var(--font-en);font-style:italic;font-size:14px;color:var(--c-text-l);letter-spacing:.18em;margin-bottom:10px;font-weight:400}
.svc-jp{font-family:var(--font-min);font-weight:600;font-size:26px;color:var(--c-ivory);letter-spacing:.08em;margin-bottom:20px;line-height:1.5;transition:color .4s}
.svc-desc{font-family:var(--font-jp);font-size:13px;line-height:2.2;color:var(--c-text-l);font-weight:400;letter-spacing:.08em;margin-bottom:24px}
.svc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.svc-tag{font-family:var(--font-en);font-size:10px;color:var(--c-gold);letter-spacing:.18em;padding:4px 10px;border:1px solid var(--c-line-gold);font-weight:500;text-transform:uppercase}
.svc-link{display:inline-flex;margin-top:24px;font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.25em;border-bottom:1px solid var(--c-line-gold);padding-bottom:4px;text-transform:uppercase}
.svc-link::after{content:" →";margin-left:6px;transition:transform .4s}
.svc-card:hover .svc-link::after{transform:translateX(4px)}
@media(max-width:1024px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.svc-grid{grid-template-columns:1fr;padding:0 22px}.svc-card{padding:38px 26px 36px}.svc-jp{font-size:22px}}

.services-cta{text-align:center;margin-top:70px}

/* =====================================================
   Works (case studies)
   ===================================================== */
.works-sec{background:var(--c-black);padding:200px 0}
.works-head{text-align:center;margin-bottom:100px;max-width:920px;margin-left:auto;margin-right:auto;padding:0 60px}
.works-list{display:grid;grid-template-columns:1fr;gap:130px;max-width:1320px;margin:0 auto;padding:0 60px}
.work-item{display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:center}
.work-item:nth-child(even){grid-template-columns:1fr 1.4fr}
.work-item:nth-child(even) .work-info{order:-1;padding-right:0;padding-left:0}
.work-visual{position:relative;aspect-ratio:4/3;background:var(--c-charcoal);overflow:hidden;border:1px solid var(--c-line)}
.work-visual img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.85);transition:transform 1.6s ease-out}
.work-visual:hover img{transform:scale(1.04)}
.work-visual::after{content:attr(data-num);position:absolute;top:24px;left:24px;font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.3em;background:rgba(10,10,10,.85);padding:7px 14px;backdrop-filter:blur(8px);font-weight:500;text-transform:uppercase;border:1px solid var(--c-line-gold)}
.work-info{padding:0}
.work-cat{font-family:var(--font-en);font-style:italic;font-size:14px;color:var(--c-gold);letter-spacing:.22em;margin-bottom:24px;display:flex;align-items:center;gap:14px;font-weight:500;text-transform:uppercase}
.work-cat::before{content:"";width:32px;height:1px;background:var(--c-gold)}
.work-title{font-family:var(--font-min);font-weight:600;font-size:40px;line-height:1.45;color:var(--c-ivory);margin-bottom:22px;letter-spacing:.06em;font-feature-settings:"palt"}
.work-title .small{display:block;font-family:var(--font-jp);font-size:.36em;color:var(--c-text-l);letter-spacing:.12em;margin-top:14px;font-weight:400}
.work-body{font-family:var(--font-jp);font-size:14px;line-height:2.4;color:var(--c-text);font-weight:400;letter-spacing:.08em;margin-bottom:30px}
.work-meta{display:flex;gap:36px;padding-top:30px;border-top:1px solid var(--c-line);flex-wrap:wrap}
.work-meta-item{font-family:var(--font-en);font-size:10px;color:var(--c-text-l);letter-spacing:.2em;font-weight:500;text-transform:uppercase}
.work-meta-item strong{display:block;font-family:var(--font-min);font-style:italic;font-size:24px;color:var(--c-gold);font-weight:500;margin-bottom:4px;letter-spacing:.04em}
.works-cta{text-align:center;margin-top:120px}
@media(max-width:900px){
  .works-sec{padding:90px 0}
  .works-list{gap:70px;padding:0 22px}
  .work-item,.work-item:nth-child(even){grid-template-columns:1fr;gap:30px}
  .work-item:nth-child(even) .work-info{order:1;padding:0}
  .work-title{font-size:24px}
  .works-cta{margin-top:60px}
}

/* =====================================================
   Before / After
   ===================================================== */
.ba-sec{background:var(--c-charcoal);padding:200px 0}
.ba-head{text-align:center;max-width:920px;margin:0 auto 80px;padding:0 60px}
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;max-width:1320px;margin:0 auto;padding:0 60px}
.ba-card{position:relative;border:1px solid var(--c-line);overflow:hidden;background:var(--c-black)}
.ba-card img{width:100%;height:520px;object-fit:cover;filter:grayscale(15%) contrast(1.05)}
.ba-card-label{position:absolute;top:22px;left:22px;font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.3em;background:rgba(10,10,10,.85);padding:7px 14px;font-weight:500;text-transform:uppercase;border:1px solid var(--c-gold)}
.ba-card-cap{position:absolute;bottom:22px;left:22px;right:22px;font-family:var(--font-min);color:var(--c-ivory);font-size:18px;letter-spacing:.06em;background:linear-gradient(0deg,rgba(10,10,10,.85),transparent);padding:36px 0 0}
.ba-card-cap small{display:block;font-family:var(--font-jp);font-size:12px;color:var(--c-text-l);letter-spacing:.1em;margin-top:6px;font-weight:400}
.ba-text{max-width:920px;margin:60px auto 0;padding:0 60px;text-align:center;font-family:var(--font-jp);font-size:14px;line-height:2.4;color:var(--c-text-l);letter-spacing:.1em}
@media(max-width:900px){
  .ba-sec{padding:90px 0}
  .ba-grid{grid-template-columns:1fr;gap:18px;padding:0 22px}
  .ba-card img{height:300px}
  .ba-text{padding:0 22px;font-size:13px}
}

/* =====================================================
   Process (flow)
   ===================================================== */
.process{background:var(--c-charcoal-l);padding:200px 0;position:relative;overflow:hidden}
.process::before{content:"PROCESS";position:absolute;top:50%;right:-60px;transform:translateY(-50%) rotate(-90deg);transform-origin:right center;font-family:var(--font-en);font-size:180px;color:rgba(184,150,94,.04);line-height:1;pointer-events:none;font-weight:400;letter-spacing:.1em}
.process-head{text-align:center;margin-bottom:90px;position:relative;z-index:2;max-width:920px;margin-left:auto;margin-right:auto;padding:0 60px}
.process-list{max-width:1120px;margin:0 auto;padding:0 60px;position:relative;z-index:2}
.proc-step{display:grid;grid-template-columns:180px 1fr;gap:80px;padding:48px 0;border-top:1px solid var(--c-line-l);align-items:start;transition:background .4s}
.proc-step:last-child{border-bottom:1px solid var(--c-line-l)}
.proc-step:hover .proc-num em{color:var(--c-gold-l)}
.proc-num{font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.3em;line-height:1.5;font-weight:500;text-transform:uppercase}
.proc-num em{display:block;font-style:italic;font-family:var(--font-en);font-weight:500;font-size:78px;color:var(--c-ivory);line-height:1;margin-top:14px;letter-spacing:.02em;transition:color .4s}
.proc-body h4{font-family:var(--font-min);font-weight:600;font-size:28px;color:var(--c-ivory);margin-bottom:8px;letter-spacing:.06em;line-height:1.5}
.proc-body h4 .small{display:block;font-family:var(--font-en);font-style:italic;font-size:.5em;color:var(--c-gold);letter-spacing:.2em;margin-top:10px;font-weight:400;padding-left:18px;position:relative;text-transform:uppercase}
.proc-body h4 .small::before{content:"";position:absolute;left:0;top:50%;width:10px;height:1px;background:var(--c-gold);opacity:.6}
.proc-body p{font-family:var(--font-jp);font-size:14px;line-height:2.4;color:var(--c-text-l);font-weight:400;letter-spacing:.08em;margin-top:18px;max-width:560px}
@media(max-width:768px){
  .process{padding:90px 0}
  .process-list{padding:0 22px}
  .proc-step{grid-template-columns:1fr;gap:14px;padding:34px 0}
  .proc-num em{font-size:46px}
  .proc-body h4{font-size:20px}
}

/* =====================================================
   Strengths (なぜZESTか / 6 reasons)
   ===================================================== */
.strengths{background:var(--c-black);padding:200px 0}
.strengths-head{text-align:center;max-width:920px;margin:0 auto 90px;padding:0 60px}
.strengths-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;max-width:1320px;margin:0 auto;padding:0 60px;border-top:1px solid var(--c-line);border-left:1px solid var(--c-line)}
.strength-card{padding:50px 38px;border-right:1px solid var(--c-line);border-bottom:1px solid var(--c-line);position:relative;transition:background .4s}
.strength-card:hover{background:rgba(184,150,94,.04)}
.strength-no{font-family:var(--font-en);font-style:italic;font-size:48px;color:var(--c-gold);font-weight:500;line-height:1;letter-spacing:.02em;margin-bottom:18px}
.strength-no small{display:inline-block;font-family:var(--font-en);font-size:10px;color:var(--c-gold-d);letter-spacing:.3em;margin-right:8px;vertical-align:8px;font-style:normal;text-transform:uppercase}
.strength-card h4{font-family:var(--font-min);font-weight:600;font-size:22px;color:var(--c-ivory);letter-spacing:.08em;margin-bottom:16px;line-height:1.6}
.strength-card h4 .em{color:var(--c-gold);font-style:italic}
.strength-card p{font-family:var(--font-jp);font-size:13px;line-height:2.2;color:var(--c-text-l);font-weight:400;letter-spacing:.08em}
@media(max-width:1024px){.strengths-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.strengths-grid{grid-template-columns:1fr;padding:0 22px}.strength-card{padding:36px 26px}}

/* =====================================================
   Pricing
   ===================================================== */
.pricing-sec{background:var(--c-black);padding:200px 0}
.pricing-head{text-align:center;max-width:920px;margin:0 auto 60px;padding:0 60px}
.pricing-table{margin-top:60px;max-width:980px;margin-left:auto;margin-right:auto;padding:0 60px}
.pricing-row{display:grid;grid-template-columns:1fr auto;gap:60px;padding:38px 0;border-bottom:1px solid var(--c-line);align-items:baseline}
.pricing-row:first-child{border-top:1px solid var(--c-line)}
.pricing-row h4{font-family:var(--font-min);font-weight:500;font-size:22px;color:var(--c-ivory);letter-spacing:.08em;line-height:1.6}
.pricing-row h4 small{display:block;font-family:var(--font-jp);font-size:12px;color:var(--c-text-l);font-weight:400;letter-spacing:.08em;margin-top:8px}
.pricing-row .pr{font-family:var(--font-en);font-size:13px;color:var(--c-text-l);letter-spacing:.1em;text-align:right;line-height:1.4;font-weight:500;text-transform:uppercase}
.pricing-row .pr strong{display:block;font-family:var(--font-min);font-style:italic;font-size:38px;color:var(--c-gold);font-weight:500;letter-spacing:.02em;margin-bottom:4px}
.pricing-note{margin-top:50px;font-family:var(--font-jp);font-size:12px;color:var(--c-text-l);letter-spacing:.1em;text-align:center;line-height:2;font-weight:400;max-width:780px;margin-left:auto;margin-right:auto}
@media(max-width:768px){
  .pricing-sec{padding:90px 0}
  .pricing-table{padding:0 22px}
  .pricing-row{grid-template-columns:1fr;gap:10px;padding:26px 0}
  .pricing-row .pr{text-align:left}
  .pricing-row .pr strong{font-size:28px}
}

/* =====================================================
   Company table (会社概要)
   ===================================================== */
.company-sec{background:var(--c-charcoal);padding:200px 0}
.company-head{text-align:center;max-width:920px;margin:0 auto 60px;padding:0 60px}
.company-table{max-width:980px;margin:60px auto 0;padding:0 60px;border-top:1px solid var(--c-line-l)}
.company-table dl{display:grid;grid-template-columns:220px 1fr;gap:40px;padding:28px 0;border-bottom:1px solid var(--c-line-l);align-items:baseline}
.company-table dt{font-family:var(--font-en);font-style:italic;font-size:14px;color:var(--c-gold);letter-spacing:.2em;font-weight:500;text-transform:uppercase}
.company-table dt small{display:block;font-family:var(--font-min);font-style:normal;font-size:13px;color:var(--c-ivory);letter-spacing:.1em;margin-top:4px;font-weight:500;text-transform:none}
.company-table dd{font-family:var(--font-jp);font-size:14px;color:var(--c-text);line-height:2.2;letter-spacing:.08em;font-weight:400}
.company-table dd strong{color:var(--c-ivory);font-weight:500}
@media(max-width:768px){
  .company-sec{padding:90px 0}
  .company-table{padding:0 22px}
  .company-table dl{grid-template-columns:1fr;gap:6px;padding:22px 0}
  .company-table dt small{margin-top:0}
}

/* =====================================================
   History (沿革)
   ===================================================== */
.history-sec{background:var(--c-black);padding:200px 0;position:relative;overflow:hidden}
.history-sec::before{content:"HISTORY";position:absolute;top:50%;left:-30px;transform:translateY(-50%) rotate(-90deg);transform-origin:left center;font-family:var(--font-en);font-size:160px;color:rgba(184,150,94,.04);line-height:1;pointer-events:none;font-weight:400}
.history-head{text-align:center;max-width:920px;margin:0 auto 80px;padding:0 60px;position:relative;z-index:2}
.history-list{max-width:1080px;margin:0 auto;padding:0 60px;position:relative;z-index:2}
.hist-item{display:grid;grid-template-columns:200px 1fr;gap:50px;padding:34px 0;border-top:1px solid var(--c-line);align-items:baseline;transition:background .4s}
.hist-item:last-child{border-bottom:1px solid var(--c-line)}
.hist-item:hover{background:rgba(184,150,94,.03)}
.hist-year{font-family:var(--font-en);font-style:italic;font-size:38px;color:var(--c-gold);font-weight:500;letter-spacing:.04em;line-height:1}
.hist-year::before{content:"—  ";font-family:var(--font-en);font-style:normal;color:var(--c-gold);font-size:.5em;letter-spacing:.2em;margin-right:6px;vertical-align:7px}
.hist-text{font-family:var(--font-jp);font-size:14px;line-height:2.2;color:var(--c-text);font-weight:400;letter-spacing:.08em}
.hist-text strong{display:block;font-family:var(--font-min);color:var(--c-ivory);font-size:18px;font-weight:600;letter-spacing:.08em;margin-bottom:8px}
@media(max-width:768px){
  .history-sec{padding:90px 0}
  .history-sec::before{font-size:80px}
  .history-list{padding:0 22px}
  .hist-item{grid-template-columns:1fr;gap:8px;padding:22px 0}
  .hist-year{font-size:26px}
}

/* =====================================================
   Message (代表挨拶)
   ===================================================== */
.message-sec{background:var(--c-charcoal);padding:200px 0}
.message-head{text-align:center;max-width:920px;margin:0 auto 80px;padding:0 60px}
.message-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;max-width:1180px;margin:0 auto;padding:0 60px;align-items:start}
.message-photo{position:sticky;top:120px}
.message-photo .photo{aspect-ratio:3/4;background:linear-gradient(135deg,var(--c-charcoal),var(--c-black));border:1px solid var(--c-line-gold);display:flex;flex-direction:column;justify-content:flex-end;padding:36px;color:var(--c-ivory);font-family:var(--font-min);position:relative;overflow:hidden}
.message-photo .photo::before{content:"";position:absolute;inset:18px;border:1px solid var(--c-line-gold);pointer-events:none}
.message-photo .photo .role{font-family:var(--font-en);font-style:italic;color:var(--c-gold);font-size:12px;letter-spacing:.25em;margin-bottom:8px;text-transform:uppercase}
.message-photo .photo .name{font-family:var(--font-min);font-size:26px;color:var(--c-ivory);letter-spacing:.12em;font-weight:600}
.message-photo .photo .sub{font-family:var(--font-en);font-style:italic;color:var(--c-gold-l);font-size:13px;letter-spacing:.18em;margin-top:10px}
.message-body h3{font-family:var(--font-min);font-weight:500;font-size:30px;color:var(--c-ivory);line-height:1.7;letter-spacing:.06em;margin-bottom:36px;font-feature-settings:"palt"}
.message-body h3 .em{color:var(--c-gold);font-style:italic;font-weight:500}
.message-body p{font-family:var(--font-jp);font-size:14px;line-height:2.6;color:var(--c-text);font-weight:400;letter-spacing:.08em;margin-bottom:1.8em}
.message-body p em{font-style:normal;color:var(--c-gold);font-weight:500}
.message-body .sign{margin-top:48px;padding-top:30px;border-top:1px solid var(--c-line-gold);font-family:var(--font-min);font-size:14px;color:var(--c-text-l);letter-spacing:.1em;display:flex;flex-direction:column;gap:4px}
.message-body .sign strong{font-family:var(--font-min);font-size:20px;color:var(--c-ivory);letter-spacing:.18em;font-weight:600;margin-top:6px}
.message-body .sign small{font-family:var(--font-en);font-style:italic;color:var(--c-gold);font-size:12px;letter-spacing:.2em}
@media(max-width:900px){
  .message-sec{padding:90px 0}
  .message-grid{grid-template-columns:1fr;gap:50px;padding:0 22px}
  .message-photo{position:static}
  .message-photo .photo{aspect-ratio:4/3;padding:26px}
  .message-photo .photo .name{font-size:20px}
  .message-body h3{font-size:20px;line-height:1.8;margin-bottom:24px}
  .message-body p{font-size:13px}
}

/* =====================================================
   Service detail (services page)
   ===================================================== */
.svc-detail{background:var(--c-charcoal);padding:200px 0}
.svc-detail-head{text-align:center;max-width:920px;margin:0 auto 90px;padding:0 60px}
.svc-detail-list{max-width:1280px;margin:0 auto;padding:0 60px;display:grid;gap:120px}
.svc-detail-card{display:grid;grid-template-columns:auto 1fr;gap:80px;align-items:start;padding-top:60px;border-top:1px solid var(--c-line-l);position:relative}
.svc-detail-card:first-child{border-top:1px solid var(--c-gold);padding-top:80px}
.svc-detail-side{width:180px;font-family:var(--font-en);position:sticky;top:120px}
.svc-detail-side .num{font-style:italic;font-size:64px;color:var(--c-gold);font-weight:500;line-height:1;letter-spacing:.02em;margin-bottom:16px}
.svc-detail-side .num::before{content:"No. ";font-family:var(--font-en);font-style:normal;font-size:.28em;color:var(--c-gold-d);letter-spacing:.25em;vertical-align:14px;margin-right:6px;text-transform:uppercase}
.svc-detail-side .cat{font-family:var(--font-en);font-style:italic;font-size:13px;color:var(--c-gold-l);letter-spacing:.25em;text-transform:uppercase;font-weight:500}
.svc-detail-body h3{font-family:var(--font-min);font-weight:600;font-size:36px;color:var(--c-ivory);letter-spacing:.06em;line-height:1.5;margin-bottom:18px;font-feature-settings:"palt"}
.svc-detail-body .copy{font-family:var(--font-min);font-size:20px;color:var(--c-gold-l);line-height:1.8;letter-spacing:.08em;font-weight:500;font-style:italic;margin-bottom:28px}
.svc-detail-body .copy em{font-style:normal;color:var(--c-gold);font-weight:600}
.svc-detail-body .desc{font-family:var(--font-jp);font-size:14px;line-height:2.6;color:var(--c-text);font-weight:400;letter-spacing:.08em;margin-bottom:32px}
.svc-detail-body .feats{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;padding:30px 0;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line);margin-bottom:30px}
.svc-detail-body .feats li{list-style:none;font-family:var(--font-jp);font-size:13px;color:var(--c-text);line-height:1.8;padding-left:22px;position:relative;letter-spacing:.06em}
.svc-detail-body .feats li::before{content:"◆";position:absolute;left:0;top:0;color:var(--c-gold);font-size:11px}
.svc-detail-body .price-line{display:flex;gap:18px;align-items:baseline;padding-top:18px;flex-wrap:wrap}
.svc-detail-body .price-line .lbl{font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.22em;text-transform:uppercase}
.svc-detail-body .price-line .val{font-family:var(--font-min);font-style:italic;font-size:32px;color:var(--c-ivory);font-weight:500;letter-spacing:.04em}
.svc-detail-body .price-line .unit{font-family:var(--font-jp);font-size:12px;color:var(--c-text-l);letter-spacing:.08em}
@media(max-width:900px){
  .svc-detail{padding:90px 0}
  .svc-detail-list{padding:0 22px;gap:60px}
  .svc-detail-card{grid-template-columns:1fr;gap:24px;padding-top:36px}
  .svc-detail-side{position:static;width:auto;display:flex;align-items:baseline;gap:14px}
  .svc-detail-side .num{font-size:42px;margin-bottom:0}
  .svc-detail-body h3{font-size:22px}
  .svc-detail-body .copy{font-size:16px;line-height:1.7}
  .svc-detail-body .feats{grid-template-columns:1fr;gap:10px;padding:22px 0}
}

/* =====================================================
   Recruit
   ===================================================== */
.recruit-list{margin-top:60px;max-width:1180px;margin-left:auto;margin-right:auto;padding:0 60px;display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.rec-card{padding:42px 36px;border:1px solid var(--c-line);background:rgba(255,255,255,.015);transition:all .4s;position:relative}
.rec-card:hover{border-color:var(--c-gold);background:rgba(184,150,94,.04)}
.rec-card:hover .rec-role{color:var(--c-gold-l)}
.rec-type{display:inline-block;font-family:var(--font-en);font-size:10px;color:var(--c-gold);letter-spacing:.25em;border:1px solid var(--c-gold);padding:4px 14px;margin-bottom:20px;font-weight:500;text-transform:uppercase}
.rec-role{font-family:var(--font-min);font-weight:600;font-size:24px;color:var(--c-ivory);letter-spacing:.08em;margin-bottom:14px;line-height:1.5;transition:color .4s}
.rec-salary{font-family:var(--font-min);font-style:italic;font-size:18px;color:var(--c-gold);margin-bottom:20px;font-weight:500;letter-spacing:.05em}
.rec-desc{font-family:var(--font-jp);font-size:13px;line-height:2.2;color:var(--c-text);font-weight:400;letter-spacing:.06em;margin-bottom:20px}
.rec-points{list-style:none;border-top:1px solid var(--c-line);padding-top:18px;display:flex;flex-direction:column;gap:8px}
.rec-points li{font-family:var(--font-jp);font-size:12px;color:var(--c-text-l);letter-spacing:.06em;padding-left:18px;position:relative;line-height:1.8}
.rec-points li::before{content:"◇";position:absolute;left:0;top:0;color:var(--c-gold);font-size:11px}
@media(max-width:768px){.recruit-list{grid-template-columns:1fr;padding:0 22px;gap:20px}.rec-card{padding:30px 24px}}

/* Recruit merit */
.merit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:1280px;margin:0 auto;padding:0 60px;margin-top:60px}
.merit-card{padding:50px 36px;border:1px solid var(--c-line);background:var(--c-black-d);text-align:left;transition:border-color .4s}
.merit-card:hover{border-color:var(--c-gold)}
.merit-card .num{font-family:var(--font-en);font-style:italic;font-size:42px;color:var(--c-gold);font-weight:500;line-height:1;margin-bottom:20px;letter-spacing:.02em}
.merit-card h4{font-family:var(--font-min);font-size:20px;color:var(--c-ivory);letter-spacing:.08em;font-weight:600;margin-bottom:16px;line-height:1.6}
.merit-card h4 .em{color:var(--c-gold);font-style:italic}
.merit-card p{font-family:var(--font-jp);font-size:13px;line-height:2.2;color:var(--c-text-l);font-weight:400;letter-spacing:.06em}
@media(max-width:900px){.merit-grid{grid-template-columns:1fr;padding:0 22px;gap:18px}.merit-card{padding:32px 26px}}

/* Welfare */
.welfare-list{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:1280px;margin:60px auto 0;padding:0 60px;border-top:1px solid var(--c-line);border-left:1px solid var(--c-line)}
.welfare-list li{list-style:none;padding:36px 26px;border-right:1px solid var(--c-line);border-bottom:1px solid var(--c-line);text-align:left;transition:background .4s}
.welfare-list li:hover{background:rgba(184,150,94,.04)}
.welfare-list li .lbl{font-family:var(--font-en);font-size:10px;color:var(--c-gold);letter-spacing:.25em;text-transform:uppercase;margin-bottom:14px;display:block;font-weight:500}
.welfare-list li strong{display:block;font-family:var(--font-min);color:var(--c-ivory);font-size:18px;letter-spacing:.06em;font-weight:600;margin-bottom:8px;line-height:1.5}
.welfare-list li span{display:block;font-family:var(--font-jp);font-size:12px;color:var(--c-text-l);letter-spacing:.06em;line-height:1.8}
@media(max-width:900px){.welfare-list{grid-template-columns:repeat(2,1fr);padding:0 22px}}
@media(max-width:520px){.welfare-list{grid-template-columns:1fr}}

/* Recruit flow */
.rec-flow-list{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1280px;margin:60px auto 0;padding:0 60px}
.rec-flow-step{padding:36px 26px;border:1px solid var(--c-line);text-align:center;background:var(--c-black);position:relative}
.rec-flow-step .step{font-family:var(--font-en);font-style:italic;font-size:11px;color:var(--c-gold);letter-spacing:.3em;margin-bottom:18px;text-transform:uppercase;font-weight:500}
.rec-flow-step .step em{font-style:italic;font-size:24px;color:var(--c-ivory);font-weight:500;margin-left:8px;letter-spacing:.05em}
.rec-flow-step h4{font-family:var(--font-min);font-size:18px;color:var(--c-ivory);letter-spacing:.08em;font-weight:600;margin-bottom:12px;line-height:1.5}
.rec-flow-step p{font-family:var(--font-jp);font-size:12px;color:var(--c-text-l);line-height:2;letter-spacing:.06em}
@media(max-width:900px){.rec-flow-list{grid-template-columns:repeat(2,1fr);padding:0 22px;gap:14px}}
@media(max-width:520px){.rec-flow-list{grid-template-columns:1fr}}

/* =====================================================
   News list
   ===================================================== */
.news-list{margin-top:40px;max-width:1080px;margin-left:auto;margin-right:auto;padding:0 60px}
.news-item{display:grid;grid-template-columns:140px 100px 1fr;gap:32px;padding:28px 0;border-bottom:1px solid var(--c-line);align-items:baseline;transition:background .4s,padding .4s}
.news-item:first-child{border-top:1px solid var(--c-line)}
.news-item:hover{background:rgba(184,150,94,.03);padding-left:18px;padding-right:18px}
.news-date{font-family:var(--font-en);font-size:14px;color:var(--c-gold);letter-spacing:.05em;font-weight:500}
.news-cat{font-family:var(--font-en);font-size:10px;color:var(--c-text-l);letter-spacing:.2em;border:1px solid var(--c-line);padding:5px 12px;text-align:center;justify-self:start;font-weight:500;text-transform:uppercase}
.news-cat.media{border-color:var(--c-gold);color:var(--c-gold)}
.news-cat.recruit{border-color:var(--c-ivory-d);color:var(--c-ivory-d)}
.news-title{font-family:var(--font-jp);font-size:15px;color:var(--c-ivory);font-weight:400;letter-spacing:.05em;line-height:1.7}
.news-pager{margin-top:60px;display:flex;justify-content:center;gap:8px}
.news-pager span,.news-pager a{font-family:var(--font-en);font-size:14px;color:var(--c-text-l);letter-spacing:.1em;padding:10px 16px;border:1px solid var(--c-line);font-weight:500;transition:all .4s}
.news-pager span.is-current,.news-pager a:hover{border-color:var(--c-gold);color:var(--c-gold);background:rgba(184,150,94,.04)}
@media(max-width:768px){.news-list{padding:0 22px}.news-item{grid-template-columns:1fr;gap:6px;padding:20px 0}.news-item:hover{padding-left:8px;padding-right:8px}}

/* =====================================================
   Contact form
   ===================================================== */
.contact-info{background:var(--c-charcoal);padding:140px 0}
.contact-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;max-width:1180px;margin:0 auto;padding:0 60px;border-top:1px solid var(--c-line-l);border-left:1px solid var(--c-line-l)}
.contact-info-card{padding:50px 36px;border-right:1px solid var(--c-line-l);border-bottom:1px solid var(--c-line-l);text-align:center;transition:background .4s}
.contact-info-card:hover{background:rgba(184,150,94,.04)}
.contact-info-card .lbl{font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.3em;margin-bottom:20px;font-weight:500;text-transform:uppercase}
.contact-info-card .val{display:block;font-family:var(--font-min);font-style:italic;font-size:30px;color:var(--c-ivory);font-weight:500;letter-spacing:.04em;margin-bottom:12px;line-height:1.3}
.contact-info-card .val.small{font-size:18px;font-style:normal;letter-spacing:.1em}
.contact-info-card .sub{font-family:var(--font-jp);font-size:12px;color:var(--c-text-l);letter-spacing:.08em;line-height:2;font-weight:400}
@media(max-width:900px){.contact-info-grid{grid-template-columns:1fr;padding:0 22px}}

.form-sec{background:var(--c-black);padding:160px 0}
.form-head{text-align:center;max-width:920px;margin:0 auto 70px;padding:0 60px}
.form-box{max-width:840px;margin:0 auto;padding:0 60px}
.form-row{display:grid;grid-template-columns:200px 1fr;gap:36px;padding:28px 0;border-bottom:1px solid var(--c-line);align-items:start}
.form-row:first-child{border-top:1px solid var(--c-line)}
.form-row label{font-family:var(--font-min);font-size:15px;color:var(--c-ivory);letter-spacing:.1em;font-weight:500;padding-top:14px;display:flex;align-items:center;gap:10px}
.form-row label .req{display:inline-block;font-family:var(--font-en);font-size:9px;color:var(--c-gold);letter-spacing:.2em;border:1px solid var(--c-gold);padding:2px 8px;font-weight:500;text-transform:uppercase}
.form-row input,.form-row select,.form-row textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--c-line-l);color:var(--c-ivory);font-family:var(--font-jp);font-size:15px;padding:14px 6px;letter-spacing:.06em;outline:none;transition:border-color .3s}
.form-row select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--c-gold) 50%),linear-gradient(135deg,var(--c-gold) 50%,transparent 50%);background-position:calc(100% - 14px) center,calc(100% - 8px) center;background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.form-row option{background:var(--c-black);color:var(--c-ivory)}
.form-row textarea{min-height:140px;resize:vertical;line-height:1.9}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-bottom-color:var(--c-gold)}
.form-row input::placeholder,.form-row textarea::placeholder{color:var(--c-text-dim);font-family:var(--font-jp);letter-spacing:.04em}
.form-submit{margin-top:50px;text-align:center}
.form-submit button{font-family:var(--font-min);font-size:15px;letter-spacing:.3em;color:var(--c-black);background:var(--c-gold);padding:22px 80px;border:1px solid var(--c-gold);cursor:pointer;font-weight:500;transition:all .4s;text-transform:uppercase}
.form-submit button:hover{background:transparent;color:var(--c-gold)}
.form-note{margin-top:24px;font-family:var(--font-jp);font-size:11px;color:var(--c-text-dim);letter-spacing:.08em;line-height:2}
@media(max-width:768px){
  .form-sec{padding:90px 0}
  .form-box{padding:0 22px}
  .form-row{grid-template-columns:1fr;gap:8px;padding:20px 0}
  .form-row label{padding-top:0}
  .form-submit button{padding:18px 40px;font-size:13px;letter-spacing:.2em}
}

/* =====================================================
   Contact CTA cards (HOME) & Foot CTA
   ===================================================== */
.contact{background:var(--c-black);padding:220px 0;position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;inset:0;background:url('/images/plan4-hero.png') center/cover;opacity:.1;filter:grayscale(70%) brightness(.8)}
.contact::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.85),rgba(10,10,10,.95))}
.contact-inner{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:0 60px;text-align:center}
.contact h2{font-family:var(--font-min);font-weight:500;font-size:54px;line-height:1.5;color:var(--c-ivory);letter-spacing:.08em;margin-bottom:36px}
.contact h2 .em{color:var(--c-gold);font-style:italic;font-weight:500}
.contact-jp{font-family:var(--font-jp);font-size:15px;line-height:2.4;color:var(--c-text);font-weight:400;letter-spacing:.1em;max-width:640px;margin:0 auto 70px}
.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:920px;margin:0 auto;border:1px solid var(--c-line-gold)}
.cont-card{padding:60px 50px;text-align:center;border-right:1px solid var(--c-line-gold);transition:background .4s}
.cont-card:last-child{border-right:none}
.cont-card:hover{background:rgba(184,150,94,.05)}
.cont-card-label{font-family:var(--font-en);font-size:12px;letter-spacing:.3em;color:var(--c-gold);margin-bottom:30px;font-weight:500;text-transform:uppercase}
.cont-card .num{font-family:var(--font-min);font-style:italic;font-size:42px;color:var(--c-ivory);font-weight:500;letter-spacing:.04em;display:block;margin-bottom:14px;line-height:1.2}
.cont-card .hours{font-family:var(--font-jp);font-size:12px;color:var(--c-text-l);letter-spacing:.1em;font-weight:400;line-height:2}
.cont-card .btn{display:inline-block;margin-top:24px;padding:18px 40px;background:transparent;color:var(--c-gold);font-family:var(--font-min);font-size:14px;letter-spacing:.25em;border:1px solid var(--c-gold);transition:all .4s;font-weight:500;text-transform:uppercase}
.cont-card .btn:hover{background:var(--c-gold);color:var(--c-black);opacity:1}
@media(max-width:900px){
  .contact{padding:100px 0}
  .contact h2{font-size:26px;line-height:1.6}
  .contact-cards{grid-template-columns:1fr}
  .cont-card{padding:40px 24px;border-right:none;border-bottom:1px solid var(--c-line-gold)}
  .cont-card:last-child{border-bottom:none}
}

/* =====================================================
   Footer
   ===================================================== */
footer{background:var(--c-black-d);color:var(--c-text-l);padding:120px 0 36px;border-top:1px solid var(--c-line-gold);position:relative}
footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--c-gold),transparent)}
.footer-inner{max-width:1320px;margin:0 auto 80px;padding:0 60px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:60px}
.footer-brand .name{font-family:var(--font-min);color:var(--c-ivory);font-size:24px;letter-spacing:.22em;font-weight:600;line-height:1.4}
.footer-brand .name em{font-style:italic;color:var(--c-gold);font-weight:500;margin-left:6px;font-size:.65em;letter-spacing:.3em}
.footer-brand .tag{font-family:var(--font-en);font-style:italic;color:var(--c-gold);font-size:13px;margin-top:8px;letter-spacing:.25em}
.footer-desc{margin-top:30px;font-family:var(--font-jp);font-size:13px;line-height:2.2;color:var(--c-text-l);font-weight:400;letter-spacing:.08em;max-width:380px}
.footer-block h5{font-family:var(--font-en);font-style:italic;font-size:13px;color:var(--c-gold);letter-spacing:.25em;margin-bottom:22px;padding-bottom:14px;border-bottom:1px solid var(--c-line);font-weight:500;text-transform:uppercase}
.footer-block p,.footer-block ul{font-family:var(--font-jp);font-size:13px;line-height:2.2;color:var(--c-text-l);font-weight:400;letter-spacing:.06em}
.footer-block ul{list-style:none}
.footer-block ul li{padding:2px 0}
.footer-block ul a{transition:color .3s}
.footer-block ul a:hover{color:var(--c-gold);opacity:1}
.footer-block .num{color:var(--c-ivory);font-family:var(--font-min);font-style:italic;font-size:20px;letter-spacing:.04em;font-weight:500;display:block;margin-bottom:6px}
.footer-bottom{border-top:1px solid var(--c-line);padding:36px 60px 0;max-width:1320px;margin:0 auto;text-align:center;font-family:var(--font-en);font-size:11px;color:var(--c-text-dim);letter-spacing:.25em;font-weight:500;text-transform:uppercase}
@media(max-width:900px){
  footer{padding:70px 0 30px}
  .footer-inner{grid-template-columns:1fr;gap:40px;padding:0 22px;margin-bottom:50px}
  .footer-bottom{padding:24px 22px 0;font-size:10px;letter-spacing:.15em}
}

/* =====================================================
   Page Hero (sub pages)
   ===================================================== */
.page-hero{position:relative;padding:140px 0 110px;background:var(--c-black);overflow:hidden;border-bottom:1px solid var(--c-line-gold)}
.page-hero::before{content:"";position:absolute;inset:0;background-image:url('/images/plan4-hero.png');background-size:cover;background-position:center;filter:grayscale(60%) brightness(.55) contrast(1.05);opacity:.6}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.7) 0%,rgba(10,10,10,.6) 50%,rgba(10,10,10,.95) 100%)}
.page-hero.interior::before{background-image:url('/images/plan4-interior.png')}
.page-hero .container{position:relative;z-index:2;text-align:center}
.page-hero .chapter{display:inline-flex;margin-bottom:36px;color:var(--c-gold)}
.page-hero h1{font-family:var(--font-min);font-weight:500;font-size:64px;line-height:1.5;letter-spacing:.08em;color:var(--c-ivory);margin-bottom:24px;font-feature-settings:"palt"}
.page-hero h1 .em{color:var(--c-gold);font-style:italic;font-weight:500}
.page-hero h1 .small{display:block;font-family:var(--font-en);font-style:italic;font-size:.32em;color:var(--c-gold-l);letter-spacing:.4em;margin-top:24px;font-weight:400;text-transform:uppercase;opacity:.85}
.page-hero p{font-family:var(--font-jp);font-size:15px;line-height:2.4;color:var(--c-text);letter-spacing:.1em;max-width:720px;margin:0 auto;font-weight:400}
.breadcrumb{margin-top:50px;font-family:var(--font-en);font-size:11px;color:var(--c-text-l);letter-spacing:.2em;text-transform:uppercase;display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap}
.breadcrumb a{color:var(--c-text-l);border-bottom:1px solid transparent;padding-bottom:2px;transition:all .3s}
.breadcrumb a:hover{color:var(--c-gold);border-bottom-color:var(--c-gold);opacity:1}
.breadcrumb span.sep{color:var(--c-gold)}
.breadcrumb span.here{color:var(--c-gold)}
@media(max-width:768px){
  .page-hero{padding:80px 0 70px}
  .page-hero h1{font-size:30px;line-height:1.6}
  .page-hero h1 .small{font-size:.42em;letter-spacing:.25em;margin-top:14px}
  .page-hero p{font-size:13px;line-height:2.2}
  .breadcrumb{margin-top:30px;font-size:10px;letter-spacing:.15em}
}

/* =====================================================
   Foot CTA (every page)
   ===================================================== */
.foot-cta{background:var(--c-charcoal);padding:140px 0;text-align:center;border-top:1px solid var(--c-line-gold);position:relative;overflow:hidden}
.foot-cta::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:120px;height:1px;background:var(--c-gold)}
.foot-cta .chapter{display:inline-flex;margin-bottom:30px}
.foot-cta h2{font-family:var(--font-min);font-weight:500;font-size:48px;line-height:1.5;color:var(--c-ivory);letter-spacing:.08em;margin-bottom:24px}
.foot-cta h2 .em{color:var(--c-gold);font-style:italic;font-weight:500}
.foot-cta p{font-family:var(--font-jp);font-size:14px;line-height:2.4;color:var(--c-text);letter-spacing:.1em;max-width:600px;margin:0 auto 50px;font-weight:400}
.foot-buttons{display:flex;justify-content:center;gap:24px;flex-wrap:wrap}
.foot-buttons a{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 50px;border:1px solid var(--c-gold);font-family:var(--font-min);font-size:14px;color:var(--c-gold);letter-spacing:.25em;line-height:1.4;min-width:280px;text-transform:uppercase;font-weight:500;transition:all .4s}
.foot-buttons a small{display:block;font-family:var(--font-en);font-size:10px;color:var(--c-gold-d);letter-spacing:.3em;margin-bottom:10px;font-style:italic;font-weight:500;text-transform:uppercase}
.foot-buttons a .num{font-family:var(--font-min);font-style:italic;font-size:26px;color:var(--c-ivory);font-weight:500;letter-spacing:.04em;margin:4px 0}
.foot-buttons a.form{background:var(--c-gold);color:var(--c-black);border-color:var(--c-gold)}
.foot-buttons a.form small{color:rgba(10,10,10,.7)}
.foot-buttons a:hover{background:var(--c-gold);color:var(--c-black);opacity:1}
.foot-buttons a:hover small{color:rgba(10,10,10,.7)}
.foot-buttons a:hover .num{color:var(--c-black)}
.foot-buttons a.form:hover{background:transparent;color:var(--c-gold)}
.foot-buttons a.form:hover small{color:var(--c-gold-d)}
@media(max-width:768px){
  .foot-cta{padding:80px 0}
  .foot-cta h2{font-size:24px;line-height:1.6}
  .foot-buttons{flex-direction:column;align-items:center}
  .foot-buttons a{min-width:280px;padding:18px 30px}
}

/* =====================================================
   Reveal animation
   ===================================================== */
@keyframes revealUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0}
.reveal.in{animation:revealUp 1.4s cubic-bezier(.2,.7,.2,1) both}

/* =====================================================
   Misc
   ===================================================== */
.gold{color:var(--c-gold)}
.ivory{color:var(--c-ivory)}
.center{text-align:center}
.mt-50{margin-top:50px}
.mt-80{margin-top:80px}

/* anchor offset (because of fixed nav) */
section[id]{scroll-margin-top:80px}

/* Voice cards (お客様の声) */
.voice-list{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:1320px;margin:60px auto 0;padding:0 60px}
.voice-card{padding:42px 36px;border:1px solid var(--c-line);background:var(--c-charcoal);transition:border-color .4s}
.voice-card:hover{border-color:var(--c-gold)}
.voice-card .stars{font-family:var(--font-en);color:var(--c-gold);letter-spacing:.2em;margin-bottom:18px;font-size:18px}
.voice-card h4{font-family:var(--font-min);font-size:18px;color:var(--c-ivory);letter-spacing:.06em;font-weight:600;margin-bottom:16px;line-height:1.6}
.voice-card p{font-family:var(--font-jp);font-size:13px;line-height:2.2;color:var(--c-text);letter-spacing:.06em;margin-bottom:24px}
.voice-card .meta{padding-top:20px;border-top:1px solid var(--c-line);font-family:var(--font-en);font-size:11px;color:var(--c-gold);letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.voice-card .meta strong{display:block;font-family:var(--font-min);font-style:normal;color:var(--c-ivory);font-size:14px;letter-spacing:.08em;margin-bottom:6px;font-weight:600}
@media(max-width:900px){.voice-list{grid-template-columns:1fr;padding:0 22px;gap:18px}.voice-card{padding:30px 24px}}

/* FAQ */
.faq-list{max-width:980px;margin:60px auto 0;padding:0 60px}
.faq-item{border-bottom:1px solid var(--c-line)}
.faq-item:first-child{border-top:1px solid var(--c-line)}
.faq-item summary{list-style:none;padding:28px 50px 28px 50px;cursor:pointer;font-family:var(--font-min);font-size:16px;color:var(--c-ivory);letter-spacing:.08em;font-weight:500;line-height:1.7;position:relative;transition:color .3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:"Q.";position:absolute;left:0;top:28px;font-family:var(--font-en);font-style:italic;color:var(--c-gold);font-size:18px;font-weight:500;letter-spacing:.05em}
.faq-item summary::after{content:"+";position:absolute;right:0;top:24px;font-family:var(--font-en);color:var(--c-gold);font-size:28px;line-height:1;transition:transform .3s;font-weight:300}
.faq-item[open] summary{color:var(--c-gold)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-answer{padding:0 50px 36px 50px;font-family:var(--font-jp);font-size:14px;color:var(--c-text);line-height:2.4;letter-spacing:.06em;position:relative}
.faq-answer::before{content:"A.";position:absolute;left:0;top:-2px;font-family:var(--font-en);font-style:italic;color:var(--c-gold);font-size:18px;font-weight:500;letter-spacing:.05em}
@media(max-width:768px){
  .faq-list{padding:0 22px}
  .faq-item summary{padding:22px 36px 22px 36px;font-size:14px}
  .faq-item summary::before,.faq-answer::before{font-size:15px}
  .faq-answer{padding:0 36px 26px 36px;font-size:13px}
}

/* Area (対応エリア) */
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;max-width:1080px;margin:60px auto 0;padding:0 60px}
.area-block{padding:46px 36px;border:1px solid var(--c-line);background:var(--c-charcoal)}
.area-block h4{font-family:var(--font-min);font-size:22px;color:var(--c-gold);letter-spacing:.1em;font-weight:600;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--c-line-gold);font-style:italic}
.area-block p{font-family:var(--font-jp);font-size:13px;line-height:2.2;color:var(--c-text);letter-spacing:.06em;font-weight:400}
@media(max-width:768px){.area-grid{grid-template-columns:1fr;padding:0 22px;gap:18px}.area-block{padding:30px 24px}}
