@charset "utf-8";
/* =========================================================
   JERAFURE  —  看板 / 店舗デザイン  Renewal
   Design concept: "SIGN PLATE" editorial
   Each section heading is mounted like a real cut-letter sign.
   ========================================================= */

:root{
  --paper:#F4F0E8;      /* warm wall the sign mounts on */
  --paper-2:#ECE5D8;
  --paper-3:#E4DBC9;
  --ink:#1A1714;        /* warm near-black, text only */
  --ink-soft:#544C42;
  --ink-mute:#857B6C;
  --brand:#E66511;      /* ジェラフレ brand orange (from logo) — action */
  --brand-deep:#C2530C;
  --brand-bright:#F0791F;
  --navy:#123034;       /* deep teal-ink — structure / trust */
  --navy-2:#0B2024;
  --charcoal:#201D1B;   /* dark editorial ground (showcase) */
  --charcoal-2:#2A2624;
  --brass:#C08A2D;      /* craft accent */
  --line:#D9D0BF;
  --line-soft:#E6DECF;
  --white:#FFFFFF;
  --shadow-plate:0 14px 30px -12px rgba(26,23,20,.34);
  --shadow-soft:0 18px 50px -20px rgba(18,48,52,.45);
  --maxw:1180px;
  --gut:clamp(20px,5vw,56px);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN",sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.85;
  font-weight:400;
  letter-spacing:.02em;
  font-feature-settings:"palt";
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}
h1,h2,h3,h4,p{margin:0}
strong{color:var(--brand-deep);font-weight:700}

.jp-disp{font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;}
.mincho{font-family:"Shippori Mincho","Noto Serif JP",serif;}
.en{font-family:"Anton",sans-serif;font-weight:400;letter-spacing:.04em;}

/* ===== layout helpers ===== */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--tight{padding-block:clamp(48px,6vw,80px)}
.center{text-align:center}
.clear{clear:both}

/* =========================================================
   SIGNATURE — the "sign plate" heading device
   ========================================================= */
.plate{
  display:inline-flex;align-items:center;gap:.7em;
  position:relative;
  padding:.5em 1.15em;
  background:var(--navy);
  color:#F4F0E8;
  border-radius:5px;
  box-shadow:var(--shadow-plate);
  font-family:"Zen Kaku Gothic New",sans-serif;
  font-weight:900;
}
.plate::before,.plate::after{
  content:"";position:absolute;top:50%;width:7px;height:7px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#5d7a7d,#0a181a 70%);
  transform:translateY(-50%);
}
.plate::before{left:7px}
.plate::after{right:7px}
.plate--brand{background:var(--brand)}
.plate--brand::before,.plate--brand::after{background:radial-gradient(circle at 35% 30%,#ff8a6b,#7e1c08 70%)}

/* eyebrow + heading block */
.head{margin-bottom:clamp(30px,4vw,48px)}
.head__ey{
  display:flex;align-items:center;gap:.6em;
  font-family:"Anton",sans-serif;font-size:clamp(13px,1.4vw,15px);
  letter-spacing:.16em;color:var(--brand);text-transform:uppercase;margin-bottom:18px;
}
.head__ey::before{content:"";width:34px;height:3px;background:var(--brand);display:inline-block}
.head__ttl{
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;
  font-size:clamp(27px,4.6vw,46px);line-height:1.28;letter-spacing:.01em;
}
.head__ttl .hl{
  background:linear-gradient(transparent 62%,rgba(224,65,28,.22) 62%);
  padding-inline:.05em;
}
.head--c{text-align:center}
.head--c .head__ey{justify-content:center}
.head__sub{margin-top:16px;color:var(--ink-soft);font-size:clamp(14px,1.7vw,16px);font-weight:500}

/* =========================================================
   HEADER
   ========================================================= */
#pagehead{
  position:fixed;inset:0 0 auto 0;z-index:120;
  background:rgba(244,240,232,.92);
  backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--line);
  transition:transform .35s ease,box-shadow .35s;
}
#pagehead.hide{transform:translateY(-100%)}
#pagehead.scrolled{box-shadow:0 8px 24px -16px rgba(26,23,20,.4)}
#pagehead .inr{
  max-width:var(--maxw);margin-inline:auto;
  display:flex;align-items:center;gap:18px;
  padding:14px var(--gut);
}
#logo{margin-right:auto;line-height:1}
#logo a{display:flex;align-items:center;gap:.7em}
#logo img{height:clamp(30px,3.4vw,38px);width:auto;display:block}
#logo .lt{
  font-family:"Anton",sans-serif;font-size:11px;letter-spacing:.16em;
  color:var(--ink-mute);text-transform:uppercase;border-left:1px solid var(--line);padding-left:.8em;
}
#gnv{display:flex;gap:clamp(14px,2vw,30px);align-items:center}
#gnv a{
  font-weight:700;font-size:15px;position:relative;padding-block:6px;color:var(--ink);
}
#gnv a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--brand);
  transition:width .25s ease;
}
#gnv a:hover::after,#gnv a:focus-visible::after{width:100%}
#snv{display:flex;gap:10px;align-items:center}
.btn-tel{
  display:flex;flex-direction:column;line-height:1.05;text-align:right;padding-right:4px;
}
.btn-tel .num{font-family:"Anton",sans-serif;font-size:20px;letter-spacing:.02em;color:var(--ink)}
.btn-tel .lb{font-size:10px;color:var(--ink-mute);font-weight:700;letter-spacing:.08em}
.btn-cta{
  display:inline-flex;align-items:center;gap:.5em;
  background:var(--brand);color:#fff;font-weight:900;
  font-family:"Zen Kaku Gothic New",sans-serif;
  padding:.72em 1.25em;border-radius:6px;font-size:14px;letter-spacing:.04em;
  box-shadow:0 10px 22px -10px rgba(224,65,28,.7);
  transition:transform .2s,box-shadow .2s,background .2s;white-space:nowrap;
}
.btn-cta:hover{transform:translateY(-2px);background:var(--brand-deep);box-shadow:0 16px 28px -10px rgba(224,65,28,.75)}
#open_menu{display:none}

