/* hokuryo-service stylesheet — extracted for Vercel deployment */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#2563eb;--bdk:#1d4ed8;--blu-lt:#eff6ff;
  --sl9:#0f172a;--sl8:#1e293b;--sl7:#334155;--sl6:#475569;--sl5:#64748b;
  --sl2:#e2e8f0;--sl1:#f1f5f9;--sl0:#f8fafc;
  --accent:#0ea5e9;
  --radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;
  --shadow-sm:0 1px 4px rgba(0,0,0,.06);
  --shadow-md:0 4px 20px rgba(0,0,0,.08);
  --shadow-lg:0 12px 40px rgba(0,0,0,.12);
  --shadow-blue:0 8px 28px rgba(37,99,235,.28);
  --transition:.28s cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;color:var(--sl8);background:#fff;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(245,247,252,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(226,232,240,.6);box-shadow:0 1px 24px rgba(0,0,0,.06)}
.ni{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 36px;height:62px}
.logo{display:flex;align-items:center;gap:10px;cursor:pointer}
.logo-ic{display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-txt{line-height:1.15}
.logo-en1{font-family:'Dancing Script',cursive;font-size:17px;font-weight:700;color:#1a1a2e;display:block;letter-spacing:.01em}
.logo-en2{font-family:'Dancing Script',cursive;font-size:14px;font-weight:600;color:#1a1a2e;display:block;margin-top:-2px;letter-spacing:.01em}
.nl{display:flex;align-items:center;gap:24px}
.nb{font-size:14px;font-weight:500;color:var(--sl8);background:none;border:none;cursor:pointer;font-family:'Noto Sans JP',sans-serif;transition:color .18s;padding:4px 0;position:relative}
.nb::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--blue);transform:scaleX(0);transition:transform .2s;transform-origin:center}
.nb:hover,.nb.act{color:var(--blue)}.nb:hover::after,.nb.act::after{transform:scaleX(1)}

/* PAGES */
.pg{display:none}.pg.on{display:block}

/* HERO */
.hero{position:relative;height:100vh;min-height:580px;display:flex;align-items:center;overflow:hidden;margin-top:62px}
.slide-bg{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;background-size:cover;background-position:center;z-index:1}.slide-bg.act{opacity:1}#sbg-0{background:linear-gradient(rgba(10,30,80,.52),rgba(5,20,60,.62)),url('../images/bg-01.jpg') center/cover no-repeat}#sbg-1{background:linear-gradient(rgba(10,30,80,.52),rgba(5,20,60,.62)),url('../images/bg-02.jpg') center/cover no-repeat}#sbg-2{background:linear-gradient(rgba(10,30,80,.52),rgba(5,20,60,.62)),url('../images/bg-03.jpg') center/cover no-repeat}
.harr{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.35);color:#fff;font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;user-select:none;transition:background .2s}
.harr:hover{background:rgba(255,255,255,.28)}
.hl{left:18px}.hr{right:18px}
.hc{position:relative;z-index:5;padding:0 76px;max-width:860px}
.hsub{font-size:13px;letter-spacing:.18em;color:rgba(255,255,255,.82);text-transform:uppercase;margin-bottom:18px;font-family:sans-serif;font-weight:400}
.ht1{font-size:clamp(46px,7.2vw,82px);font-weight:900;line-height:1.08;color:#fff;margin-bottom:4px;letter-spacing:-.01em}
.ht2{font-size:clamp(34px,5.5vw,64px);font-weight:900;line-height:1.1;color:#7eb8ff;margin-bottom:52px;letter-spacing:-.01em}
.hbtns{display:flex;gap:14px;flex-wrap:wrap}
.bpw{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#111;border:none;padding:13px 28px;font-size:15px;font-weight:700;border-radius:100px;cursor:pointer;font-family:'Noto Sans JP',sans-serif;box-shadow:0 3px 14px rgba(0,0,0,.18);transition:all .22s}
.bpw:hover{background:#f0f4ff;transform:translateY(-2px)}
.bpo{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;border:2px solid rgba(255,255,255,.78);padding:13px 28px;font-size:15px;font-weight:700;border-radius:100px;cursor:pointer;font-family:'Noto Sans JP',sans-serif;transition:all .22s}
.bpo:hover{background:rgba(255,255,255,.13);transform:translateY(-2px)}
.hbar{position:absolute;bottom:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#60a5fa,#2563eb,#1d4ed8);z-index:10}

/* SECTIONS */
.sp{padding:88px 32px}
.si{max-width:1200px;margin:0 auto}
.sl{font-size:11.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin-bottom:10px}
.st{font-size:clamp(26px,3.5vw,38px);font-weight:900;line-height:1.2;color:var(--sl9);letter-spacing:-.01em;margin-bottom:14px}
.sd{font-size:15px;line-height:1.8;color:var(--sl6);max-width:540px}

/* FEAT */
.fg{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.fc{background:#fff;border:1px solid var(--sl2);border-radius:14px;padding:30px;transition:all .3s}
.fc:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(0,0,0,.08);border-color:rgba(37,99,235,.2)}
.fi{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}
.ib{background:#eff6ff}.ip{background:#f5f3ff}.ig{background:#f0fdf4}.io{background:#fff7ed}.ipk{background:#fdf2f8}.ii{background:#eef2ff}
.ft{font-size:16px;font-weight:700;color:var(--sl9);margin-bottom:8px}
.fd{font-size:13.5px;line-height:1.8;color:var(--sl6)}

/* SRV */
.svg2{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.svc{border-radius:18px;overflow:hidden;border:1px solid var(--sl2);transition:all .4s;background:#fff}
.svc:hover{transform:translateY(-8px);box-shadow:0 24px 48px rgba(0,0,0,.15)}
.svt{height:150px;display:flex;align-items:center;justify-content:center;font-size:52px;position:relative}
.s1{background:linear-gradient(135deg,#1e3a8a,#3b82f6)}.s2{background:linear-gradient(135deg,#4c1d95,#8b5cf6)}.s3{background:linear-gradient(135deg,#134e4a,#0d9488)}
.svb{padding:22px}
.svtl{font-size:16px;font-weight:700;color:var(--sl9);margin-bottom:7px}
.svd{font-size:13px;line-height:1.8;color:var(--sl6);margin-bottom:14px}
.svtgs{display:flex;gap:6px;flex-wrap:wrap}
.svtg{background:var(--sl1);color:var(--sl6);font-size:11px;font-weight:500;padding:3px 9px;border-radius:5px}
.svl{display:flex;align-items:center;gap:5px;color:var(--blue);font-size:12.5px;font-weight:600;margin-top:12px;cursor:pointer;background:none;border:none;padding:0;font-family:'Noto Sans JP',sans-serif}

/* ABOUT dark */
.abs{background:linear-gradient(135deg,#0f172a,#1e3a8a);position:relative;overflow:hidden;padding:96px 32px}
.abs::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 0 50%,rgba(59,130,246,.12),transparent 60%);pointer-events:none}
.absi{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;position:relative;z-index:2}
.abs .sl{color:#60a5fa}.abs .st{color:#fff}.abs .sd{color:rgba(255,255,255,.6);max-width:440px}
.afs{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.af{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:10px;padding:12px 18px;transition:all .3s}
.af:hover{background:rgba(255,255,255,.1)}
.aft{font-size:13.5px;font-weight:500;color:rgba(255,255,255,.9)}
.abr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.as{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.11);border-radius:14px;padding:26px 22px;text-align:center;transition:all .3s}
.as:hover{background:rgba(255,255,255,.12);transform:translateY(-3px)}
.asn{font-size:36px;font-weight:800;line-height:1;background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.asl{font-size:12px;color:rgba(255,255,255,.55);margin-top:7px}

/* WORKS */
.wkg{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:52px}
.wkc{background:#fff;border:1px solid var(--sl2);border-radius:14px;overflow:hidden;transition:all .3s}
.wkc:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(0,0,0,.1)}
.wki{height:165px;display:flex;align-items:center;justify-content:center;font-size:44px;position:relative}
.w1{background:linear-gradient(135deg,#0f172a,#1e3a8a)}.w2{background:linear-gradient(135deg,#1e1b4b,#4c1d95)}.w3{background:linear-gradient(135deg,#0c4a6e,#0369a1)}.w4{background:linear-gradient(135deg,#052e16,#065f46)}.w5{background:linear-gradient(135deg,#450a0a,#991b1b)}.w6{background:linear-gradient(135deg,#2d1b69,#7c3aed)}
.wtg{position:absolute;top:11px;left:11px;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:5px}
.wkb{padding:17px}
.wktl{font-size:14px;font-weight:700;color:var(--sl9);margin-bottom:4px}
.wks{font-size:12px;color:var(--sl6)}
.wkm{display:flex;gap:10px;margin-top:11px;padding-top:11px;border-top:1px solid var(--sl1);font-size:11px;color:#94a3b8}

/* FLOW */
.fls{display:flex;margin-top:52px}
.flst{flex:1;text-align:center;position:relative;padding:0 8px}
.flst::after{content:'→';position:absolute;top:22px;right:-10px;font-size:16px;color:var(--blue)}
.flst:last-child::after{display:none}
.flc{width:48px;height:48px;background:linear-gradient(135deg,var(--blue),var(--bdk));border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 13px;font-size:17px;font-weight:800;color:#fff;box-shadow:0 6px 16px rgba(37,99,235,.35)}
.flt{font-size:13px;font-weight:700;color:var(--sl9);margin-bottom:5px}
.fld{font-size:11.5px;color:var(--sl6);line-height:1.7}

/* CTA */
.cta{background:linear-gradient(135deg,#1d4ed8,#2563eb,#3b82f6);padding:72px 32px;text-align:center}
.cta h2{font-size:clamp(24px,4vw,36px);font-weight:900;color:#fff;margin-bottom:10px}
.cta p{font-size:15px;color:rgba(255,255,255,.8);margin-bottom:32px}
.ctel{font-size:36px;font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:6px}
.cthr{font-size:12.5px;color:rgba(255,255,255,.65);margin-bottom:26px}
.bct{background:#fff;color:var(--bdk);padding:13px 32px;font-size:14px;font-weight:700;border-radius:100px;cursor:pointer;border:none;box-shadow:0 6px 20px rgba(0,0,0,.18);transition:all .25s;font-family:'Noto Sans JP',sans-serif}
.bct:hover{transform:translateY(-2px)}

/* FOOTER */
footer{background:#0f172a;padding:60px 32px 24px}
.fti{max-width:1200px;margin:0 auto}
.ftop{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px}
.flr{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.flic{display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fle{font-family:'Dancing Script',cursive;font-size:15px;font-weight:700;color:#fff;line-height:1.15}
.fle2{font-family:'Dancing Script',cursive;font-size:13px;font-weight:600;color:#fff;line-height:1.15}
.fdesc{font-size:12.5px;line-height:1.8;color:#64748b;margin-bottom:18px}
.ftel{font-size:16px;font-weight:700;color:#fff;margin-bottom:4px}
.fhrs{font-size:11.5px;color:#64748b}
.fcol h4{font-size:11px;font-weight:700;color:#e2e8f0;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}
.fcol ul{list-style:none}
.fcol li{margin-bottom:8px}
.fcol a{font-size:13px;color:#64748b;text-decoration:none;transition:color .2s;cursor:pointer;display:flex;align-items:center;gap:5px}
.fcol a::before{content:'›';color:#3b82f6;font-size:14px;font-weight:700}
.fcol a:hover{color:#93c5fd}
.fbot{border-top:1px solid rgba(255,255,255,.06);padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#475569;flex-wrap:wrap;gap:8px}
.fbot-links{display:flex;gap:18px}
.fbot-links a{color:#475569;text-decoration:none;cursor:pointer;font-size:12px;transition:color .2s}
.fbot-links a:hover{color:#3b82f6}

/* PAGE HERO */
.ph{padding:110px 32px 52px;background:linear-gradient(135deg,#0f172a,#1e3a8a);position:relative;overflow:hidden;margin-top:62px}
.ph::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 30% 50%,rgba(59,130,246,.1),transparent 60%)}
.phi{max-width:1200px;margin:0 auto;position:relative;z-index:2}
.phl{font-size:11px;font-weight:700;letter-spacing:.15em;color:#60a5fa;text-transform:uppercase;margin-bottom:9px}
.pht{font-size:clamp(28px,5vw,48px);font-weight:900;color:#fff;margin-bottom:12px;letter-spacing:-.02em}
.phd{font-size:15px;color:rgba(255,255,255,.65);max-width:480px;line-height:1.7}

/* COMPANY */
.cg{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start;margin-top:52px}
.itb{width:100%;border-collapse:collapse}
.itb tr{border-bottom:1px solid var(--sl1)}
.itb th{width:120px;padding:14px 0;font-size:13px;font-weight:600;color:var(--sl6);text-align:left;vertical-align:top}
.itb td{padding:14px 0;font-size:14px;color:var(--sl8);line-height:1.7}

/* CONTACT */
.ctg{display:grid;grid-template-columns:1fr 1fr;gap:44px;margin-top:52px}
.cfm{background:#fff;border:1px solid var(--sl2);border-radius:14px;padding:36px}
.cfm h3{font-size:18px;font-weight:700;color:var(--sl9);margin-bottom:20px}
.fmg{margin-bottom:16px}
.fml{display:block;font-size:12.5px;font-weight:600;color:#334155;margin-bottom:5px}
.fmr{color:#ef4444;margin-left:4px;font-size:11px}
.fmi,.fms,.fmt{width:100%;padding:10px 12px;border:1.5px solid var(--sl2);border-radius:8px;font-size:13.5px;font-family:'Noto Sans JP',sans-serif;color:var(--sl8);background:var(--sl0);outline:none;transition:all .2s}
.fmi:focus,.fms:focus,.fmt:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.fmt{resize:vertical;min-height:110px}
.bsub{width:100%;background:linear-gradient(135deg,var(--blue),var(--bdk));color:#fff;border:none;padding:12px;font-size:14px;font-weight:700;border-radius:8px;cursor:pointer;transition:all .25s;font-family:'Noto Sans JP',sans-serif}
.bsub:hover{transform:translateY(-1px)}
.cci{background:linear-gradient(135deg,#0f172a,#1e3a8a);border-radius:14px;padding:28px;margin-bottom:16px}
.cci h4{font-size:13px;font-weight:600;color:#93c5fd;margin-bottom:7px}
.btel{font-size:28px;font-weight:800;color:#fff;letter-spacing:-.02em}
.cth2{font-size:12px;color:rgba(255,255,255,.55);margin-top:5px}

/* CAREERS */
.jg{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:52px}
.jc{background:#fff;border:1px solid var(--sl2);border-radius:14px;padding:26px;transition:all .3s}
.jc:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(0,0,0,.08)}
.jtp{font-size:11px;font-weight:600;padding:4px 11px;border-radius:5px;display:inline-block;margin-bottom:11px}
.jf{background:#eff6ff;color:#1d4ed8}.jp{background:#f5f3ff;color:#6d28d9}
.jtl{font-size:18px;font-weight:700;color:var(--sl9);margin-bottom:8px}
.jds{font-size:13.5px;color:var(--sl6);line-height:1.7;margin-bottom:16px}
.jdt{border-top:1px solid var(--sl1);padding-top:13px;display:flex;flex-direction:column;gap:7px}
.jdr{display:flex;gap:9px;font-size:12.5px}
.jdl{color:#94a3b8;width:52px;min-width:52px}
.jdv{color:#334155;font-weight:500}
.bpp{display:inline-flex;align-items:center;background:linear-gradient(135deg,var(--blue),var(--bdk));color:#fff;border:none;padding:12px 26px;font-size:14px;font-weight:700;border-radius:100px;cursor:pointer;box-shadow:0 6px 18px rgba(37,99,235,.4);transition:all .25s;font-family:'Noto Sans JP',sans-serif}
.bpp:hover{transform:translateY(-2px)}
.bob{display:inline-block;border:1.5px solid var(--blue);color:var(--blue);background:transparent;padding:11px 26px;border-radius:100px;font-size:13.5px;font-weight:700;cursor:pointer;font-family:'Noto Sans JP',sans-serif;transition:all .2s}
.bob:hover{background:rgba(37,99,235,.06)}

/*施工実績写真カード */
.work-photo{width:100%;height:165px;object-fit:cover}

@media(max-width:768px){
  .hc{padding:0 48px}
  .absi,.cg,.ctg{grid-template-columns:1fr;gap:36px}
  .fg,.svg2,.wkg,.jg{grid-template-columns:1fr}
  .ftop{grid-template-columns:1fr 1fr}
  .nl{display:none}
  .fls{flex-direction:column;gap:18px}
  .flst::after{display:none}
  .abr{grid-template-columns:1fr 1fr}
}

/* SLIDESHOW DOTS */
.slide-dots{position:absolute;bottom:56px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:15}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:all .3s;border:none;padding:0}
.dot.act{background:#fff;transform:scale(1.25)}
/* TEXT FADE */
.hc-inner.fade{animation:textIn .65s ease both}
@keyframes textIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
/* TOPICS BAR */
.topics-bar{background:#2563eb;padding:14px 0}
.topics-inner2{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:16px;padding:0 36px}
.tlabel{background:#fff;color:#2563eb;font-size:11px;font-weight:800;padding:4px 12px;border-radius:3px;white-space:nowrap;letter-spacing:.05em;flex-shrink:0}
.tdate{font-size:13px;color:rgba(255,255,255,.9);font-weight:500;white-space:nowrap;flex-shrink:0}
.ttext{font-size:13.5px;color:#fff;font-weight:500;flex:1}
.tall{margin-left:auto;font-size:13px;color:#fff;font-weight:700;white-space:nowrap;cursor:pointer;text-decoration:none;flex-shrink:0}
.tall:hover{color:rgba(255,255,255,.8)}

/* STATS SECTION */
.stats-sec{background:#fff;padding:52px 32px;border-top:1px solid var(--sl2);border-bottom:1px solid var(--sl2)}
.stats-g{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-bx{text-align:center;padding:20px 12px;border-right:1px solid var(--sl2)}
.stat-bx:last-child{border-right:none}
.stat-nn{font-size:clamp(40px,5.5vw,70px);font-weight:900;color:var(--sl9);line-height:1;letter-spacing:-.02em}
.stat-ll{font-size:14px;color:var(--sl5);margin-top:10px;font-weight:500}

/* SVC2 SECTION */
.svc2-wrap{background:var(--sl0);padding:88px 32px}
.svc2-hd{text-align:center;margin-bottom:52px}
.svc2-hd h2{font-size:clamp(28px,3.5vw,40px);font-weight:900;color:var(--sl9);padding-bottom:18px;position:relative;display:inline-block}
.svc2-hd h2::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:48px;height:3px;background:var(--blue);border-radius:2px}
.svc2-hd p{font-size:15px;color:var(--sl6);margin-top:22px;line-height:1.8;max-width:620px;margin-left:auto;margin-right:auto}
.svc2-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.svc2-card{border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 2px 20px rgba(0,0,0,.08);transition:all .35s;cursor:pointer}
.svc2-card:hover{transform:translateY(-8px);box-shadow:0 18px 42px rgba(0,0,0,.15)}
.svc2-img{height:220px;position:relative;overflow:hidden}
.svc2-imgbg{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .45s}
.svc2-card:hover .svc2-imgbg{transform:scale(1.06)}
.svc2-badge{position:absolute;top:16px;left:16px;width:52px;height:52px;background:#2563eb;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(37,99,235,.45)}
.svc2-bd{padding:22px 24px 26px}
.svc2-tl{font-size:18px;font-weight:700;color:var(--sl9);margin-bottom:8px}
.svc2-ds{font-size:13px;color:var(--sl6);line-height:1.7}
.svc2-lk{display:inline-flex;align-items:center;gap:4px;color:var(--blue);font-size:13px;font-weight:600;margin-top:14px;cursor:pointer;background:none;border:none;padding:0;font-family:'Noto Sans JP',sans-serif}
@media(max-width:768px){.stats-g{grid-template-columns:repeat(2,1fr)}.stat-bx{border-bottom:1px solid var(--sl2)}.svc2-grid{grid-template-columns:1fr}}

.btn-detail{display:inline-flex;align-items:center;gap:10px;background:#2563eb;color:#fff;border:none;padding:16px 40px;font-size:16px;font-weight:700;border-radius:100px;cursor:pointer;font-family:'Noto Sans JP',sans-serif;box-shadow:0 6px 20px rgba(37,99,235,.4);transition:all .25s}
.btn-detail:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 10px 28px rgba(37,99,235,.5)}

.svc2-img{height:240px}
.svc2-bd{padding:24px 26px 28px}
.svc2-tl{font-size:19px;font-weight:700;color:var(--sl9);margin-bottom:12px}
.svc2-ds{font-size:14px;color:var(--sl6);line-height:1.8}

/* SKILL SECTION */
.skill-wrap{background:#2563eb;padding:80px 32px}
.skill-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.skill-txt h2{font-size:clamp(26px,3.5vw,40px);font-weight:900;color:#fff;margin-bottom:20px;line-height:1.35}
.skill-txt p{font-size:15px;color:rgba(255,255,255,.88);line-height:1.85;margin-bottom:36px;max-width:440px}
.btn-skill{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#1d4ed8;border:none;padding:14px 28px;font-size:15px;font-weight:700;border-radius:100px;cursor:pointer;font-family:'Noto Sans JP',sans-serif;box-shadow:0 4px 16px rgba(0,0,0,.15);transition:all .25s}
.btn-skill:hover{background:#f0f4ff;transform:translateY(-2px)}
.skill-photos{display:block}
.skill-photo{border-radius:16px;overflow:hidden;height:400px;box-shadow:0 12px 36px rgba(0,0,0,.25)}
.sph{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .45s}
.skill-photo:hover .sph{transform:scale(1.04)}

/* WORKS2 SECTION */
.works2-wrap{background:var(--sl0);padding:88px 32px}
.w2hd{text-align:center;margin-bottom:52px}
.w2hd h2{font-size:clamp(28px,3.5vw,42px);font-weight:900;color:var(--sl9);padding-bottom:18px;position:relative;display:inline-block}
.w2hd h2::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:48px;height:3px;background:var(--blue);border-radius:2px}
.w2hd p{font-size:15px;color:var(--sl6);margin-top:22px;line-height:1.8;max-width:700px;margin-left:auto;margin-right:auto}
.w2grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.w2card{border-radius:14px;overflow:hidden;position:relative;height:265px;cursor:pointer;transition:all .35s}
.w2card:hover{transform:translateY(-6px);box-shadow:0 18px 44px rgba(0,0,0,.22)}
.w2bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .45s}
.w2card:hover .w2bg{transform:scale(1.06)}
.w2ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.78) 0%,rgba(0,0,0,.22) 55%,transparent 100%)}
.w2body{position:absolute;bottom:0;left:0;right:0;padding:20px 22px}
.w2tag{display:inline-block;background:#2563eb;color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:100px;margin-bottom:10px}
.w2title{font-size:18px;font-weight:700;color:#fff;line-height:1.3}

/* ABOUT2 SECTION */
.ab2-wrap{background:#fff;padding:88px 32px}
.ab2-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.ab2-txt h2{font-size:clamp(28px,3.5vw,44px);font-weight:900;color:var(--sl9);margin-bottom:24px;letter-spacing:-.01em}
.ab2-txt p{font-size:15px;color:var(--sl6);line-height:1.9;margin-bottom:16px}
.ab2-facts{margin:28px 0}
.ab2-fact{display:flex;align-items:center;gap:14px;padding:15px 0;border-bottom:1px solid var(--sl1)}
.ab2-fact:first-child{border-top:1px solid var(--sl1)}
.ab2-ico{width:30px;height:30px;border-radius:7px;background:var(--sl1);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px}
.ab2-lbl{font-size:14px;font-weight:600;color:var(--sl8)}
.ab2-val{font-size:14px;color:var(--sl6)}
.btn-ab2{display:inline-flex;align-items:center;gap:7px;color:var(--blue);font-size:15px;font-weight:700;background:none;border:none;padding:0;cursor:pointer;font-family:'Noto Sans JP',sans-serif;transition:color .2s}
.btn-ab2:hover{color:var(--bdk)}
.ab2-card{background:#fff;border:1px solid var(--sl2);border-radius:16px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.07)}
.ab2-cimg{height:265px;background-size:cover;background-position:center}
.ab2-cbody{padding:26px 28px}
.ab2-ctitle{font-size:20px;font-weight:700;color:var(--sl9);margin-bottom:10px}
.ab2-cdesc{font-size:14px;color:var(--sl6);line-height:1.8}

@media(max-width:768px){
  .skill-inner,.ab2-inner{grid-template-columns:1fr;gap:40px}
  .w2grid{grid-template-columns:1fr}
  .skill-photos{grid-template-columns:1fr 1fr}
}

/* ===== COMPANY PAGE ===== */
.co-hero{background:linear-gradient(135deg,#1d4ed8 0%,#2563eb 100%);padding:80px 32px;text-align:center;margin-top:62px}
.co-hero h1{font-size:clamp(32px,5vw,54px);font-weight:900;color:#fff;margin-bottom:16px;letter-spacing:-.02em}
.co-hero p{font-size:15.5px;color:rgba(255,255,255,.88);max-width:640px;margin:0 auto;line-height:1.8}
.co-sec{padding:80px 32px;background:#fff}
.co-sec-g{padding:80px 32px;background:var(--sl0)}
.co-hd{text-align:center;margin-bottom:52px}
.co-hd h2{font-size:clamp(26px,3.5vw,38px);font-weight:900;color:var(--sl9);padding-bottom:16px;position:relative;display:inline-block}
.co-hd h2::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:42px;height:3px;background:var(--blue);border-radius:2px}
/* 社長挨拶 */
.co-gi{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:280px 1fr;gap:60px;align-items:start}
.co-pc{background:var(--sl0);border-radius:16px;padding:30px;text-align:center;border:1px solid var(--sl2)}
.co-pph{width:152px;height:152px;border-radius:50%;margin:0 auto 16px;background-size:cover;background-position:center top;border:4px solid #fff;box-shadow:0 4px 18px rgba(0,0,0,.14)}
.co-pnm{font-size:20px;font-weight:700;color:var(--sl9);margin-bottom:4px}
.co-ptl{font-size:13px;color:var(--blue);font-weight:600}
.co-gm p{font-size:15px;color:var(--sl6);line-height:2;margin-bottom:18px}
.co-gs{margin-top:32px;text-align:right;border-top:1px solid var(--sl2);padding-top:18px;font-size:14px;color:var(--sl6);line-height:2.2}
.co-gs strong{font-size:17px;color:var(--sl9);font-weight:700}
/* 会社概要 */
.co-ovi{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.3fr;gap:52px;align-items:start}
.co-oimg{height:300px;border-radius:14px;overflow:hidden;box-shadow:0 6px 24px rgba(0,0,0,.12)}
.co-oimgb{width:100%;height:100%;background-size:cover;background-position:center}
.co-otbl{width:100%;border-collapse:collapse}
.co-otbl tr{border-bottom:1px solid var(--sl2)}
.co-otbl th{width:120px;padding:16px 0;font-size:14px;font-weight:700;color:var(--sl8);text-align:left;vertical-align:top;white-space:nowrap}
.co-otbl td{padding:16px 0;font-size:14px;color:var(--sl6);line-height:1.7}
/* 使命・価値観・ビジョン */
.co-mvvg{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.co-mvc{background:#fff;border:1px solid var(--sl2);border-radius:16px;padding:36px 26px;text-align:center;transition:all .3s}
.co-mvc:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.09)}
.co-mvi{width:54px;height:54px;margin:0 auto 18px;color:var(--blue);display:flex;align-items:center;justify-content:center}
.co-mvl{font-size:20px;font-weight:700;color:var(--sl9);margin-bottom:14px}
.co-mvt{font-size:14px;color:var(--sl6);line-height:1.85}
/* 沿革 */
.co-tl{max-width:800px;margin:0 auto;position:relative}
.co-tl::before{content:'';position:absolute;left:88px;top:20px;bottom:20px;width:2px;background:rgba(37,99,235,.2)}
.co-tli{display:flex;gap:0;padding:24px 0;position:relative;align-items:flex-start}
.co-tli::after{content:'';position:absolute;left:82px;top:32px;width:14px;height:14px;border-radius:50%;background:var(--blue);border:3px solid #fff;box-shadow:0 0 0 2px var(--blue)}
.co-tlyr{min-width:88px;padding-right:32px;text-align:right;padding-top:4px}
.co-tlyb{display:inline-block;background:#2563eb;color:#fff;font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:6px;white-space:nowrap}
.co-tlbd{padding-left:28px}
.co-tltt{font-size:16px;font-weight:700;color:var(--sl9);margin-bottom:6px}
.co-tlds{font-size:13.5px;color:var(--sl6);line-height:1.75}

@media(max-width:768px){
  .co-gi,.co-ovi{grid-template-columns:1fr;gap:36px}
  .co-mvvg{grid-template-columns:1fr}
}

/* COMPANY PAGE */
.co-phero{background:#2563eb;padding:80px 32px;text-align:center;margin-top:62px}
.co-phero-inner{max-width:800px;margin:0 auto}
.co-phero-title{font-size:clamp(32px,5vw,52px);font-weight:900;color:#fff;margin-bottom:16px}
.co-phero-desc{font-size:16px;color:rgba(255,255,255,.88);line-height:1.8}

/* Section headings */
.co-hd2{text-align:center;margin-bottom:52px}
.co-hd2 h2{font-size:clamp(24px,3.2vw,36px);font-weight:900;color:var(--sl9);padding-bottom:16px;position:relative;display:inline-block}
.co-hd2 h2::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:48px;height:3px;background:var(--blue);border-radius:2px}
.co-hd-left{margin-bottom:44px}
.co-hd-left h2{font-size:clamp(22px,3vw,32px);font-weight:900;color:var(--sl9);padding-bottom:14px;position:relative;display:inline-block}
.co-hd-left h2::after{content:'';position:absolute;bottom:0;left:0;width:48px;height:3px;background:var(--blue);border-radius:2px}

/* 社長挨拶 */
.co-pres-sec{background:#fff;padding:88px 32px}
.co-pres-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.6fr;gap:64px;align-items:start}
.co-pres-left{background:var(--sl0);border-radius:16px;padding:36px 28px;text-align:center;border:1px solid var(--sl2)}
.co-pres-photo{margin:0 auto 20px;display:flex;justify-content:center}
.co-pres-name{font-size:20px;font-weight:700;color:var(--sl9);margin-bottom:6px}
.co-pres-pos{font-size:13.5px;color:var(--blue);font-weight:600}
.co-pres-right p{font-size:15px;line-height:1.95;color:var(--sl6);margin-bottom:18px}
.co-pres-sign{text-align:right;margin-top:32px;border-top:1px solid var(--sl2);padding-top:20px}
.co-pres-sign-co{font-size:13.5px;color:var(--sl5);margin-bottom:6px}
.co-pres-sign-name{font-size:15px;font-weight:700;color:var(--blue)}

/* 会社概要 */
.co-ov-sec{background:var(--sl0);padding:88px 32px}
.co-ov-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:start}
.co-ov-img{border-radius:14px;overflow:hidden;height:310px;box-shadow:0 4px 20px rgba(0,0,0,.1)}
.co-ov-imgbg{width:100%;height:100%;background-size:cover;background-position:center}
.co-ov-table{width:100%;border-collapse:collapse}
.co-ov-table tr{border-bottom:1px solid var(--sl2)}
.co-ov-table th{width:110px;padding:16px 0;font-size:14px;font-weight:600;color:var(--sl6);text-align:left;vertical-align:top}
.co-ov-table td{padding:16px 0;font-size:14px;color:var(--sl8);line-height:1.7}

/* MVV */
.co-mvv-sec{background:#fff;padding:88px 32px}
.co-mvv-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.co-mvv-card{border:1px solid var(--sl2);border-radius:16px;padding:40px 28px;text-align:center;transition:all .3s}
.co-mvv-card:hover{box-shadow:0 12px 32px rgba(0,0,0,.08);border-color:rgba(37,99,235,.25);transform:translateY(-4px)}
.co-mvv-icon{width:56px;height:56px;background:#eff6ff;border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.co-mvv-title{font-size:18px;font-weight:700;color:var(--sl9);margin-bottom:12px}
.co-mvv-desc{font-size:13.5px;color:var(--sl6);line-height:1.85}

/* 沿革 */
.co-hist-sec{background:var(--sl0);padding:88px 32px}
.co-hist-wrap{max-width:780px;margin:0 auto}
.co-hist-item{display:flex;gap:0;margin-bottom:0}
.co-hist-left{width:96px;flex-shrink:0;padding:4px 20px 48px 0;text-align:right}
.co-hist-yr{background:#2563eb;color:#fff;font-size:11.5px;font-weight:700;padding:5px 10px;border-radius:6px;display:inline-block;white-space:nowrap}
.co-hist-right{flex:1;border-left:3px solid #2563eb;padding:0 0 44px 28px}
.co-hist-item:last-child .co-hist-right{border-left:3px solid transparent;padding-bottom:0}
.co-hist-tl{font-size:16px;font-weight:700;color:var(--sl9);margin-bottom:7px;margin-top:2px}
.co-hist-ds{font-size:13.5px;color:var(--sl6);line-height:1.75}

@media(max-width:768px){
  .co-pres-inner,.co-ov-inner{grid-template-columns:1fr;gap:36px}
  .co-mvv-grid{grid-template-columns:1fr}
  .co-hist-left{width:72px;padding-right:12px}
}

/* 施工プロセス */
.proc-sec{background:var(--sl0);padding:88px 32px}
.proc-grid{max-width:1200px;margin:48px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.proc-card{background:#fff;border:1px solid var(--sl2);border-radius:16px;padding:36px 26px 30px;text-align:center;position:relative;transition:all .3s}
.proc-card:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(0,0,0,.09)}
.proc-card::after{content:'→';position:absolute;right:-18px;top:44px;color:#2563eb;font-size:20px;font-weight:800;z-index:2;background:var(--sl0);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.proc-card:nth-child(3)::after,.proc-card:nth-child(6)::after{display:none}
.proc-num{width:58px;height:58px;background:#2563eb;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:17px;font-weight:800;color:#fff;font-family:'Inter',sans-serif;box-shadow:0 6px 16px rgba(37,99,235,.35)}
.proc-title{font-size:17px;font-weight:700;color:var(--sl9);margin-bottom:12px}
.proc-desc{font-size:13.5px;color:var(--sl6);line-height:1.8}
.proc-hl{color:#2563eb}

/* サポート体制 */
.supp-sec{background:#2563eb;padding:88px 32px}
.supp-hd{text-align:center;margin-bottom:48px}
.supp-hd h2{font-size:clamp(26px,3.5vw,38px);font-weight:900;color:#fff;padding-bottom:16px;position:relative;display:inline-block}
.supp-hd h2::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:48px;height:3px;background:rgba(255,255,255,.65);border-radius:2px}
.supp-hd p{font-size:15px;color:rgba(255,255,255,.88);margin-top:20px;line-height:1.8}
.supp-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.supp-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:16px;padding:44px 28px;text-align:center;transition:all .3s}
.supp-card:hover{background:rgba(255,255,255,.2);transform:translateY(-4px)}
.supp-icon{margin:0 auto 18px;display:flex;align-items:center;justify-content:center}
.supp-title{font-size:18px;font-weight:700;color:#fff;margin-bottom:12px}
.supp-desc{font-size:13.5px;color:rgba(255,255,255,.85);line-height:1.85}

@media(max-width:768px){
  .proc-grid,.supp-grid{grid-template-columns:1fr}
  .proc-card::after{display:none}
}

.wks-phero{background:linear-gradient(135deg,#1d4ed8,#2563eb,#3b82f6);padding:80px 32px;text-align:center;margin-top:62px}
.wks-phero h1{font-size:clamp(30px,5vw,50px);font-weight:900;color:#fff;margin-bottom:16px}
.wks-phero p{font-size:15px;color:rgba(255,255,255,.88);max-width:700px;margin:0 auto;line-height:1.8}
.wks-fw{background:#f8fafc;padding:22px 32px;border-bottom:1px solid var(--sl2)}
.wks-fl{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.wks-tb{font-size:13px;font-weight:600;padding:8px 16px;border-radius:100px;cursor:pointer;border:1px solid var(--sl2);background:#fff;color:var(--sl6);font-family:'Noto Sans JP',sans-serif;transition:all .2s;white-space:nowrap}
.wks-tb.act{background:#2563eb;color:#fff;border-color:#2563eb}
.wks-tb:hover:not(.act){background:var(--sl1)}
.wks-projs{background:#fff;padding:72px 32px}
.wks-proj{max-width:1200px;margin:0 auto 80px;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.wks-proj:last-child{margin-bottom:0}
.wks-proj.rev{direction:rtl}.wks-proj.rev>*{direction:ltr}
.wks-pimg{border-radius:16px;overflow:hidden;height:320px;position:relative;box-shadow:0 8px 28px rgba(0,0,0,.12)}
.wks-pimg-bg{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .45s}
.wks-pimg:hover .wks-pimg-bg{transform:scale(1.05)}
.wks-ptag{position:absolute;top:16px;left:16px;background:#2563eb;color:#fff;font-size:12px;font-weight:700;padding:5px 14px;border-radius:100px}
.wks-pinfo h2{font-size:clamp(20px,3vw,28px);font-weight:900;color:var(--sl9);margin-bottom:16px;line-height:1.3}
.wks-pmeta{display:flex;gap:0;margin-bottom:20px;flex-wrap:wrap}
.wks-pmeta-item{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--sl5);background:var(--sl0);border:1px solid var(--sl2);padding:6px 12px;border-right:none}
.wks-pmeta-item:first-child{border-radius:8px 0 0 8px}.wks-pmeta-item:last-child{border-right:1px solid var(--sl2);border-radius:0 8px 8px 0}
.wks-pdesc{font-size:14px;color:var(--sl6);line-height:1.9;margin-bottom:20px}
.wks-pfeat-title,.wks-award-title{font-size:15px;font-weight:700;color:var(--sl9);margin-bottom:10px}
.wks-pfeats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}
.wks-pfeat{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--sl7)}
.wks-pfeat::before{content:'●';color:#2563eb;font-size:7px;flex-shrink:0}
.wks-awards{display:flex;gap:8px;flex-wrap:wrap}
.wks-award{display:flex;align-items:center;gap:6px;background:#fef9c3;border:1px solid #fde68a;color:#92400e;font-size:12px;font-weight:600;padding:5px 12px;border-radius:100px}
.wks-fields{background:var(--sl0);padding:88px 32px}
.wks-fgrid{max-width:1200px;margin:36px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.wks-fcard{background:#fff;border:1px solid var(--sl2);border-radius:16px;padding:36px 24px;text-align:center;transition:all .3s;cursor:pointer}
.wks-fcard:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(0,0,0,.09);border-color:rgba(37,99,235,.25)}
.wks-ficon{margin:0 auto 14px;display:flex;justify-content:center}
.wks-fname{font-size:16px;font-weight:700;color:var(--sl9);margin-bottom:6px}
.wks-fcount{font-size:13px;color:var(--sl5);margin-bottom:12px}
.wks-flink{color:#2563eb;font-size:13px;font-weight:600}
@media(max-width:768px){.wks-proj,.wks-proj.rev{grid-template-columns:1fr;direction:ltr;gap:28px}.wks-fgrid{grid-template-columns:1fr 1fr}}

/* FAQ SECTION */
.faq-sec{background:var(--sl0);padding:88px 32px}
.faq-hd{text-align:center;margin-bottom:52px}
.faq-hd h2{font-size:clamp(26px,3.5vw,38px);font-weight:900;color:var(--sl9);padding-bottom:16px;position:relative;display:inline-block}
.faq-hd h2::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:48px;height:3px;background:var(--blue);border-radius:2px}
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:20px}
.faq-card{background:#fff;border-radius:14px;padding:28px 32px;box-shadow:0 2px 16px rgba(0,0,0,.07);border:1px solid var(--sl1);transition:all .3s}
.faq-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.1);transform:translateY(-2px)}
.faq-q{font-size:16px;font-weight:700;color:var(--sl9);margin-bottom:12px;display:flex;align-items:flex-start;gap:8px}
.faq-q-label{color:#2563eb;font-weight:800;flex-shrink:0}
.faq-a{font-size:14.5px;color:var(--sl6);line-height:1.85;display:flex;align-items:flex-start;gap:8px}
.faq-a-label{color:var(--sl4);font-weight:700;flex-shrink:0}

/* CAREERS PAGE */
.cr-hero{background:linear-gradient(135deg,#1d4ed8,#2563eb,#3b82f6);padding:80px 32px;text-align:center;margin-top:62px}
.cr-hero h1{font-size:clamp(30px,5vw,50px);font-weight:900;color:#fff;margin-bottom:16px}
.cr-hero p{font-size:15px;color:rgba(255,255,255,.88);max-width:700px;margin:0 auto;line-height:1.8}

/* 私たちの価値観 */
.cr-vals{background:var(--sl0);padding:88px 32px}
.cr-vgrid{max-width:1200px;margin:48px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cr-vcard{background:#fff;border-radius:16px;padding:36px 24px;text-align:center;border:1px solid var(--sl2);transition:all .3s}
.cr-vcard:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.09)}
.cr-vicon{margin:0 auto 16px;display:flex;justify-content:center}
.cr-vtitle{font-size:17px;font-weight:700;color:var(--sl9);margin-bottom:10px}
.cr-vdesc{font-size:13.5px;color:var(--sl6);line-height:1.8}

/* 職場環境 */
.cr-env{background:#fff;padding:88px 32px}
.cr-egrid{max-width:1200px;margin:48px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cr-ecard{border-radius:14px;overflow:hidden;background:#fff;border:1px solid var(--sl2);box-shadow:0 2px 16px rgba(0,0,0,.06);transition:all .3s}
.cr-ecard:hover{transform:translateY(-5px);box-shadow:0 14px 32px rgba(0,0,0,.12)}
.cr-eimg{height:200px;background-size:cover;background-position:center}
.cr-ebody{padding:22px 22px 26px}
.cr-etitle{font-size:17px;font-weight:700;color:var(--sl9);margin-bottom:8px}
.cr-edesc{font-size:13.5px;color:var(--sl6);line-height:1.8}

/* フィルタ */
.cr-filter-wrap{background:var(--sl0);padding:28px 32px 0;border-bottom:1px solid var(--sl2)}
.cr-filter{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:8px;padding-bottom:0}
.cr-ftab{font-size:13.5px;font-weight:600;padding:10px 20px;border-radius:100px;cursor:pointer;border:1.5px solid var(--sl2);background:#fff;color:var(--sl6);font-family:'Noto Sans JP',sans-serif;transition:all .2s;display:flex;align-items:center;gap:6px}
.cr-ftab.act{background:#2563eb;color:#fff;border-color:#2563eb}
.cr-ftab:hover:not(.act){background:var(--sl1)}
.cr-ficon{color:var(--sl4)}

/* 募集職種 */
.cr-jobs{background:var(--sl0);padding:72px 32px 88px}
.cr-jhd{text-align:center;margin-bottom:52px}
.cr-job-list{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:24px}
.cr-jcard{background:#fff;border-radius:18px;padding:36px 40px;border:1px solid var(--sl2);box-shadow:0 2px 16px rgba(0,0,0,.06)}
.cr-jcard-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.cr-jtitle{font-size:22px;font-weight:800;color:var(--sl9)}
.cr-jsal{font-size:18px;font-weight:800;color:#2563eb;text-align:right}
.cr-jsub{font-size:12px;color:var(--sl5);text-align:right;margin-top:2px}
.cr-jtags{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.cr-tag{font-size:12px;font-weight:600;padding:4px 12px;border-radius:100px}
.cr-tag-new{background:#dbeafe;color:#1d4ed8}
.cr-tag-career{background:#d1fae5;color:#065f46}
.cr-tag-intern{background:#e0f2fe;color:#0c4a6e}
.cr-tag-full{background:#dcfce7;color:#166534}
.cr-jbody{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:20px}
.cr-jleft{}
.cr-jdesc{font-size:14px;color:var(--sl6);line-height:1.9;margin-bottom:20px}
.cr-jmeta{display:flex;flex-wrap:wrap;gap:24px}
.cr-jmeta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--sl5)}
.cr-jright{}
.cr-req-title{font-size:15px;font-weight:700;color:var(--sl9);margin-bottom:10px}
.cr-req-list{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}
.cr-req-item{font-size:13.5px;color:var(--sl6);display:flex;gap:8px;align-items:flex-start}
.cr-req-item::before{content:'●';color:#2563eb;font-size:8px;margin-top:5px;flex-shrink:0}
.cr-ben-item::before{content:'●';color:#16a34a;font-size:8px;margin-top:5px;flex-shrink:0}
.cr-ben-item{font-size:13.5px;color:var(--sl6);display:flex;gap:8px;align-items:flex-start}
.cr-apply-btn{width:100%;margin-top:22px;background:#2563eb;color:#fff;border:none;padding:14px 0;font-size:15px;font-weight:700;border-radius:10px;cursor:pointer;font-family:'Noto Sans JP',sans-serif;transition:all .25s}
.cr-apply-btn:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 8px 20px rgba(37,99,235,.4)}

/* 福利厚生 */
.cr-ben{background:#fff;padding:88px 32px}
.cr-bengrid{max-width:1200px;margin:48px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cr-bencard{background:var(--sl0);border-radius:16px;padding:32px 24px;border:1px solid var(--sl2)}
.cr-bencard-title{font-size:16px;font-weight:700;color:var(--sl9);text-align:center;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #e2e8f0}
.cr-benitem{font-size:13.5px;color:var(--sl6);padding:8px 0;border-bottom:1px solid var(--sl1);display:flex;align-items:flex-start;gap:8px}
.cr-benitem::before{content:'●';color:#2563eb;font-size:8px;margin-top:5px;flex-shrink:0}
.cr-benitem:last-child{border-bottom:none}

/* 応募方法 */
.cr-how{background:var(--sl0);padding:88px 32px}
.cr-howbox{max-width:900px;margin:48px auto 0;background:#fff;border-radius:20px;padding:40px;border:1px solid var(--sl2);box-shadow:0 4px 24px rgba(0,0,0,.07)}
.cr-howgrid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}
.cr-howcard{background:var(--sl0);border-radius:14px;padding:32px 24px;text-align:center;border:1px solid var(--sl2)}
.cr-howicon{margin:0 auto 14px;display:flex;justify-content:center}
.cr-howtitle{font-size:17px;font-weight:700;color:var(--sl9);margin-bottom:10px}
.cr-howdesc{font-size:13.5px;color:var(--sl6);line-height:1.8;margin-bottom:12px}
.cr-howlink{color:#2563eb;font-size:14px;font-weight:600}
.cr-howphone{color:#16a34a;font-size:20px;font-weight:800}
.cr-docs-title{font-size:16px;font-weight:700;color:var(--sl9);text-align:center;margin-bottom:16px}
.cr-docs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cr-doc{background:var(--sl0);border-radius:10px;padding:16px;text-align:center;font-size:13.5px;color:var(--sl7);border:1px solid var(--sl2)}

@media(max-width:768px){
  .cr-vgrid,.cr-bengrid{grid-template-columns:repeat(2,1fr)}
  .cr-egrid{grid-template-columns:1fr}
  .cr-jbody{grid-template-columns:1fr}
  .cr-howgrid{grid-template-columns:1fr}
  .cr-docs-grid{grid-template-columns:1fr}
}

/* FOOTER CLEAN */
.fcol-main{flex:1.6}
.finfo-row{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.7);margin-top:8px}

/* ========================================
   COMPREHENSIVE MOBILE STYLES (max-width:480px)
   ======================================== */
@media(max-width:480px){

  /* ── NAV ── */
  .ni{padding:0 16px;height:54px}
  .nl{display:none}
  .logo img{height:40px!important}

  /* ── HERO ── */
  .hero{height:420px;min-height:420px}
  .hc{padding:0 20px;max-width:100%}
  .hsub{font-size:11px;margin-bottom:12px}
  #slide-t1{font-size:clamp(26px,8vw,38px)!important}
  #slide-t2{font-size:clamp(18px,5.5vw,26px)!important}
  .dots{bottom:12px}
  .slide-nav{display:none}

  /* ── STATS ── */
  .stats-sec{padding:32px 16px}
  .stats-g{grid-template-columns:repeat(2,1fr)}
  .stat-nn{font-size:clamp(32px,9vw,48px)}
  .stat-ll{font-size:12px}
  .stat-bx{padding:16px 8px;border-bottom:1px solid var(--sl2)}

  /* ── HOME SERVICE CARDS ── */
  .svc2-wrap{padding:56px 16px}
  .svc2-hd h2{font-size:26px}
  .svc2-hd p{font-size:13.5px}
  .svc2-grid{grid-template-columns:1fr;gap:20px}
  .svc2-img{height:200px}
  .svc2-bd{padding:18px 18px 22px}
  .svc2-tl{font-size:17px}
  .svc2-ds{font-size:13px}
  .btn-detail{font-size:14px;padding:14px 28px}

  /* ── SKILL SECTION ── */
  .skill-wrap{padding:56px 16px}
  .skill-inner{grid-template-columns:1fr;gap:32px}
  .skill-txt h2{font-size:24px}
  .skill-txt p{font-size:13.5px}
  .skill-photo{height:240px}
  .btn-skill{font-size:13.5px;padding:12px 22px}

  /* ── WORKS2 HOME ── */
  .works2-wrap{padding:56px 16px}
  .w2hd h2{font-size:26px}
  .w2hd p{font-size:13.5px}
  .w2grid{grid-template-columns:1fr;gap:16px}
  .w2card{height:220px}

  /* ── ABOUT2 HOME ── */
  .ab2-wrap{padding:56px 16px}
  .ab2-inner{grid-template-columns:1fr;gap:32px}
  .ab2-txt h2{font-size:26px}
  .ab2-txt p{font-size:13.5px}
  .ab2-cimg{height:200px}
  .ab2-cbody{padding:18px 20px}

  /* ── SECTION HEADINGS ── */
  .co-hd2 h2,.co-hd-left h2{font-size:24px}
  .svc2-hd h2{font-size:26px}

  /* ── COMPANY PAGE ── */
  .co-phero{padding:56px 16px}
  .co-phero-title{font-size:28px}
  .co-phero-desc{font-size:13.5px}
  .co-pres-sec,.co-ov-sec,.co-mvv-sec{padding:56px 16px}
  .co-pres-inner{grid-template-columns:1fr;gap:28px}
  .co-ov-inner{grid-template-columns:1fr;gap:28px}
  .co-ov-img{height:220px}
  .co-ov-table th{width:90px;font-size:13px}
  .co-ov-table td{font-size:13px}
  .co-mvv-grid{grid-template-columns:1fr;gap:14px}
  .co-mvv-card{padding:28px 20px}

  /* ── SERVICES PAGE ── */
  .ph{padding:72px 16px 40px}
  .pht{font-size:28px}
  .phd{font-size:13.5px}
  .sp{padding:40px 16px}
  .si{max-width:100%}
  .si > div > div[style*="display:grid"]{
    grid-template-columns:1fr!important;
    gap:28px!important;
    padding:28px 20px!important
  }
  .proc-sec{padding:56px 16px}
  .proc-grid{grid-template-columns:1fr;gap:14px}
  .proc-card{padding:26px 20px}
  .proc-card::after{display:none}
  .supp-sec{padding:56px 16px}
  .supp-grid{grid-template-columns:1fr;gap:14px}
  .supp-card{padding:32px 20px}

  /* ── WORKS PAGE ── */
  .wks-phero{padding:56px 16px}
  .wks-phero h1{font-size:28px}
  .wks-fw{padding:16px}
  .wks-fl{gap:6px}
  .wks-tb{font-size:12px;padding:6px 12px}
  .wks-projs{padding:40px 16px}
  .wks-proj,.wks-proj.rev{grid-template-columns:1fr;direction:ltr;gap:24px;margin-bottom:48px}
  .wks-pimg{height:220px}
  .wks-pinfo h2{font-size:20px}
  .wks-pmeta{flex-direction:column;gap:6px}
  .wks-pmeta-item{border-radius:8px!important;border-right:1px solid var(--sl2)!important}
  .wks-pfeats{grid-template-columns:1fr;gap:6px}
  .wks-fields{padding:56px 16px}
  .wks-fgrid{grid-template-columns:repeat(2,1fr);gap:12px}
  .wks-fcard{padding:24px 16px}

  /* ── CAREERS PAGE ── */
  .cr-hero{padding:56px 16px}
  .cr-hero h1{font-size:28px}
  .cr-vals,.cr-env,.cr-ben,.cr-how{padding:56px 16px}
  .cr-vgrid{grid-template-columns:repeat(2,1fr);gap:14px}
  .cr-vcard{padding:24px 16px}
  .cr-egrid{grid-template-columns:1fr;gap:16px}
  .cr-eimg{height:180px}
  .cr-filter-wrap{padding:16px}
  .cr-jobs{padding:40px 16px}
  .cr-jcard{padding:24px 20px}
  .cr-jcard-top{flex-direction:column;gap:4px}
  .cr-jsal{text-align:left!important;font-size:16px}
  .cr-jbody{grid-template-columns:1fr;gap:24px}
  .cr-bengrid{grid-template-columns:1fr;gap:14px}
  .cr-howgrid{grid-template-columns:1fr}
  .cr-docs-grid{grid-template-columns:1fr;gap:8px}
  .cr-how{padding:56px 16px}
  .cr-howbox{padding:24px 16px}

  /* ── CONTACT PAGE ── */
  .ctg{grid-template-columns:1fr!important;gap:28px}
  .cfm{padding:24px 20px!important}
  .fmg{margin-bottom:14px}
  .faq-sec{padding:56px 16px}
  .faq-list{gap:14px}
  .faq-card{padding:20px 20px}
  .faq-q{font-size:14.5px}
  .faq-a{font-size:13.5px}

  /* ── FOOTER ── */
  .fti{padding:40px 16px 24px}
  .ftop{grid-template-columns:1fr!important;gap:32px}
  .fcol-main,.fcol{min-width:0}
  .fbot{flex-direction:column!important;gap:12px;text-align:center}
  .fbot-links{justify-content:center;flex-wrap:wrap;gap:12px}
}

/* TABLET 481-768px */
@media(min-width:481px) and (max-width:768px){
  .ni{padding:0 20px}
  .nl{display:none}
  .svc2-grid{grid-template-columns:1fr;gap:20px}
  .w2grid{grid-template-columns:1fr;gap:16px}
  .cr-jbody{grid-template-columns:1fr;gap:24px}
  .cr-jcard-top{flex-direction:column}
  .wks-proj,.wks-proj.rev{grid-template-columns:1fr;direction:ltr}
  .ftop{grid-template-columns:1fr 1fr!important}
}

/* ── HAMBURGER MENU ── */
.hb-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1100}
.hb-btn span{display:block;width:22px;height:2px;background:var(--sl7);border-radius:2px;transition:all .3s}
@media(max-width:768px){
  .hb-btn{display:flex}
  .nl{position:fixed;top:54px;left:0;right:0;background:#f5f7fc;border-bottom:1px solid var(--sl2);flex-direction:column;padding:12px 0;display:none;z-index:999;box-shadow:0 4px 12px rgba(0,0,0,.1)}
  .nl.open{display:flex}
  .nb{padding:14px 24px;text-align:left;border-radius:0;font-size:15px;width:100%;border-bottom:1px solid var(--sl1)}
  .nb:last-child{border-bottom:none}
}

/* ── GLOBAL REFINEMENTS ── */
*{box-sizing:border-box}

/* Smooth card lift - applied globally */
.svc2-card,.prod-card,.w2card,.ab2-card,.co-mvv-card,.cr-vcard,.cr-ecard,.wks-fcard,.faq-card,.cr-bencard{
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

/* Section heading refinement */
.co-hd2 h2::after,.co-hd-left h2::after,.w2hd h2::after,.supp-hd h2::after,
.cr-jhd .co-hd2 h2::after,.faq-hd h2::after,.cr-how .co-hd2 h2::after,
.proc-sec .co-hd2 h2::after{
  width:36px;height:2px;border-radius:1px;
  background:linear-gradient(90deg,var(--blue),var(--accent));
}

/* ── HERO UPGRADE ── */
.hero{background:#0a0f1e}
.slide-bg{opacity:0;transition:opacity 1.2s ease}
.slide-bg.act{opacity:1}
.hbar{background:linear-gradient(90deg,rgba(37,99,235,.9),rgba(14,165,233,.7));height:3px}

/* ── STATS UPGRADE ── */
.stats-sec{background:#fff;padding:52px 32px;border-top:none;border-bottom:none;
  box-shadow:inset 0 1px 0 var(--sl1),inset 0 -1px 0 var(--sl1)}
.stat-bx{position:relative;padding:24px 16px}
.stat-nn{background:linear-gradient(135deg,var(--blue),var(--accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── SERVICE CARDS (home) ── */
.svc2-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--sl1)}
.svc2-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc2-badge{border-radius:12px;width:48px;height:48px;background:linear-gradient(135deg,var(--blue),var(--accent))}
.svc2-tl{font-size:18px;font-weight:800;letter-spacing:-.01em}

/* ── SKILL SECTION UPGRADE ── */
.skill-wrap{background:linear-gradient(150deg,#0f172a 0%,#1e3a8a 50%,#1d4ed8 100%);position:relative;overflow:hidden}
.skill-wrap::before{content:'';position:absolute;top:-60%;right:-10%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(14,165,233,.15) 0%,transparent 70%);pointer-events:none}
.skill-txt h2{font-size:clamp(26px,3.5vw,40px);letter-spacing:-.02em;line-height:1.2}
.btn-skill{border-radius:100px;font-weight:700;letter-spacing:.03em;
  box-shadow:0 4px 20px rgba(255,255,255,.2);transition:all var(--transition)}
.btn-skill:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,255,255,.3)}

/* ── WORKS2 (home施工実績) ── */
.w2card{border-radius:var(--radius-lg)}
.w2tag{font-size:11px;font-weight:700;letter-spacing:.04em;backdrop-filter:blur(8px);background:rgba(37,99,235,.85)}
.w2title{font-size:17px;font-weight:800;letter-spacing:-.01em}

/* ── ABOUT2 (home会社) ── */
.ab2-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.ab2-fact{padding:16px 0}
.ab2-ico{border-radius:10px;background:var(--blu-lt)}

/* ── SECTION BACKGROUNDS alternating ──  */
.proc-sec{background:linear-gradient(180deg,#fff 0%,var(--sl0) 100%)}
.supp-sec{background:linear-gradient(150deg,#1d4ed8 0%,var(--blue) 60%,var(--accent) 100%)}

/* ── PROCESS CARDS ── */
.proc-num{background:linear-gradient(135deg,var(--blue),var(--accent));box-shadow:0 6px 18px rgba(37,99,235,.35)}
.proc-card{border-radius:var(--radius-md);transition:all var(--transition)}
.proc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}

/* ── WORKS PAGE ── */
.wks-phero{background:linear-gradient(150deg,#0a0f1e 0%,#1e3a8a 60%,#2563eb 100%)}
.wks-pimg{border-radius:var(--radius-lg)}
.wks-award{border-radius:100px}
.wks-tb{border-radius:100px;font-weight:600}
.wks-tb.act{background:var(--blue);box-shadow:0 4px 14px rgba(37,99,235,.3)}

/* ── COMPANY PAGE ── */
.co-phero{background:linear-gradient(150deg,#0a0f1e 0%,#1e3a8a 60%,#2563eb 100%)}
.co-mvv-card{border-radius:var(--radius-lg)}
.co-mvv-icon{border-radius:14px;background:linear-gradient(135deg,var(--blu-lt),#e0f2fe)}

/* ── CAREERS PAGE ── */
.cr-hero{background:linear-gradient(150deg,#0a0f1e 0%,#1e3a8a 60%,#2563eb 100%)}
.cr-ftab{border-radius:100px;font-weight:600}
.cr-ftab.act{background:var(--blue);box-shadow:0 4px 14px rgba(37,99,235,.3)}
.cr-jcard{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.cr-jcard:hover{box-shadow:var(--shadow-lg)}
.cr-apply-btn{border-radius:100px;font-weight:700;letter-spacing:.04em;
  background:linear-gradient(135deg,var(--blue),var(--accent));
  box-shadow:0 6px 20px rgba(37,99,235,.3);transition:all var(--transition)}
.cr-apply-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(37,99,235,.45)}

/* ── CONTACT ── */
.faq-card{border-radius:var(--radius-md);border:1px solid var(--sl1)}
.faq-card:hover{box-shadow:var(--shadow-md);border-color:rgba(37,99,235,.15)}
.faq-q-label{font-size:18px;color:var(--blue);font-weight:900}
.bsub{background:linear-gradient(135deg,var(--blue),var(--accent));
  border-radius:100px;font-weight:700;letter-spacing:.04em;
  box-shadow:0 6px 20px rgba(37,99,235,.3);transition:all var(--transition)}
.bsub:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(37,99,235,.4)}

/* ── FOOTER UPGRADE ── */
footer{background:linear-gradient(150deg,#0a0f1e 0%,#0f172a 100%)}
.fle{font-size:16px;font-weight:800;letter-spacing:.02em}
.fcol h4{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px}
.fcol ul li a{color:rgba(255,255,255,.7);transition:color var(--transition)}
.fcol ul li a:hover{color:#fff}
.fbot{border-top:1px solid rgba(255,255,255,.08)}

/* ── CTA BUTTON (global) ── */
.btn-cta,.btn-detail{
  background:linear-gradient(135deg,var(--blue),var(--accent));
  border-radius:100px;font-weight:700;letter-spacing:.04em;
  box-shadow:var(--shadow-blue);transition:all var(--transition)
}
.btn-cta:hover,.btn-detail:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(37,99,235,.42)}

/* ── SCROLL FADE-IN ANIMATION ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.svc2-card,.proc-card,.w2card,.wks-proj,.cr-jcard,.faq-card{animation:fadeUp .6s ease both}
.svc2-card:nth-child(2){animation-delay:.1s}
.svc2-card:nth-child(3){animation-delay:.2s}
.proc-card:nth-child(2){animation-delay:.1s}
.proc-card:nth-child(3){animation-delay:.2s}
.proc-card:nth-child(4){animation-delay:.3s}
.proc-card:nth-child(5){animation-delay:.4s}
.proc-card:nth-child(6){animation-delay:.5s}

/* ── SERVICE ITEMS ── */
.sl{font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--blue);
  text-transform:uppercase;margin-bottom:8px;font-family:sans-serif}

/* Anchor-based nav and logo (multi-page conversion) */
.logo{text-decoration:none;color:inherit}
.nb{display:inline-block;text-decoration:none}
