/*
Theme Name: GABEL Official Final
Theme URI: https://www.gabel.co.jp/
Author: GABEL
Author URI: https://www.gabel.co.jp/
Description: GABEL official WordPress theme. World Materials, Japanese Craftsmanship.
Version: 1.0
Requires at least: 5.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: gabel-official-final
Tags: custom, responsive, business
*/

:root{
  --paper:#f6f1e8;
  --ink:#262420;
  --muted:#6f675d;
  --navy:#17263a;
  --gold:#a98a52;
  --line:#d9cdbb;
  --white:#fffaf2;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  line-height:1.9;
  letter-spacing:.04em;
}
a{color:inherit;text-decoration:none}
.site-header{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:22px 6vw;
  background:rgba(246,241,232,.94);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(8px);
}
.logo{
  font-family:"Times New Roman","Yu Mincho",serif;
  font-size:28px;
  letter-spacing:.18em;
  color:var(--navy);
}
.nav{
  display:flex;
  gap:22px;
  align-items:center;
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.nav-cta{
  color:var(--white)!important;
  background:var(--gold);
  padding:8px 14px;
  border:1px solid var(--gold);
}
.hero{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  min-height:760px;
  border-bottom:1px solid var(--line);
}
.photo-frame{
  margin:0;
  overflow:hidden;
  background:
    linear-gradient(135deg,rgba(23,38,58,.85),rgba(169,138,82,.45)),
    repeating-linear-gradient(45deg,#d8cbb7 0,#d8cbb7 1px,#eee5d6 1px,#eee5d6 18px);
}
.photo-frame img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
  filter:saturate(.82) contrast(.98);
}
.hero__image.photo-frame{min-height:760px}
.hero__content{
  padding:110px 7vw 80px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.eyebrow{
  margin:0 0 14px;
  color:var(--gold);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:600;
}
h1,h2,h3,h4{
  font-family:"Yu Mincho","Hiragino Mincho ProN","Times New Roman",serif;
  line-height:1.45;
  font-weight:500;
  color:var(--navy);
}
h1{font-size:clamp(42px,5vw,72px); margin:0 0 32px}
h2{font-size:clamp(30px,3.5vw,48px); margin:0 0 26px}
h3{font-size:28px; margin:0 0 16px}
p{margin:0 0 18px}
.buttons{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.btn{
  min-width:150px;
  padding:12px 22px;
  border:1px solid var(--navy);
  text-align:center;
  font-size:14px;
  display:inline-block;
}
.btn-primary{background:var(--navy);color:var(--white)}
.btn-secondary{background:transparent;color:var(--navy)}
.section{
  padding:95px 7vw;
  border-bottom:1px solid var(--line);
}
.section-title{
  max-width:900px;
  margin:0 auto 46px;
  text-align:center;
}
.philosophy,.material{
  max-width:980px;
  margin:auto;
  text-align:center;
}
.philosophy{
  background:var(--white);
  outline:1px solid var(--line);
  outline-offset:-28px;
}
.material-list{
  max-width:760px;
  margin:30px auto;
  display:grid;
  gap:18px;
}
.material-item strong{
  display:block;
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-size:23px;
  color:var(--navy);
}
.material-item span{
  display:block;
  color:var(--muted);
  font-size:14px;
}
.cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.card{
  background:rgba(255,250,242,.58);
  border:1px solid var(--line);
  padding:24px;
}
.card__image.photo-frame{
  height:230px;
  margin:-24px -24px 26px;
}
.card p{color:#3b3731}
.signature{
  margin-top:18px;
  color:var(--gold)!important;
  font-family:"Times New Roman",serif;
  font-size:14px;
  line-height:1.6;
}
.flow{
  max-width:900px;
  margin:0 auto;
  padding:0;
  list-style:none;
  display:grid;
  gap:14px;
}
.flow li{
  display:flex;
  align-items:center;
  gap:22px;
  padding:22px 26px;
  background:rgba(255,250,242,.55);
  border:1px solid var(--line);
  font-family:"Yu Mincho",serif;
  font-size:20px;
}
.flow span{
  color:var(--gold);
  font-family:"Times New Roman",serif;
  letter-spacing:.16em;
}
.reservation{background:var(--white)}
.reservation-single{
  max-width:980px;
  margin:0 auto;
}
.reservation-step{
  border-top:1px solid var(--line);
  padding-top:34px;
  margin-top:34px;
}
.reservation-step:first-child{
  border-top:none;
  padding-top:0;
  margin-top:0;
}
.reservation-step h3{text-align:center;margin-bottom:20px}
.step-label{
  text-align:center;
  color:var(--gold);
  font-size:12px;
  letter-spacing:.18em;
  font-weight:600;
  margin-bottom:6px;
}
.sub-note{text-align:center;color:var(--muted);font-size:14px}
.booking-card,.reserve-form{
  background:rgba(246,241,232,.72);
  border:1px solid var(--line);
  padding:30px;
}
.booking-card-wide{
  max-width:920px;
  margin:0 auto;
}
.booking-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:26px;
}
.calendar-btn{
  width:42px;
  height:42px;
  border:1px solid var(--line);
  background:var(--white);
  color:var(--navy);
  font-size:28px;
  line-height:1;
  cursor:pointer;
}
.slot-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}
.slot-day{
  border:1px solid var(--line);
  background:rgba(255,250,242,.75);
  padding:14px;
  display:grid;
  gap:10px;
}
.slot-day strong{
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  color:var(--navy);
  font-size:15px;
  text-align:center;
}
.slot-day button{
  border:1px solid var(--navy);
  background:var(--white);
  color:var(--navy);
  padding:10px 6px;
  cursor:pointer;
  font-family:inherit;
}
.slot-day button:hover{background:var(--navy);color:var(--white)}
.slot-day button:disabled{
  border-color:#cfc7bb;
  background:#e7dfd3;
  color:#9a9186;
  cursor:not-allowed;
}
.booking-note{
  margin-top:18px;
  font-size:12px;
  color:var(--muted);
  line-height:1.8;
}
.check-list-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
  max-width:820px;
  margin:20px auto 0;
}
.check-list label{
  display:block;
  padding:11px 12px;
  border:1px solid var(--line);
  background:rgba(255,250,242,.72);
}
.reserve-form-wide{
  max-width:920px;
  margin:34px auto 0;
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px 18px;
}
.field{
  display:grid;
  gap:6px;
  margin-bottom:14px;
  color:var(--navy);
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
}
.field input,.field textarea{
  width:100%;
  border:1px solid var(--line);
  background:var(--white);
  padding:12px 14px;
  font:inherit;
  color:var(--ink);
}
.submit-area{
  max-width:520px;
  margin:28px auto 0;
  text-align:center;
}
.submit-area .reserve-submit{width:100%}
.final-contact{
  background:var(--navy);
  color:var(--white);
  text-align:center;
  border-bottom:none;
  padding-top:90px;
  padding-bottom:86px;
}
.final-contact .eyebrow{color:#d7bb7c}
.final-contact h2,.final-contact h3{color:var(--white)}
.final-contact-inner{
  max-width:1040px;
  margin:0 auto;
}
.final-contact .lead{
  max-width:680px;
  margin:0 auto 34px;
  color:rgba(255,250,242,.86);
}
.simple-contact-row{
  max-width:920px;
  margin:38px auto 42px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border-top:1px solid rgba(255,250,242,.32);
  border-bottom:1px solid rgba(255,250,242,.32);
}
.simple-contact-item{
  min-height:150px;
  padding:30px 22px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:8px;
  border-right:1px solid rgba(255,250,242,.22);
}
.simple-contact-item:last-child{border-right:none}
.simple-contact-item:hover{background:rgba(255,250,242,.08)}
.simple-contact-item span{
  color:#d7bb7c;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.simple-contact-item strong{
  color:var(--white);
  font-family:"Yu Mincho","Hiragino Mincho ProN","Times New Roman",serif;
  font-size:clamp(18px,1.8vw,24px);
  font-weight:500;
  line-height:1.45;
  word-break:break-word;
}
.simple-contact-item.primary{background:rgba(169,138,82,.18)}
.simple-company{
  max-width:760px;
  margin:0 auto;
  padding:26px 20px;
  border-bottom:1px solid rgba(255,250,242,.20);
}
.simple-company p{
  margin:4px 0;
  font-size:14px;
  color:rgba(255,250,242,.84);
}
.closing-message{
  margin-top:38px;
  font-family:"Times New Roman","Yu Mincho",serif;
  letter-spacing:.08em;
}
.closing-message p{
  margin:0;
  font-size:clamp(24px,3.2vw,40px);
  line-height:1.25;
  color:var(--white);
}
.closing-message span{
  display:block;
  margin-top:18px;
  color:#d7bb7c;
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-size:18px;
}
.footer{
  padding:38px 7vw;
  text-align:center;
  color:var(--muted);
}
.footer nav{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:18px;
  margin-bottom:22px;
  font-size:13px;
}
.footer p{
  margin:8px 0;
  font-size:13px;
}
#contact,#reservation,#philosophy,#material,#collection,#flow{
  scroll-margin-top:96px;
}
@media (max-width:980px){
  .cards{grid-template-columns:1fr 1fr}
  .nav{display:none}
}
@media (max-width:900px){
  .hero{grid-template-columns:1fr}
  .hero__image.photo-frame{min-height:360px}
  .hero__content{padding:60px 7vw}
  .section{padding:70px 6vw}
  .slot-grid{grid-template-columns:1fr 1fr}
  .check-list-grid,.form-grid{grid-template-columns:1fr}
  .simple-contact-row{
    grid-template-columns:1fr;
    max-width:560px;
  }
  .simple-contact-item{
    border-right:none;
    border-bottom:1px solid rgba(255,250,242,.22);
    min-height:120px;
  }
  .simple-contact-item:last-child{border-bottom:none}
}
@media (max-width:640px){
  .cards{grid-template-columns:1fr}
  .slot-grid{grid-template-columns:1fr}
}


/* Formal reservation embed area */
.reservation-formal{
  background:var(--white);
}
.reservation-official{
  max-width:980px;
  margin:0 auto;
}
.reservation-embed-widget{
  width:100%;
  min-height:520px;
  background:rgba(246,241,232,.72);
  border:1px solid var(--line);
  padding:18px;
  overflow:hidden;
}
.reservation-embed-widget iframe{
  width:100%;
  min-height:640px;
  border:0;
  display:block;
}
.reservation-placeholder{
  text-align:center;
  background:rgba(246,241,232,.72);
  border:1px solid var(--line);
  padding:56px 28px;
}
.reservation-placeholder h3{
  margin-bottom:16px;
}
.reservation-services{
  margin:32px auto 0;
  max-width:760px;
  text-align:center;
  color:var(--muted);
}
.reservation-services h3{
  color:var(--navy);
}


/* Immediately operational reservation form */
.reservation-live{
  background:var(--white);
}
.reservation-live-wrap{
  max-width:980px;
  margin:0 auto;
}
.reservation-plugin-wrap{
  width:100%;
}
.reservation-link-section{
  text-align:center;
}
.reservation-link-section .btn{
  margin-top:22px;
}
.reservation-page-intro{
  max-width:760px;
  margin:0 auto 46px;
  text-align:center;
}
.reservation-page-intro h2{
  margin-bottom:18px;
}
.reservation-page-contact{
  max-width:980px;
  margin:34px auto 0;
  padding:28px;
  border:1px solid var(--line);
  text-align:center;
}
.reservation-page-contact p{
  margin:0 0 8px;
  color:var(--muted);
}
.reservation-page-contact a{
  display:block;
  color:var(--navy);
  font-family:"Times New Roman",serif;
  font-size:clamp(28px,4vw,42px);
  letter-spacing:.08em;
}
.reservation-page-contact span{
  display:block;
  margin-top:6px;
  color:var(--muted);
}
.reservation-complete-page{
  background:var(--white);
}
.reservation-complete-card{
  max-width:760px;
  margin:0 auto;
  padding:56px 48px;
  border:1px solid var(--line);
  background:rgba(246,241,232,.72);
  text-align:center;
}
.reservation-complete-mark{
  width:72px;
  height:72px;
  margin:0 auto 24px;
  border:1px solid var(--gold);
  border-radius:50%;
  color:var(--gold);
  font-size:38px;
  line-height:70px;
}
.reservation-complete-card h2{
  margin-bottom:24px;
}
.reservation-complete-contact{
  margin:32px 0;
  padding:24px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.reservation-complete-contact span,
.reservation-complete-contact small{
  display:block;
  color:var(--muted);
}
.reservation-complete-contact a{
  display:block;
  color:var(--navy);
  font-family:"Times New Roman",serif;
  font-size:clamp(28px,4vw,40px);
  letter-spacing:.08em;
}
.reservation-complete-actions{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
}
@media (max-width:600px){
  .reservation-complete-card{
    padding:42px 24px;
  }
}
.gabel-live-reservation-form{
  background:rgba(246,241,232,.72);
  border:1px solid var(--line);
  padding:34px;
}
.live-slot-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}
.live-slot{
  display:block;
  cursor:pointer;
}
.live-slot input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.live-slot span{
  display:block;
  padding:14px 10px;
  text-align:center;
  border:1px solid var(--line);
  background:var(--white);
  color:var(--navy);
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
}
.live-slot input:checked + span{
  background:var(--navy);
  color:var(--white);
  border-color:var(--navy);
}
.reservation-notice{
  max-width:980px;
  margin:0 auto 20px;
  padding:16px 18px;
  border:1px solid var(--gold);
  background:#fff8e8;
  color:var(--navy);
  text-align:center;
}
.gabel-live-reservation-form button.btn{
  cursor:pointer;
  font-family:inherit;
}
@media (max-width:900px){
  .live-slot-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media (max-width:560px){
  .live-slot-grid{
    grid-template-columns:1fr;
  }
}


/* Uploaded uniform photo adjustment */
.card__image.photo-frame img[alt*="ネイビースーツ"]{
  object-position:center center;
}


/* Company page */
.page-hero{
  background:var(--navy);
  color:var(--white);
  padding:110px 7vw 90px;
  text-align:center;
}
.page-hero h1{
  color:var(--white);
  font-size:clamp(38px,5vw,64px);
  margin:0 0 18px;
}
.page-hero p{
  color:rgba(255,250,242,.86);
}
.company-page{
  background:var(--paper);
}
.company-page-inner{
  max-width:980px;
  margin:0 auto;
}
.company-message{
  text-align:center;
  max-width:760px;
  margin:0 auto 48px;
}
.company-table{
  width:100%;
  border-collapse:collapse;
  background:rgba(255,250,242,.62);
  border:1px solid var(--line);
}
.company-table th,
.company-table td{
  border-bottom:1px solid var(--line);
  padding:22px 24px;
  text-align:left;
  vertical-align:top;
}
.company-table tr:last-child th,
.company-table tr:last-child td{
  border-bottom:none;
}
.company-table th{
  width:210px;
  color:var(--navy);
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-weight:500;
  background:rgba(255,250,242,.52);
}
.company-actions{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:38px;
}
@media (max-width:700px){
  .company-table th,
  .company-table td{
    display:block;
    width:100%;
  }
  .company-table th{
    border-bottom:none;
    padding-bottom:6px;
  }
  .company-table td{
    padding-top:6px;
  }
}


/* COMPANY page history layout */
.company-history,
.company-today,
.company-profile{
  margin-top:78px;
}
.company-history > .eyebrow,
.company-history > h2,
.company-today,
.company-profile > .eyebrow,
.company-profile > h2{
  text-align:center;
}
.timeline{
  max-width:900px;
  margin:42px auto 0;
  position:relative;
}
.timeline:before{
  content:"";
  position:absolute;
  left:105px;
  top:0;
  bottom:0;
  width:1px;
  background:var(--line);
}
.timeline-item{
  display:grid;
  grid-template-columns:170px 1fr;
  gap:34px;
  position:relative;
  padding:0 0 44px;
}
.timeline-item:last-child{
  padding-bottom:0;
}
.timeline-year{
  font-family:"Times New Roman","Yu Mincho",serif;
  color:var(--gold);
  font-size:28px;
  letter-spacing:.08em;
  text-align:right;
  padding-right:34px;
  position:relative;
}
.timeline-year:after{
  content:"";
  position:absolute;
  right:-7px;
  top:16px;
  width:13px;
  height:13px;
  border-radius:50%;
  background:var(--gold);
}
.timeline-content{
  background:rgba(255,250,242,.58);
  border:1px solid var(--line);
  padding:28px;
}
.timeline-content h3{
  margin-top:0;
}
.company-today{
  max-width:820px;
  margin-left:auto;
  margin-right:auto;
  text-align:center;
  background:var(--white);
  border:1px solid var(--line);
  padding:42px 36px;
}
.company-profile{
  margin-top:78px;
}
@media (max-width:760px){
  .timeline:before{
    left:18px;
  }
  .timeline-item{
    grid-template-columns:1fr;
    gap:12px;
    padding-left:42px;
  }
  .timeline-year{
    text-align:left;
    padding-right:0;
    font-size:24px;
  }
  .timeline-year:after{
    left:-30px;
    right:auto;
  }
}
/* Google Maps address links */
.simple-company a,
.company-table td a[target="_blank"]{
  text-decoration:underline;
  text-decoration-color:var(--gold);
  text-underline-offset:4px;
}