/* burger */
.burger{width:46px;height:40px;border:none;background:var(--navy);border-radius:6px;position:relative;cursor:pointer}
.burger span{position:absolute;left:11px;right:11px;height:2.5px;background:#fff;border-radius:2px;transition:.3s}
.burger span:nth-child(1){top:13px}
.burger span:nth-child(2){top:19px}
.burger span:nth-child(3){top:25px}
body.nav-open .burger span:nth-child(1){top:19px;transform:rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){top:19px;transform:rotate(-45deg)}

/* =========================================================
   HERO
   ========================================================= */
/* full-bleed key visual */
#hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;isolation:isolate;
}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
#hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(20,18,16,.62) 0%,rgba(20,18,16,.12) 34%,rgba(20,18,16,.5) 72%,rgba(20,18,16,.92) 100%),
    linear-gradient(90deg,rgba(20,18,16,.55),transparent 60%);
}
.hero__inner{
  max-width:var(--maxw);margin-inline:auto;width:100%;
  padding:0 var(--gut) clamp(58px,10vh,118px);
}
.hero__eyebrow{
  display:inline-block;font-family:"Anton",sans-serif;letter-spacing:.2em;
  font-size:clamp(11px,1.4vw,13px);color:var(--brand-bright);margin-bottom:20px;
}
.hero__big{
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;
  font-size:clamp(38px,8.4vw,100px);line-height:1.05;letter-spacing:.01em;
  text-shadow:0 8px 44px rgba(0,0,0,.45);
}
.hero__big .or{color:var(--brand-bright)}
.hero__big .sm{display:block;font-size:.42em;margin-top:.5em;font-weight:700;letter-spacing:.02em}
.hero__sub{margin-top:26px;font-size:clamp(14.5px,1.9vw,17px);font-weight:600;max-width:33em;color:#f1e9df;line-height:1.95;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.cta-lg{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:clamp(15px,1.8vw,17px);
  padding:1.02em 1.7em;border-radius:8px;transition:transform .2s,box-shadow .2s,background .2s,color .2s;
}
.cta-lg .ic{width:1.2em;height:1.2em;flex:none}
.cta-quote{background:var(--brand);color:#fff;box-shadow:0 14px 30px -12px rgba(230,101,17,.7)}
.cta-quote:hover{transform:translateY(-3px);background:var(--brand-deep)}
.cta-ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.7);backdrop-filter:blur(4px)}
.cta-ghost:hover{transform:translateY(-3px);background:#fff;color:var(--ink);border-color:#fff}
.cta-ghost .tel{font-family:"Anton",sans-serif;letter-spacing:.02em}
.cta-sub{font-size:11px;font-weight:700;opacity:.85;display:block;letter-spacing:.06em;margin-top:1px}
.hero__scroll{
  position:absolute;left:clamp(20px,5vw,56px);bottom:26px;z-index:2;
  font-family:"Anton",sans-serif;font-size:10px;letter-spacing:.22em;color:#fff;opacity:.85;
  writing-mode:vertical-rl;display:flex;align-items:center;gap:12px;
}
.hero__scroll::after{content:"";width:1.5px;height:50px;background:#fff;transform-origin:top;animation:scrolldrop 1.9s infinite ease-in-out}
@keyframes scrolldrop{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* =========================================================
   SHOWCASE — editorial skewed panels (store / sign design)
   ========================================================= */
#showcase{background:var(--charcoal);color:#fff;position:relative;overflow:hidden;padding:clamp(72px,11vw,128px) 0}
#showcase::before{
  content:"DESIGN";position:absolute;right:-2%;bottom:-4%;
  font-family:"Anton",sans-serif;font-size:24vw;color:rgba(255,255,255,.035);
  line-height:1;pointer-events:none;letter-spacing:.02em;
}
#showcase .wrap{position:relative;z-index:2}
.sc__head{text-align:center;margin-bottom:clamp(34px,5vw,60px)}
.sc__label{font-family:"Anton",sans-serif;letter-spacing:.2em;font-size:13px;color:var(--brand-bright)}
.sc__big{
  font-family:"Anton",sans-serif;font-size:clamp(50px,11.5vw,142px);line-height:.9;
  color:var(--brand);letter-spacing:.005em;margin-top:12px;
}
.sc__ja{display:inline-block;margin-top:22px;background:#fff;color:var(--charcoal);font-weight:900;font-family:"Zen Kaku Gothic New",sans-serif;padding:.55em 1.6em;border-radius:40px;font-size:clamp(13px,1.7vw,15px)}
.sc__stage{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,4vw,56px);max-width:1060px;margin:0 auto;perspective:1600px}
.sc__panel{position:relative;border-radius:6px;overflow:hidden;box-shadow:0 44px 80px -34px rgba(0,0,0,.8);transition:transform .5s cubic-bezier(.22,1,.36,1)}
.sc__panel img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/11;display:block}
.sc__panel--l{transform:rotateY(10deg) rotateZ(-1.2deg) translateY(10px)}
.sc__panel--r{transform:rotateY(-10deg) rotateZ(1.2deg)}
.sc__stage:hover .sc__panel--l{transform:rotateY(6deg) rotateZ(-.6deg) translateY(4px)}
.sc__stage:hover .sc__panel--r{transform:rotateY(-6deg) rotateZ(.6deg)}
.sc__cap{position:absolute;left:14px;bottom:14px;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);color:#fff;font-weight:700;font-size:12.5px;padding:.5em .9em;border-radius:4px}
.sc__badge{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-9deg);z-index:5;
  width:clamp(94px,13vw,138px);height:clamp(94px,13vw,138px);border-radius:50%;
  background:#fff;color:var(--charcoal);display:grid;place-content:center;text-align:center;
  font-family:"Anton",sans-serif;font-size:clamp(11px,1.4vw,14px);letter-spacing:.05em;line-height:1.25;
  box-shadow:0 24px 44px -18px rgba(0,0,0,.7);
}
.sc__badge .ar{color:var(--brand);font-size:1.3em}
.sc__lead{text-align:center;max-width:40em;margin:clamp(38px,5vw,58px) auto 0;color:#d6cec4;font-weight:500;line-height:2;font-size:clamp(14px,1.8vw,16px)}
.sc__cta{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-top:32px}

/* h1 seo (hidden visually but accessible) */

/* h1 seo (hidden visually but accessible) */
.seo-h1{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* =========================================================
   PROBLEM  (お悩み)
   ========================================================= */
#problem{background:var(--paper-2);position:relative}
.prob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.prob{
  background:#fff;border:1px solid var(--line-soft);border-radius:12px;
  padding:30px 26px;position:relative;
  box-shadow:0 10px 30px -22px rgba(26,23,20,.5);
}
.prob__q{
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;color:var(--navy);
  font-size:13px;letter-spacing:.1em;margin-bottom:12px;display:flex;align-items:center;gap:.4em;
}
.prob__q::before{content:"Q";font-family:"Anton",sans-serif;color:var(--brand);font-size:20px}
.prob p{font-size:15.5px;font-weight:700;line-height:1.7}
.prob__mark{position:absolute;right:18px;bottom:10px;font-family:"Shippori Mincho",serif;font-size:54px;color:var(--brand);opacity:.14;font-weight:700;line-height:1}
.prob-bridge{
  text-align:center;margin-top:clamp(32px,4vw,48px);
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;
  font-size:clamp(19px,3vw,30px);line-height:1.5;
}
.prob-bridge .em{color:var(--brand);position:relative;white-space:nowrap}
.prob-bridge .arw{display:block;color:var(--brand);font-size:1.4em;line-height:1;margin:.1em 0}

/* =========================================================
   REASONS  (選ばれる理由 — numbered)
   ========================================================= */
.reason{
  display:grid;grid-template-columns:1fr 1fr;align-items:center;
  gap:clamp(24px,5vw,68px);
  padding-block:clamp(34px,5vw,56px);border-bottom:1px solid var(--line);
}
.reason:last-child{border-bottom:none}
.reason:nth-child(even) .reason__media{order:2}
.reason__media{position:relative}
.reason__media img{width:100%;border-radius:10px;aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow-plate)}
.reason__no{
  position:absolute;left:-16px;top:-22px;
  font-family:"Anton",sans-serif;font-size:clamp(64px,9vw,108px);line-height:.8;
  color:var(--brand);opacity:.9;-webkit-text-stroke:2px #fff;text-stroke:2px #fff;
  text-shadow:0 6px 0 rgba(180,46,16,.25);
}
.reason__body .lab{
  display:inline-block;background:var(--navy);color:#fff;font-weight:900;font-size:12px;
  letter-spacing:.1em;padding:.35em .9em;border-radius:4px;margin-bottom:16px;
  font-family:"Zen Kaku Gothic New",sans-serif;
}
.reason__body h3{
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;
  font-size:clamp(21px,3vw,31px);line-height:1.35;margin-bottom:14px;
}
.reason__body h3 .hl{background:linear-gradient(transparent 60%,rgba(224,65,28,.2) 60%)}
.reason__body p{color:var(--ink-soft);font-size:15.5px;font-weight:500}

/* =========================================================
   SERVICES  (できること — sign plates)
   ========================================================= */
#services{background:var(--navy);color:#EDE7DC;position:relative;overflow:hidden}
#services::before{
  content:"SIGN / STORE / GRAPHIC";position:absolute;top:8%;left:-2%;
  font-family:"Anton",sans-serif;font-size:18vw;color:rgba(255,255,255,.035);
  white-space:nowrap;pointer-events:none;line-height:1;
}
#services .head__ttl{color:#fff}
#services .head__sub{color:#b9c4c2}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;position:relative}
.svc{
  position:relative;border-radius:12px;overflow:hidden;min-height:230px;
  display:flex;flex-direction:column;justify-content:flex-end;
  color:#fff;box-shadow:var(--shadow-plate);
}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease;filter:saturate(1.05)}
.svc::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,32,36,.05) 30%,rgba(11,32,36,.86))}
.svc:hover img{transform:scale(1.07)}
.svc__t{position:relative;z-index:2;padding:22px}
.svc__t .no{font-family:"Anton",sans-serif;font-size:13px;color:var(--brand);letter-spacing:.1em}
.svc__t h3{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:19px;margin:4px 0 6px}
.svc__t p{font-size:13px;color:#d7dad7;font-weight:500;line-height:1.6}

/* =========================================================
   CATEGORY preview
   ========================================================= */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cat{
  background:#fff;border-radius:12px;overflow:hidden;border:1px solid var(--line-soft);
  box-shadow:0 12px 30px -24px rgba(26,23,20,.6);transition:transform .25s,box-shadow .25s;
}
.cat:hover{transform:translateY(-4px);box-shadow:0 22px 40px -24px rgba(26,23,20,.5)}
.cat figure{margin:0;position:relative;aspect-ratio:16/11;overflow:hidden}
.cat figure img{width:100%;height:100%;object-fit:cover}
.cat__no{position:absolute;left:12px;top:12px;background:var(--brand);color:#fff;font-family:"Anton",sans-serif;font-size:13px;padding:.2em .6em;border-radius:4px}
.cat figcaption{
  padding:16px 18px;font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:16.5px;
  display:flex;align-items:center;justify-content:space-between;
}
.cat figcaption::after{content:"→";color:var(--brand);font-weight:900}

/* =========================================================
   WORKS gallery
   ========================================================= */
#works{background:var(--paper-2)}
.works-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:14px;grid-auto-flow:dense;
}
.work{position:relative;overflow:hidden;border-radius:10px;background:var(--navy);box-shadow:var(--shadow-plate)}
.work img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.work:hover img{transform:scale(1.06)}
.work figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:30px 16px 14px;color:#fff;
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:14px;
  background:linear-gradient(transparent,rgba(11,32,36,.85));
  opacity:0;transform:translateY(8px);transition:.3s;
}
.work:hover figcaption{opacity:1;transform:none}
.work .tag{font-family:"Anton",sans-serif;font-size:11px;color:#ffb9a4;display:block;letter-spacing:.08em}
.w-a{grid-column:span 7;aspect-ratio:16/10}
.w-b{grid-column:span 5;aspect-ratio:16/12}
.w-c{grid-column:span 4;aspect-ratio:4/3}
.w-d{grid-column:span 4;aspect-ratio:4/3}
.w-e{grid-column:span 4;aspect-ratio:4/3}
.w-f{grid-column:span 5;aspect-ratio:16/11}
.w-g{grid-column:span 7;aspect-ratio:16/8}

/* =========================================================
   FLOW (ご相談の流れ — numbered)
   ========================================================= */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;counter-reset:fl}
