/* 岡本電設 — sub-page styles v2 */

/* ============================================================
   Reusable header/footer markup blocks (HTML uses partials)
   ============================================================ */

/* shared placeholder for image scenes (sub-pages) */
.scene-frame{position:relative;overflow:hidden;border-radius:2px;background:#eadfd2}
.scene-frame img{width:100%;height:100%;object-fit:cover;display:block}
.scene-frame::after{
  content:"";position:absolute;left:-10px;top:-10px;width:64px;height:64px;
  border:1px solid var(--c-orange);
}

/* ============================================================
   BUSINESS page
   ============================================================ */
.biz{background:var(--c-bg);padding:0}
.biz__row{
  display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center;
  padding:120px 0;
  border-top:1px solid var(--c-line);
}
.biz__row:first-of-type{border-top:0}
.biz__row--rev .biz__media{order:2}
.biz__media{aspect-ratio:5/6;position:relative;border-radius:2px;overflow:hidden;box-shadow:var(--shadow-md)}
.biz__media img{width:100%;height:100%;object-fit:cover}
.biz__media-caption{
  position:absolute;left:18px;bottom:14px;font-family:var(--f-en);font-style:italic;font-size:11px;
  color:#fff;background:rgba(28,23,20,.6);padding:4px 12px;letter-spacing:.04em;backdrop-filter:blur(4px);
}
.biz__num{
  font-family:var(--f-en);font-style:italic;font-size:64px;color:var(--c-orange);font-weight:500;line-height:1;
}
.biz__num small{display:block;font-family:var(--f-mono);font-style:normal;font-size:11px;color:var(--c-ink-3);letter-spacing:.18em;margin-top:14px}
.biz__title{
  font-family:var(--f-serif);font-weight:500;font-size:clamp(26px,3.4vw,38px);line-height:1.5;letter-spacing:.06em;margin:32px 0 0;
  text-wrap:balance;
}
.biz__title .em{color:var(--c-orange)}
.biz__lead{font-size:14.5px;line-height:2.1;color:var(--c-ink-2);margin:24px 0 32px;letter-spacing:.04em;text-wrap:pretty}
.biz__list{list-style:none;margin:0;padding:0;border-top:1px solid var(--c-line)}
.biz__list li{
  position:relative;padding:18px 0 18px 28px;border-bottom:1px solid var(--c-line);
  font-size:13.5px;color:var(--c-ink);letter-spacing:.04em;
}
.biz__list li::before{
  content:"";position:absolute;left:0;top:50%;width:14px;height:1px;background:var(--c-orange);
}

@media (max-width:880px){
  .biz__row{grid-template-columns:1fr;gap:40px;padding:72px 0}
  .biz__row--rev .biz__media{order:0}
}

/* ============================================================
   COMPANY page
   ============================================================ */
.cmp{background:var(--c-bg);padding-top:0}
.cmp__inner{max-width:1100px;margin:0 auto;padding:120px 48px}
.cmp__head{
  display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:end;
  margin-bottom:80px;
}
.cmp-table{width:100%;border-collapse:collapse;margin:0}
.cmp-table tr{border-top:1px solid var(--c-line)}
.cmp-table tr:last-child{border-bottom:1px solid var(--c-line)}
.cmp-table th,.cmp-table td{
  padding:28px 0;text-align:left;font-size:14.5px;line-height:2;vertical-align:top;letter-spacing:.04em;
}
.cmp-table th{
  width:240px;font-family:var(--f-en);font-style:italic;color:var(--c-orange);font-weight:500;font-size:14px;
}
.cmp-table th small{
  display:block;font-family:var(--f-sans);font-style:normal;color:var(--c-ink);font-size:13px;letter-spacing:.06em;
  margin-top:4px;font-weight:500;
}
.cmp-table td{color:var(--c-ink-2)}
.cmp-table td strong{color:var(--c-ink);font-weight:500}

.cmp-map{
  margin-top:80px;height:420px;border-radius:2px;overflow:hidden;position:relative;
  background:#E8DBC1;
}
.cmp-map::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(transparent 49%,rgba(80,55,30,.28) 49% 51%,transparent 51%) 0 0/100% 48px,
    linear-gradient(90deg,transparent 49%,rgba(80,55,30,.28) 49% 51%,transparent 51%) 0 0/48px 100%;
}
.cmp-map::after{
  content:"";position:absolute;left:50%;top:55%;width:14px;height:14px;border-radius:50%;
  background:var(--c-orange);transform:translate(-50%,-50%);
  box-shadow:0 0 0 8px rgba(224,122,60,.2),0 0 0 16px rgba(224,122,60,.1);
}
.cmp-map .pin-label{
  position:absolute;left:50%;top:43%;transform:translate(-50%,0);
  background:#fff;color:var(--c-ink);padding:10px 18px;
  font-size:12.5px;font-weight:500;box-shadow:var(--shadow-sm);letter-spacing:.06em;
}