.flow__step{
  background:#fff;border-radius:12px;padding:28px 22px 24px;position:relative;
  border:1px solid var(--line-soft);box-shadow:0 10px 30px -24px rgba(26,23,20,.5);
}
.flow__step::before{
  counter-increment:fl;content:"0" counter(fl);
  font-family:"Anton",sans-serif;font-size:34px;color:var(--brand);line-height:1;display:block;margin-bottom:12px;
}
.flow__step h4{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:17px;margin-bottom:8px}
.flow__step p{font-size:13.5px;color:var(--ink-soft);font-weight:500}
.flow__step:not(:last-child)::after{
  content:"";position:absolute;right:-11px;top:50%;width:14px;height:14px;
  border-top:3px solid var(--brand);border-right:3px solid var(--brand);
  transform:translateY(-50%) rotate(45deg);z-index:2;
}

/* =========================================================
   GUARANTEE band (最安値保証)
   ========================================================= */
#guarantee{background:var(--brand);color:#fff;position:relative;overflow:hidden}
#guarantee::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 22px,transparent 22px 44px);
}
.guar{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,4vw,46px);align-items:center;position:relative}
.guar__seal{
  width:clamp(112px,16vw,160px);aspect-ratio:1;border-radius:50%;
  background:#fff;color:var(--brand);display:grid;place-content:center;text-align:center;
  box-shadow:0 18px 40px -16px rgba(0,0,0,.45);border:4px solid rgba(255,255,255,.5);
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;line-height:1.15;
}
.guar__seal b{font-family:"Anton",sans-serif;font-size:clamp(30px,4vw,44px);display:block;color:var(--brand-deep)}
.guar__seal span{font-size:12px}
.guar__t h2{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:clamp(23px,4vw,40px);line-height:1.3}
.guar__t p{margin-top:14px;font-size:clamp(14px,1.8vw,16px);font-weight:500;opacity:.95;max-width:44em}
.guar__t .mincho{display:inline-block;margin-top:18px;font-size:clamp(15px,2vw,19px);color:#fff5e9;border-top:1px solid rgba(255,255,255,.4);padding-top:14px}

/* =========================================================
   FAQ
   ========================================================= */
.faq{max-width:840px;margin-inline:auto;display:flex;flex-direction:column;gap:12px}
.faq details{
  background:#fff;border:1px solid var(--line-soft);border-radius:10px;overflow:hidden;
  box-shadow:0 8px 26px -24px rgba(26,23,20,.5);
}
.faq summary{
  list-style:none;cursor:pointer;padding:20px 56px 20px 56px;position:relative;
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:16px;line-height:1.6;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{
  content:"Q";position:absolute;left:18px;top:18px;font-family:"Anton",sans-serif;color:#fff;
  background:var(--brand);width:26px;height:26px;border-radius:5px;display:grid;place-content:center;font-size:15px;
}
.faq summary::after{
  content:"";position:absolute;right:22px;top:50%;width:11px;height:11px;
  border-right:2.5px solid var(--ink-mute);border-bottom:2.5px solid var(--ink-mute);
  transform:translateY(-65%) rotate(45deg);transition:.3s;
}
.faq details[open] summary::after{transform:translateY(-30%) rotate(-135deg)}
.faq__a{padding:0 24px 22px 56px;color:var(--ink-soft);font-size:15px;font-weight:500}

/* =========================================================
   FINAL CTA
   ========================================================= */
#finalcta{background:var(--navy-2);color:#fff;position:relative;overflow:hidden;text-align:center}
#finalcta::before{
  content:"CONTACT";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:"Anton",sans-serif;font-size:26vw;color:rgba(255,255,255,.03);white-space:nowrap;line-height:1;pointer-events:none;
}
.fc{position:relative;z-index:2}
.fc__ey{font-family:"Anton",sans-serif;color:var(--brand);letter-spacing:.18em;font-size:15px}
.fc h2{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:clamp(26px,5vw,48px);line-height:1.3;margin:14px 0 10px}
.fc p{color:#c2cbca;font-weight:500;margin-bottom:34px}
.fc__btns{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}
.fc__tel{margin-top:30px;color:#aeb8b7;font-weight:500;font-size:14px}
.fc__tel a{font-family:"Anton",sans-serif;color:#fff;font-size:clamp(26px,4vw,38px);display:block;letter-spacing:.02em;margin-top:4px}
.fc__tel small{font-size:12px;color:#8f9a99}

/* =========================================================
   FOOTER
   ========================================================= */
#pagefoot{background:var(--ink);color:#cfc7ba;padding-block:clamp(48px,6vw,72px) 0}
#pagefoot .wrap{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:36px}
#f_logo img{height:38px;width:auto;display:block}
.foot__phil{margin-top:18px;font-size:14px;line-height:1.9;color:#a99f90;max-width:24em}
.foot__col h5{color:#fff;font-weight:900;font-family:"Zen Kaku Gothic New",sans-serif;font-size:14px;letter-spacing:.08em;margin-bottom:16px}
.foot__col li{margin-bottom:10px}
.foot__col a{font-size:14px;color:#bcb3a5;transition:color .2s}
.foot__col a:hover{color:#fff}
.foot__info{font-size:13.5px;line-height:1.9;color:#a99f90}
.foot__info b{color:#e6ddcf;display:block;margin-bottom:6px;font-size:15px}
#copy{text-align:center;font-size:12px;color:#7d7466;padding:30px var(--gut);margin-top:clamp(40px,5vw,60px);border-top:1px solid rgba(255,255,255,.08)}

/* =========================================================
   MOBILE sticky CTA bar
   ========================================================= */
#mbar{
  position:fixed;left:0;right:0;bottom:0;z-index:130;display:none;
  grid-template-columns:1fr 1.4fr;
  background:var(--ink);box-shadow:0 -8px 24px -12px rgba(0,0,0,.5);
  padding:8px;gap:8px;
}
#mbar a{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  padding:9px 4px;border-radius:8px;font-weight:900;font-size:12px;color:#fff;
  font-family:"Zen Kaku Gothic New",sans-serif;line-height:1.1;
}
#mbar .ic{width:20px;height:20px}
#mbar .m-tel{background:var(--navy)}
#mbar .m-line{background:#06C755}
#mbar .m-quote{background:var(--brand)}

/* =========================================================
   PAGE TOP
   ========================================================= */
#pagetop{position:fixed;right:18px;bottom:90px;z-index:110;opacity:0;visibility:hidden;transition:.3s}
#pagetop.on{opacity:1;visibility:visible}
#pagetop a{
  display:grid;place-content:center;width:46px;height:46px;background:var(--navy);color:#fff;border-radius:50%;
  font-size:0;box-shadow:var(--shadow-plate);
}
#pagetop a::before{content:"";width:11px;height:11px;border-top:2.5px solid #fff;border-left:2.5px solid #fff;transform:rotate(45deg) translate(2px,2px)}

/* =========================================================
   SUB-PAGE header banner
   ========================================================= */
#d_screen{
  margin-top:118px;padding:clamp(54px,9vw,104px) var(--gut);
  background:var(--navy);color:#fff;position:relative;overflow:hidden;text-align:center;
}
#d_screen::before{
  content:attr(data-en);position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:"Anton",sans-serif;font-size:21vw;color:rgba(255,255,255,.04);white-space:nowrap;line-height:1;pointer-events:none;
}
#d_screen .inr{position:relative;z-index:2}
#d_screen .jp{display:block;font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:clamp(26px,5vw,44px);letter-spacing:.04em}
#d_screen .en2{display:block;font-family:"Anton",sans-serif;color:var(--brand);letter-spacing:.16em;font-size:14px;margin-top:12px}
.crumb{font-size:12px;color:var(--ink-mute);padding:16px var(--gut) 0;max-width:var(--maxw);margin-inline:auto}
.crumb a:hover{color:var(--brand)}

/* sub-page generic prose */
.lede{font-size:clamp(15px,2vw,17px);color:var(--ink-soft);font-weight:500;line-height:2;max-width:62em}
.note-box{
  background:#fff;border:1px solid var(--line-soft);border-left:5px solid var(--brand);
  border-radius:8px;padding:24px 28px;margin-top:24px;box-shadow:0 10px 30px -24px rgba(26,23,20,.5);
}

/* about table */
.tb1{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 12px 30px -24px rgba(26,23,20,.5)}
.tb1 th,.tb1 td{padding:18px 22px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line-soft);font-size:15px}
.tb1 th{background:var(--navy);color:#fff;font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;width:170px;white-space:nowrap}
.tb1 tr:last-child th,.tb1 tr:last-child td{border-bottom:none}

/* category detail cards */
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:14px}
.dcard{background:#fff;border-radius:12px;overflow:hidden;border:1px solid var(--line-soft);box-shadow:0 12px 30px -24px rgba(26,23,20,.5)}
.dcard figure{margin:0;position:relative;aspect-ratio:16/11;overflow:hidden}
.dcard figure img{width:100%;height:100%;object-fit:cover}
.dcard figcaption{position:absolute;left:12px;bottom:12px;background:var(--brand);color:#fff;font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:14px;padding:.35em .8em;border-radius:4px}
.dcard__b{padding:18px 20px 22px;font-size:14px;color:var(--ink-soft);font-weight:500;line-height:1.8}

.two-box{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.tbx{background:#fff;border-radius:12px;padding:30px;border:1px solid var(--line-soft);box-shadow:0 12px 30px -24px rgba(26,23,20,.5)}
.tbx h3{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:20px;color:var(--navy);margin-bottom:12px;display:flex;align-items:center;gap:.5em}
.tbx h3 .en{color:var(--brand);font-size:14px}
.tbx p{color:var(--ink-soft);font-size:15px;font-weight:500}

/* contact form */
#form-intro{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:34px}
.fi-card{display:flex;gap:16px;align-items:center;background:#fff;border:1px solid var(--line-soft);border-radius:12px;padding:22px 24px;box-shadow:0 10px 30px -24px rgba(26,23,20,.5)}
.fi-card .ic{width:48px;height:48px;border-radius:10px;display:grid;place-content:center;flex:none;color:#fff}
.fi-card.line .ic{background:#06C755}
.fi-card.mail .ic{background:var(--brand)}
.fi-card.tel .ic{background:var(--navy)}
.fi-card.info .ic{background:var(--paper-3);color:var(--brand)}
.fi-card b{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:17px;display:block}
.fi-card .num{font-family:"Anton",sans-serif;font-size:22px;color:var(--brand)}
.fi-card span{font-size:12.5px;color:var(--ink-mute);font-weight:600}

.box_anti{position:absolute;left:-9999px}
.form-tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 14px 36px -26px rgba(26,23,20,.5)}
.form-tbl th,.form-tbl td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--line-soft);vertical-align:top}
.form-tbl th{background:var(--paper-2);font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:14.5px;width:200px;white-space:nowrap}
.required{display:inline-block;background:var(--brand);color:#fff;font-size:10px;font-weight:900;padding:.2em .55em;border-radius:3px;margin-left:.6em;vertical-align:middle}
.any{display:inline-block;background:var(--paper-3);color:var(--ink-soft);font-size:10px;font-weight:900;padding:.2em .55em;border-radius:3px;margin-left:.6em;vertical-align:middle}
.form-tbl input[type=file].file-in{
  width:100%;max-width:480px;font:inherit;font-size:14px;padding:.55em .7em;border:1.5px dashed var(--line);border-radius:7px;background:var(--paper);color:var(--ink-soft);cursor:pointer;
}
.form-tbl input[type=file].file-in::file-selector-button{
  font:inherit;font-weight:900;font-size:13px;color:#fff;background:var(--navy);border:none;border-radius:6px;padding:.55em 1.1em;margin-right:12px;cursor:pointer;
}
.form-tbl input[type=file].file-in::file-selector-button:hover{background:var(--brand)}
.form-tbl input[type=text],.form-tbl textarea,.form-tbl select{
  width:100%;max-width:480px;font:inherit;font-size:15px;padding:.7em .8em;border:1.5px solid var(--line);border-radius:7px;background:var(--paper);color:var(--ink);
}
.form-tbl input:focus,.form-tbl textarea:focus,.form-tbl select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(224,65,28,.15)}
.form-tbl textarea{min-height:160px;resize:vertical}
.form-tbl .example{font-size:12px;color:var(--ink-mute);display:block;margin-top:6px}
.form-lead{font-size:15px;font-weight:600;color:var(--ink-soft);line-height:1.9;margin-bottom:8px}
#btn_submit{text-align:center;margin-top:30px}
#btn_submit input{
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:18px;color:#fff;
  background:var(--brand);border:none;border-radius:9px;padding:1.1em 3em;cursor:pointer;letter-spacing:.06em;
  box-shadow:0 16px 32px -14px rgba(224,65,28,.7);transition:transform .2s,background .2s;
}
#btn_submit input:hover{transform:translateY(-2px);background:var(--brand-deep)}

/* =========================================================
   REVEAL animation
   ========================================================= */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}.rv.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1000px){
  .reason{grid-template-columns:1fr;gap:24px}
  .reason:nth-child(even) .reason__media{order:0}
  .reason__no{left:-6px;top:-30px}
  .svc-grid,.cat-grid,.detail-grid{grid-template-columns:repeat(2,1fr)}
  .flow{grid-template-columns:repeat(2,1fr)}
  .flow__step:nth-child(2)::after{display:none}
  #pagefoot .wrap{grid-template-columns:1fr 1fr}
  #f_logo{grid-column:1/-1}
}
@media (max-width:760px){
  #gnv,#snv .btn-tel{display:none}
  #snv .btn-cta{display:none}
  #open_menu{display:block}
  #hero{min-height:88svh}
  .hero__scroll{display:none}
  .sc__stage{grid-template-columns:1fr;max-width:440px;gap:30px;perspective:none}
  .sc__panel--l,.sc__panel--r{transform:none}
  .sc__stage:hover .sc__panel--l,.sc__stage:hover .sc__panel--r{transform:none}
  .sc__badge{display:none}
  .prob-grid{grid-template-columns:1fr}
  .two-box,#form-intro{grid-template-columns:1fr}
  .works-grid > *{grid-column:1/-1 !important;aspect-ratio:16/10 !important}
  #mbar{display:grid}
  body{padding-bottom:74px}
  #pagetop{bottom:84px}
  #pagehead .inr{padding:12px var(--gut)}
  .form-tbl th{width:auto;display:block;border-bottom:none;padding-bottom:6px}
  .form-tbl td{display:block;padding-top:6px}
}
@media (max-width:480px){
  .svc-grid,.cat-grid,.detail-grid,.flow{grid-template-columns:1fr}
  #pagefoot .wrap{grid-template-columns:1fr}
}

/* =========================================================
   SLIDE MENU (mobile drawer)
   ========================================================= */
#navdrawer{
  position:fixed;inset:0;z-index:200;visibility:hidden;
}
#navdrawer .ov{position:absolute;inset:0;background:rgba(11,32,36,.55);opacity:0;transition:.3s}
#navdrawer .panel{
  position:absolute;top:0;right:0;height:100%;width:min(82vw,360px);
  background:var(--paper);transform:translateX(100%);transition:transform .35s cubic-bezier(.3,.7,.2,1);
  padding:80px 30px 30px;box-shadow:-20px 0 50px -20px rgba(0,0,0,.4);overflow:auto;
}
body.nav-open #navdrawer{visibility:visible}
body.nav-open #navdrawer .ov{opacity:1}
body.nav-open #navdrawer .panel{transform:none}
#navdrawer .panel a{display:block;font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:19px;padding:16px 0;border-bottom:1px solid var(--line)}
#navdrawer .panel a .en{display:block;font-family:"Anton",sans-serif;font-size:11px;color:var(--brand);letter-spacing:.12em}
#navdrawer .panel .draw-cta{margin-top:24px;display:flex;flex-direction:column;gap:12px}
#navdrawer .close{position:absolute;top:22px;right:24px;width:40px;height:40px;border:none;background:var(--navy);border-radius:8px;cursor:pointer}
#navdrawer .close::before,#navdrawer .close::after{content:"";position:absolute;left:11px;right:11px;top:19px;height:2.5px;background:#fff}
#navdrawer .close::before{transform:rotate(45deg)}
#navdrawer .close::after{transform:rotate(-45deg)}

/* trust JP-big override */
.trust__cell b.b-jp{font-family:"Zen Kaku Gothic New",sans-serif;font-size:clamp(20px,3vw,28px);line-height:1.18}