@media (max-width:880px){
  .cmp__inner{padding:64px 24px}
  .cmp__head{grid-template-columns:1fr;gap:32px;margin-bottom:48px}
  .cmp-table th{width:120px;font-size:12px}
  .cmp-table th small{font-size:12px}
  .cmp-table td{font-size:13.5px}
}

/* ============================================================
   MESSAGE page
   ============================================================ */
.msg{background:var(--c-bg);padding-top:0}
.msg__inner{max-width:1100px;margin:0 auto;padding:120px 48px}
.msg__hero{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.msg__media{aspect-ratio:4/5;position:relative;border-radius:2px;overflow:hidden}
.msg__media img{width:100%;height:100%;object-fit:cover}
.msg__media::after{content:"";position:absolute;left:-12px;top:-12px;width:80px;height:80px;border:1px solid var(--c-orange)}
.msg__title{
  font-family:var(--f-serif);font-weight:500;font-size:clamp(26px,3.4vw,40px);line-height:1.6;letter-spacing:.06em;
  text-wrap:balance;
}
.msg__title .em{color:var(--c-orange)}
.msg__title small{display:block;font-family:var(--f-en);font-style:italic;font-size:14px;color:var(--c-ink-3);font-weight:500;margin-bottom:18px;letter-spacing:.04em}

.msg__body{
  margin-top:120px;display:grid;grid-template-columns:1fr 280px;gap:80px;align-items:start;
  border-top:1px solid var(--c-line);padding-top:80px;
}
.msg__body p{font-size:14.5px;line-height:2.15;color:var(--c-ink-2);margin:0 0 1.5em;letter-spacing:.04em;text-wrap:pretty}
.msg__body p:first-child::first-letter{
  font-family:var(--f-serif);font-size:64px;float:left;line-height:.9;padding:8px 18px 0 0;color:var(--c-orange);font-weight:500;
}
.msg__sign{
  margin-top:48px;font-family:var(--f-serif);font-size:18px;letter-spacing:.06em;color:var(--c-ink);
}
.msg__sign small{display:block;font-family:var(--f-en);font-style:italic;font-size:12px;color:var(--c-ink-3);font-weight:500;letter-spacing:.04em;margin-bottom:8px}
.msg__card{
  background:#fff;padding:32px;position:sticky;top:120px;border:1px solid var(--c-line);
}
.msg__card h4{font-family:var(--f-en);font-style:italic;font-size:13px;color:var(--c-orange);font-weight:500;margin:0 0 16px;letter-spacing:.04em}
.msg__card dl{margin:0;display:grid;gap:8px;font-size:13px}
.msg__card dt{font-family:var(--f-en);font-style:italic;color:var(--c-ink-3);font-size:11px;letter-spacing:.04em}
.msg__card dd{margin:0 0 12px;font-size:13.5px;line-height:1.7;color:var(--c-ink)}

/* baseball */
.baseball{
  margin-top:120px;background:var(--c-ink);color:#f1e8da;padding:80px;
  display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center;
  position:relative;overflow:hidden;
}
.baseball::before{
  content:"BASEBALL";position:absolute;right:-40px;top:-30px;
  font-family:var(--f-en);font-style:italic;font-size:240px;
  color:rgba(232,116,60,.06);letter-spacing:0;line-height:1;font-weight:500;pointer-events:none;
}
.baseball__eye{font-family:var(--f-en);font-style:italic;font-size:14px;color:var(--c-orange-soft);font-weight:500;letter-spacing:.04em}
.baseball h3{
  font-family:var(--f-serif);font-weight:500;font-size:clamp(24px,3vw,34px);line-height:1.55;letter-spacing:.06em;
  margin:18px 0 24px;color:#fff;text-wrap:balance;
}
.baseball p{font-size:14px;line-height:2.05;color:#cbb9a3;margin:0 0 1.4em;letter-spacing:.04em}
.baseball__media{aspect-ratio:4/5;position:relative;overflow:hidden}
.baseball__media img{width:100%;height:100%;object-fit:cover}
.baseball__stats{margin-top:32px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.08)}
.baseball__stats div{background:var(--c-ink);padding:20px;text-align:center}
.baseball__stats .v{font-family:var(--f-en);font-style:italic;font-size:28px;color:var(--c-orange-soft);font-weight:500;line-height:1}
.baseball__stats .k{font-family:var(--f-en);font-style:italic;font-size:11px;color:#a89b8a;letter-spacing:.04em;margin-top:8px}

@media (max-width:880px){
  .msg__inner{padding:64px 24px}
  .msg__hero,.msg__body,.baseball{grid-template-columns:1fr;gap:40px}
  .msg__body{margin-top:64px;padding-top:48px}
  .msg__card{position:static}
  .baseball{padding:40px 24px;margin-top:64px}
}

/* ============================================================
   WORKS page
   ============================================================ */
.works-page{background:var(--c-bg);padding:120px 0}
.works-page__inner{max-width:1300px;margin:0 auto;padding:0 48px}
.works-page__head{
  display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:end;margin-bottom:64px;
}
.works-filter{display:flex;gap:8px;flex-wrap:wrap;margin:48px 0 64px}
.works-filter button{
  padding:10px 20px;border:1px solid var(--c-line);font-size:12px;letter-spacing:.06em;
  background:transparent;color:var(--c-ink-2);transition:all .25s var(--ease);
  font-family:var(--f-en);font-style:italic;
}
.works-filter button:hover{border-color:var(--c-orange);color:var(--c-orange)}
.works-filter button.is-active{background:var(--c-ink);border-color:var(--c-ink);color:#fff}

.works-grid-page{display:grid;grid-template-columns:repeat(2,1fr);gap:80px 48px}
.work-page-item .ba{aspect-ratio:5/4}
.work-page-item__head{display:flex;justify-content:space-between;align-items:baseline;margin-top:20px;font-family:var(--f-en);font-style:italic;font-size:12px;letter-spacing:.04em}
.work-page-item__cat{color:var(--c-orange)}
.work-page-item__date{color:var(--c-ink-3)}
.work-page-item h3{font-family:var(--f-serif);font-weight:500;font-size:22px;letter-spacing:.06em;margin:8px 0 14px;line-height:1.55}
.work-page-item p{font-size:13.5px;line-height:2;color:var(--c-ink-2);margin:0 0 20px;letter-spacing:.04em;text-wrap:pretty}
.work-page-item__price{
  display:inline-flex;align-items:baseline;gap:14px;padding:14px 20px;background:var(--c-bg-2);
  border-left:2px solid var(--c-orange);font-size:12px;color:var(--c-ink-2);letter-spacing:.04em;
}
.work-page-item__price strong{font-family:var(--f-en);font-style:normal;font-size:20px;color:var(--c-ink);font-weight:600;letter-spacing:.02em}

.works-note{
  margin-top:80px;padding:32px;background:var(--c-bg-2);font-size:13px;line-height:2;color:var(--c-ink-2);
  text-align:center;letter-spacing:.04em;
}
.works-note strong{color:var(--c-ink);font-weight:500}

@media (max-width:760px){
  .works-page__head{grid-template-columns:1fr;gap:32px}
  .works-grid-page{grid-template-columns:1fr;gap:64px}
}

/* ============================================================
   FAQ page
   ============================================================ */
.faq{background:var(--c-bg);padding:120px 0}
.faq__inner{max-width:920px;margin:0 auto;padding:0 48px}
.faq__head{margin-bottom:64px}
.faq__list{}
.faq__item{border-top:1px solid var(--c-line)}
.faq__list .faq__item:last-child{border-bottom:1px solid var(--c-line)}
.faq__item summary{
  list-style:none;padding:32px 56px 32px 64px;cursor:pointer;
  font-family:var(--f-serif);font-weight:500;font-size:16px;letter-spacing:.04em;
  position:relative;line-height:1.7;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::before{
  content:"Q.";position:absolute;left:0;top:34px;
  font-family:var(--f-en);font-style:italic;font-size:18px;color:var(--c-orange);font-weight:500;letter-spacing:0;
}
.faq__item summary::after{
  content:"";position:absolute;right:14px;top:38px;width:12px;height:12px;
  border-right:1.4px solid var(--c-ink-2);border-bottom:1.4px solid var(--c-ink-2);
  transform:rotate(45deg);transition:transform .3s var(--ease);
}
.faq__item[open] summary::after{transform:rotate(-135deg);top:42px}
.faq__answer{
  padding:0 24px 36px 64px;font-size:14px;line-height:2.1;color:var(--c-ink-2);position:relative;letter-spacing:.04em;text-wrap:pretty;
}
.faq__answer::before{
  content:"A.";position:absolute;left:0;top:0;
  font-family:var(--f-en);font-style:italic;font-size:18px;color:var(--c-ink);font-weight:500;letter-spacing:0;
}

@media (max-width:560px){
  .faq__inner{padding:0 24px}
  .faq__item summary{padding:24px 36px 24px 48px;font-size:15px}
  .faq__item summary::before{top:26px;font-size:16px}
  .faq__item summary::after{top:30px}
  .faq__item[open] summary::after{top:34px}
  .faq__answer{padding:0 0 28px 48px}
}

/* ============================================================
   PRIVACY page
   ============================================================ */
.policy{max-width:880px;margin:0 auto;padding:120px 48px;font-size:14px;line-height:2.1;color:var(--c-ink-2)}
.policy h2{
  font-family:var(--f-serif);font-weight:500;font-size:20px;letter-spacing:.06em;color:var(--c-ink);
  margin:56px 0 18px;padding-left:18px;border-left:2px solid var(--c-orange);line-height:1.6;
}
.policy h2 small{display:block;font-family:var(--f-en);font-style:italic;font-size:12px;color:var(--c-orange);font-weight:500;letter-spacing:.04em;margin-bottom:6px}
.policy p{margin:0 0 1.4em;text-wrap:pretty;letter-spacing:.04em}
.policy ul{margin:0 0 1.4em;padding-left:1.4em}
.policy li{margin-bottom:.5em}
.policy__updated{margin-top:64px;font-family:var(--f-en);font-style:italic;font-size:12px;color:var(--c-ink-3);text-align:right;letter-spacing:.04em}

@media (max-width:560px){
  .policy{padding:64px 24px}
}

/* ============================================================
   Sub-page CTA band
   ============================================================ */
.sub-cta{
  background:var(--c-ink);color:#f1e8da;padding:100px 0;position:relative;overflow:hidden;
}
.sub-cta::before{
  content:"CONTACT";position:absolute;left:-2%;top:-30%;font-family:var(--f-en);font-style:italic;
  font-size:clamp(120px,16vw,220px);color:rgba(232,116,60,.07);letter-spacing:0;line-height:1;font-weight:500;
}
.sub-cta__inner{position:relative;max-width:1100px;margin:0 auto;padding:0 48px;text-align:center}
.sub-cta__hand{font-family:var(--f-en);font-style:italic;font-size:18px;color:var(--c-orange-soft);font-weight:500}
.sub-cta__title{font-family:var(--f-serif);font-weight:500;font-size:clamp(26px,3.4vw,38px);letter-spacing:.06em;line-height:1.6;margin:14px 0 32px;color:#fff;text-wrap:balance}
.sub-cta__sub{font-size:14px;color:#cbb9a3;line-height:2;margin:0 0 36px;letter-spacing:.04em}
.sub-cta__buttons{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center}
