/* ===== Design Tokens ===== */
:root{
  --saffron:#E8772E;      /* インドのサフラン */
  --saffron-dark:#C85A1B;
  --peacock:#0E5A63;      /* ピーコックブルー */
  --peacock-dark:#093F46;
  --gold:#C9A227;
  --ink:#1B1A18;
  --ink-soft:#4A4742;
  --cream:#FBF7F0;
  --cream-2:#F3ECE0;
  --line:rgba(27,26,24,.12);
  --white:#ffffff;
  --radius:18px;
  --shadow:0 18px 50px -20px rgba(14,90,99,.30);
  --shadow-sm:0 8px 24px -12px rgba(27,26,24,.25);
  --maxw:1160px;
  --serif:"Noto Serif JP",serif;
  --sans:"Noto Sans JP",sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:78px}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(92%,var(--maxw));margin-inline:auto}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4em;
  padding:.95em 1.9em;border-radius:999px;font-weight:700;font-size:.95rem;
  cursor:pointer;border:none;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
  letter-spacing:.02em;white-space:nowrap;
}
.btn-primary{background:linear-gradient(135deg,var(--saffron),var(--saffron-dark));color:#fff;box-shadow:0 12px 28px -10px rgba(200,90,27,.6)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 36px -12px rgba(200,90,27,.7)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.55);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.22);transform:translateY(-3px)}
.btn-block{width:100%}

/* ===== Header ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(251,247,240,.0);transition:background .35s ease,box-shadow .35s ease,backdrop-filter .35s;
}
.site-header.scrolled{background:rgba(251,247,240,.92);backdrop-filter:blur(10px);box-shadow:0 4px 20px -12px rgba(0,0,0,.3)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:.65rem}
.brand-mark{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:#fff;overflow:hidden;
  display:grid;place-items:center;box-shadow:var(--shadow-sm);
}
.brand-mark img{width:100%;height:100%;object-fit:contain}
.brand-text{display:flex;flex-direction:column;line-height:1.2}
.brand-name{font-family:var(--serif);font-weight:900;font-size:1.05rem;letter-spacing:.04em;color:var(--ink)}
.brand-sub{font-size:.66rem;letter-spacing:.18em;color:var(--peacock);text-transform:uppercase}
.site-header:not(.scrolled) .brand-name{color:#fff}
.site-header:not(.scrolled) .brand-sub{color:rgba(255,255,255,.85)}

.nav{display:flex;align-items:center;gap:2rem}
.nav a{font-size:.9rem;font-weight:500;color:var(--ink);position:relative;transition:color .2s}
.site-header:not(.scrolled) .nav a{color:#fff}
.nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--saffron);transition:width .25s}
.nav a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:var(--saffron);color:#fff!important;padding:.55em 1.3em;border-radius:999px;box-shadow:0 8px 18px -8px rgba(200,90,27,.6)}
.nav-cta:hover{background:var(--saffron-dark);transform:translateY(-2px)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:2.5px;background:#fff;border-radius:2px;transition:.3s}
.site-header.scrolled .nav-toggle span{background:var(--ink)}

/* ===== Hero ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{
  position:absolute;inset:0;
  background:url("images/bg-taj.avif") center/cover no-repeat;
  transform:scale(1.08);animation:slowZoom 18s ease-out forwards;
}
@keyframes slowZoom{to{transform:scale(1)}}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(115deg,rgba(9,63,70,.88) 0%,rgba(14,90,99,.6) 45%,rgba(200,90,27,.35) 100%),
    linear-gradient(to top,rgba(9,63,70,.85),transparent 55%);
}
.hero-content{position:relative;z-index:2;padding:120px 0 90px}
.hero-eyebrow{
  display:inline-block;font-size:.8rem;letter-spacing:.16em;font-weight:500;
  padding:.5em 1.1em;border:1px solid rgba(255,255,255,.4);border-radius:999px;margin-bottom:1.6rem;
  background:rgba(255,255,255,.08);backdrop-filter:blur(4px);
}
.hero-title{
  font-family:var(--serif);font-weight:900;line-height:1.35;
  font-size:clamp(2rem,5.4vw,3.7rem);letter-spacing:.01em;
  text-shadow:0 4px 30px rgba(0,0,0,.35);
}
.hero-title .accent{color:#FFD27A;position:relative}
.hero-lead{margin-top:1.6rem;font-size:clamp(.98rem,2vw,1.15rem);max-width:40em;color:rgba(255,255,255,.92);font-weight:400}
.hero-actions{margin-top:2.4rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero-stats{margin-top:3.5rem;display:flex;gap:2.6rem;flex-wrap:wrap}
.stat{display:flex;flex-direction:column}
.stat-num{font-family:var(--serif);font-weight:900;font-size:2.4rem;line-height:1;color:#fff}
.stat-num small{font-size:.9rem;margin-left:.15em;color:#FFD27A}
.stat-label{font-size:.78rem;letter-spacing:.08em;color:rgba(255,255,255,.8);margin-top:.5rem}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;width:26px;height:42px;border:2px solid rgba(255,255,255,.6);border-radius:999px}
.scroll-cue span{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:4px;height:8px;background:#fff;border-radius:2px;animation:scrollDot 1.6s infinite}
@keyframes scrollDot{0%{opacity:0;top:8px}40%{opacity:1}80%{opacity:0;top:22px}100%{opacity:0}}

/* ===== Trusted ===== */
.trusted{background:var(--peacock-dark);color:#fff;padding:34px 0}
.trusted-label{text-align:center;font-size:.78rem;letter-spacing:.14em;color:rgba(255,255,255,.6);margin-bottom:1.1rem}
.trusted-logos{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem 2.2rem}
.trusted-logos li{font-family:var(--serif);font-weight:700;font-size:1.1rem;color:rgba(255,255,255,.85);letter-spacing:.05em}

/* ===== Section base ===== */
.section{padding:clamp(64px,9vw,120px) 0}
.section-eyebrow{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--saffron);font-weight:700;margin-bottom:.9rem}
.section-title{font-family:var(--serif);font-weight:900;font-size:clamp(1.6rem,3.6vw,2.5rem);line-height:1.45;color:var(--ink)}
.section-head{margin-bottom:3.4rem}
.section-head.center{text-align:center}
.section-head.center .section-eyebrow{display:block}
.section-head.light .section-title,.section-head.light .section-eyebrow{color:#fff}
.section-head.light .section-eyebrow{color:#FFD27A}

/* ===== About ===== */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.about-media{position:relative}
.about-media img{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/5;object-fit:cover}
.about-badge{
  position:absolute;right:-18px;bottom:-22px;background:#fff;border-radius:16px;
  padding:1rem 1.4rem;text-align:center;box-shadow:var(--shadow);border:2px solid var(--saffron);
}
.about-badge-num{display:block;font-family:var(--serif);font-weight:900;font-size:1.8rem;color:var(--saffron)}
.about-badge-text{font-size:.72rem;letter-spacing:.16em;color:var(--ink-soft)}
.about-text{color:var(--ink-soft);margin-bottom:1.1rem;font-size:1rem}
.strength-list{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:2rem}
.strength{padding:1.1rem 1.2rem;background:#fff;border-radius:14px;border-left:4px solid var(--peacock);box-shadow:var(--shadow-sm)}
.strength h3{font-size:.98rem;font-weight:700;color:var(--peacock-dark);margin-bottom:.3rem}
.strength p{font-size:.84rem;color:var(--ink-soft);line-height:1.7}

/* ===== Services ===== */
.services{background:linear-gradient(180deg,var(--cream) 0%,var(--cream-2) 100%)}
.service-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.service-card{
  position:relative;background:#fff;border-radius:var(--radius);padding:2.2rem 1.8rem 2rem;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;
  display:flex;flex-direction:column;
}
.service-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--saffron),var(--peacock));opacity:0;transition:opacity .3s}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.service-card:hover::before{opacity:1}
.service-no{position:absolute;top:1.1rem;right:1.4rem;font-family:"Cormorant Garamond",serif;font-size:3rem;font-weight:700;color:var(--cream-2);line-height:1}
.service-icon{font-size:2rem;margin-bottom:1rem}
.service-card h3{font-size:1.18rem;font-weight:700;color:var(--ink);margin-bottom:.8rem;line-height:1.5}
.service-card>p{font-size:.9rem;color:var(--ink-soft);line-height:1.8}
.service-tags{list-style:none;display:flex;flex-wrap:wrap;gap:.45rem;margin:1.1rem 0}
.service-tags li{font-size:.72rem;padding:.3em .8em;background:var(--cream-2);color:var(--peacock-dark);border-radius:999px;font-weight:500}
.service-proof{margin-top:auto;font-size:.78rem;color:var(--saffron-dark);font-weight:500;padding-top:1rem;border-top:1px dashed var(--line);line-height:1.6}
.service-card-cta{
  background:linear-gradient(140deg,var(--peacock),var(--peacock-dark));color:#fff;
  align-items:flex-start;justify-content:center;gap:1rem;border:none;
}
.service-card-cta h3{color:#fff;font-family:var(--serif)}
.service-card-cta p{color:rgba(255,255,255,.85);font-size:.9rem}
.service-card-cta .btn{margin-top:.4rem}

/* ===== Works ===== */
.works{position:relative;color:#fff;overflow:hidden}
.works-bg{position:absolute;inset:0;background:url("images/bg-taj.avif") center/cover fixed;}
.works-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(9,63,70,.95),rgba(27,26,24,.92))}
.works .container{position:relative;z-index:2}
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.work-item{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:14px;padding:1.7rem 1.5rem;backdrop-filter:blur(4px);transition:.3s;
}
.work-item:hover{background:rgba(255,255,255,.11);transform:translateY(-5px)}
.work-cat{display:inline-block;font-size:.7rem;letter-spacing:.1em;padding:.3em .8em;border-radius:999px;background:var(--saffron);color:#fff;font-weight:700;margin-bottom:.9rem}
.work-item h3{font-size:1.05rem;font-weight:700;margin-bottom:.5rem;line-height:1.5}
.work-item p{font-size:.85rem;color:rgba(255,255,255,.78);line-height:1.7}

/* ===== Flow ===== */
.flow{background:var(--cream)}
.flow-steps{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;counter-reset:none}
.flow-steps li{position:relative;text-align:center;padding:2rem 1.2rem;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.flow-no{
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;margin:0 auto 1rem;
  background:linear-gradient(135deg,var(--saffron),var(--peacock));color:#fff;
  font-family:var(--serif);font-weight:900;font-size:1.4rem;box-shadow:var(--shadow-sm);
}
.flow-steps h3{font-size:1.02rem;font-weight:700;margin-bottom:.4rem;color:var(--peacock-dark)}
.flow-steps p{font-size:.84rem;color:var(--ink-soft);line-height:1.7}
.flow-steps li:not(:last-child)::after{content:"→";position:absolute;right:-1rem;top:50%;transform:translateY(-50%);color:var(--saffron);font-size:1.3rem;font-weight:700;z-index:2}

/* ===== Contact ===== */
.contact{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-text{color:var(--ink-soft);margin:1.3rem 0 1.8rem;font-size:1rem}
.contact-info{list-style:none;display:flex;flex-direction:column;gap:.9rem}
.contact-info li{display:flex;align-items:center;gap:1rem;font-size:.92rem;color:var(--ink)}
.ci-label{flex-shrink:0;width:96px;font-size:.74rem;letter-spacing:.1em;color:#fff;background:var(--peacock);padding:.35em .7em;border-radius:6px;text-align:center;font-weight:700}
.contact-form{background:#fff;border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.6rem);box-shadow:var(--shadow);border:1px solid var(--line)}
.field{margin-bottom:1.2rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.field label{display:block;font-size:.85rem;font-weight:700;margin-bottom:.5rem;color:var(--ink)}
.req{font-size:.66rem;color:#fff;background:var(--saffron);padding:.15em .55em;border-radius:4px;margin-left:.4em;vertical-align:middle;font-weight:700}
.field input,.field select,.field textarea{
  width:100%;padding:.85em 1em;border:1.5px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--cream);transition:border .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--saffron);box-shadow:0 0 0 3px rgba(232,119,46,.15);background:#fff;
}
.field textarea{resize:vertical}
.check{display:flex;align-items:flex-start;gap:.6rem;font-size:.85rem;color:var(--ink-soft);margin-bottom:1.4rem;cursor:pointer}
.check input{width:18px;height:18px;margin-top:.15rem;accent-color:var(--saffron);flex-shrink:0}
.form-note{margin-top:1rem;font-size:.88rem;text-align:center;font-weight:500}
.form-note.ok{color:var(--peacock)}
.form-note.err{color:#c0392b}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#c0392b;box-shadow:0 0 0 3px rgba(192,57,43,.12)}

/* ===== Footer ===== */
.site-footer{background:var(--peacock-dark);color:#fff}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:46px 0;flex-wrap:wrap}
.footer-brand{display:flex;align-items:center;gap:.9rem}
.footer-brand .brand-name{color:#fff;font-size:1.1rem}
.footer-brand .brand-sub{color:rgba(255,255,255,.6)}
.footer-nav{display:flex;gap:1.8rem;flex-wrap:wrap}
.footer-nav a{font-size:.88rem;color:rgba(255,255,255,.82);transition:color .2s}
.footer-nav a:hover{color:#FFD27A}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:18px 0}
.footer-bottom p{font-size:.78rem;color:rgba(255,255,255,.55);text-align:center}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:980px){
  .service-cards{grid-template-columns:repeat(2,1fr)}
  .works-grid{grid-template-columns:repeat(2,1fr)}
  .flow-steps{grid-template-columns:repeat(2,1fr)}
  .flow-steps li:nth-child(2)::after{display:none}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .about-media{max-width:420px;margin-inline:auto}
}
@media(max-width:760px){
  .nav{
    position:fixed;top:72px;right:0;left:0;background:rgba(251,247,240,.98);backdrop-filter:blur(10px);
    flex-direction:column;gap:0;padding:1rem 0;transform:translateY(-130%);transition:transform .35s ease;
    box-shadow:0 18px 30px -16px rgba(0,0,0,.3);max-height:calc(100svh - 72px);overflow:auto;
  }
  .nav.open{transform:none}
  .nav a{width:100%;text-align:center;padding:.95rem 0;color:var(--ink)!important}
  .site-header:not(.scrolled) .nav a{color:var(--ink)!important}
  .nav-cta{border-radius:0;margin:.5rem 1.2rem 0;width:calc(100% - 2.4rem)}
  .nav-toggle{display:flex}
  .nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  .site-header.scrolled .nav-toggle span,.nav-toggle span{background:var(--ink)}
  .hero-stats{gap:1.6rem}
  .stat-num{font-size:1.9rem}
  .strength-list{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr;gap:0}
  .works-bg{background-attachment:scroll}
}
@media(max-width:540px){
  .service-cards,.works-grid,.flow-steps{grid-template-columns:1fr}
  .flow-steps li::after{display:none!important}
  .footer-inner{flex-direction:column;text-align:center}
}

/* ============================================================
   SUB-PAGE COMPONENTS
   ============================================================ */

/* Always-solid header for sub-pages */
.site-header.always-solid{background:rgba(251,247,240,.95);backdrop-filter:blur(10px);box-shadow:0 4px 20px -12px rgba(0,0,0,.3)}
.site-header.always-solid .brand-name{color:var(--ink)}
.site-header.always-solid .brand-sub{color:var(--peacock)}
.site-header.always-solid .nav a{color:var(--ink)}
.site-header.always-solid .nav-cta{color:#fff}
.site-header.always-solid .nav-toggle span{background:var(--ink)}

/* Page hero (sub-page banner) */
.page-hero{position:relative;padding:140px 0 60px;color:#fff;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background:url("images/bg-taj.avif") center/cover;transform:scale(1.05)}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(9,63,70,.92),rgba(14,90,99,.7) 60%,rgba(200,90,27,.45))}
.page-hero .container{position:relative;z-index:2}
.page-hero .en{font-family:"Cormorant Garamond",serif;font-size:1rem;letter-spacing:.3em;text-transform:uppercase;color:#FFD27A;display:block;margin-bottom:.5rem}
.page-hero h1{font-family:var(--serif);font-weight:900;font-size:clamp(1.8rem,4.4vw,2.9rem);line-height:1.4;text-shadow:0 4px 24px rgba(0,0,0,.3)}
.page-hero p.lead{margin-top:1rem;max-width:42em;color:rgba(255,255,255,.9)}

/* Breadcrumb */
.breadcrumb{background:var(--cream-2);border-bottom:1px solid var(--line)}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;padding:.9rem 0;font-size:.8rem;color:var(--ink-soft)}
.breadcrumb a{color:var(--peacock);font-weight:500}
.breadcrumb li:not(:last-child)::after{content:"/";margin-left:.5rem;color:var(--line)}

/* Generic content wrapper */
.page-section{padding:clamp(54px,7vw,90px) 0}
.prose{max-width:760px;margin-inline:auto}
.prose h2{font-family:var(--serif);font-size:1.5rem;color:var(--peacock-dark);margin:2.4rem 0 1rem;line-height:1.5}
.prose h3{font-size:1.1rem;color:var(--ink);margin:1.8rem 0 .6rem}
.prose p{color:var(--ink-soft);margin-bottom:1.1rem}
.prose ul{margin:0 0 1.2rem 1.2rem;color:var(--ink-soft)}
.prose li{margin-bottom:.5rem}
.lead-text{font-size:1.05rem;color:var(--ink)}

/* ===== Message (代表挨拶) ===== */
.message-grid{display:grid;grid-template-columns:300px 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.message-photo{position:sticky;top:100px}
.message-photo .photo-frame{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:linear-gradient(160deg,var(--peacock),var(--saffron));aspect-ratio:3/4;display:grid;place-items:center;color:#fff}
.message-photo .photo-frame span{font-family:var(--serif);font-size:3rem;opacity:.5}
.message-photo .name{margin-top:1.1rem;text-align:center}
.message-photo .name strong{display:block;font-family:var(--serif);font-size:1.2rem;color:var(--ink)}
.message-photo .name small{color:var(--ink-soft);font-size:.82rem}
.message-body h2{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2rem);color:var(--peacock-dark);line-height:1.5;margin-bottom:1.4rem}
.message-body p{color:var(--ink-soft);margin-bottom:1.2rem}
.message-sign{margin-top:2rem;font-family:var(--serif);font-size:1.1rem;color:var(--ink);text-align:right}
.message-sign small{display:block;font-family:var(--sans);font-size:.8rem;color:var(--ink-soft)}

/* ===== Timeline (沿革) ===== */
.timeline{list-style:none;max-width:760px;margin-inline:auto;position:relative;padding-left:2rem}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--saffron),var(--peacock))}
.timeline-item{position:relative;padding:0 0 2rem 1.4rem}
.timeline-item::before{content:"";position:absolute;left:-2rem;top:4px;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--saffron);box-shadow:0 0 0 4px var(--cream)}
.timeline-item .yr{font-family:var(--serif);font-weight:900;color:var(--saffron-dark);font-size:1.05rem}
.timeline-item p{color:var(--ink-soft);margin-top:.2rem;font-size:.94rem}

/* ===== Company table (会社概要) ===== */
.info-table{width:100%;border-collapse:collapse;max-width:760px;margin-inline:auto;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.info-table th,.info-table td{text-align:left;padding:1.1rem 1.4rem;border-bottom:1px solid var(--line);vertical-align:top;font-size:.94rem}
.info-table th{width:30%;background:var(--cream-2);color:var(--peacock-dark);font-weight:700;white-space:nowrap}
.info-table td{color:var(--ink-soft)}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:none}

/* ===== Value cards (理念など) ===== */
.value-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.4rem}
.value-card{background:#fff;border-radius:var(--radius);padding:2rem 1.6rem;box-shadow:var(--shadow-sm);border-top:4px solid var(--saffron);text-align:center}
.value-card .vc-icon{font-size:2rem;margin-bottom:.8rem}
.value-card h3{font-family:var(--serif);font-size:1.15rem;color:var(--peacock-dark);margin-bottom:.6rem}
.value-card p{font-size:.88rem;color:var(--ink-soft);line-height:1.8}

/* ===== Service detail blocks ===== */
.service-detail{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3.5rem);align-items:center;padding:clamp(2.4rem,5vw,4rem) 0;border-bottom:1px solid var(--line)}
.service-detail:nth-child(even) .sd-media{order:2}
.service-detail .sd-media{background:linear-gradient(150deg,var(--peacock),var(--saffron));border-radius:var(--radius);aspect-ratio:16/11;display:grid;place-items:center;color:rgba(255,255,255,.85);box-shadow:var(--shadow);position:relative;overflow:hidden}
.sd-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.sd-media::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,rgba(14,90,99,.55),rgba(200,90,27,.25))}
.sd-media{display:block!important}
.sd-media .sd-no{position:absolute;z-index:2;top:.6rem;left:1.3rem;font-family:"Cormorant Garamond",serif;font-size:4.5rem;font-weight:700;line-height:1;color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.5)}
.sd-media .sd-emoji{position:absolute;z-index:2;font-size:3rem;bottom:1.4rem;right:1.6rem;opacity:.95;filter:drop-shadow(0 3px 8px rgba(0,0,0,.4))}

/* 代表写真 (message) */
.message-photo .photo-frame{position:relative}
.message-photo .photo-frame img{width:100%;height:100%;object-fit:cover;display:block}

/* Home service cards with photo header */
.service-card.has-media{padding:0}
.sc-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.sc-media img{width:100%;height:100%;object-fit:cover}
.sc-media::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(14,90,99,.30),rgba(27,26,24,.45))}
.sc-media .service-no{position:absolute;z-index:2;top:.3rem;left:1.1rem;right:auto;color:#fff;text-shadow:0 3px 14px rgba(0,0,0,.55)}
.sc-body{padding:1.9rem 1.7rem 1.9rem;display:flex;flex-direction:column;flex:1}

/* Larger value cards (会社概要 理念) */
.value-card{padding:3rem 2.2rem}
.value-card h3{font-size:1.55rem;margin-bottom:1rem}
.value-card p{font-size:1rem}

/* LINE QR (contact) */
.line-qr{margin:0 auto 2rem;max-width:230px;text-align:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:1rem;box-shadow:var(--shadow-sm)}
.line-qr img{width:100%;display:block;border-radius:8px}
.line-qr p{margin-top:.6rem;font-size:.78rem;color:var(--ink-soft);font-weight:700}
.service-detail .sd-body .label{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--saffron);font-weight:700}
.service-detail .sd-body h2{font-family:var(--serif);font-size:clamp(1.4rem,3vw,1.9rem);color:var(--ink);margin:.5rem 0 1rem;line-height:1.5}
.service-detail .sd-body p{color:var(--ink-soft);margin-bottom:1rem}
.sd-list{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.sd-list li{font-size:.78rem;padding:.35em .9em;background:var(--cream-2);color:var(--peacock-dark);border-radius:999px;font-weight:500}
.sd-proof{font-size:.84rem;color:var(--saffron-dark);font-weight:600;border-left:3px solid var(--saffron);padding-left:.9rem}

/* ===== Blog ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.blog-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.blog-thumb{aspect-ratio:16/10;background:linear-gradient(140deg,var(--peacock),var(--saffron));display:grid;place-items:center;color:rgba(255,255,255,.7);font-size:2.4rem}
.blog-card .bc-body{padding:1.4rem 1.4rem 1.6rem;display:flex;flex-direction:column;flex:1}
.blog-meta{display:flex;gap:.7rem;align-items:center;font-size:.74rem;color:var(--ink-soft);margin-bottom:.6rem}
.blog-cat{background:var(--peacock);color:#fff;padding:.2em .7em;border-radius:999px;font-weight:700;letter-spacing:.04em}
.blog-card h3{font-size:1.05rem;font-weight:700;line-height:1.55;color:var(--ink);margin-bottom:.6rem}
.blog-card p{font-size:.85rem;color:var(--ink-soft);line-height:1.7;flex:1}
.blog-more{margin-top:1rem;font-size:.85rem;font-weight:700;color:var(--saffron-dark)}
.sidebar-widget{background:#fff;border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm);border:1px solid var(--line);margin-bottom:1.4rem}
.sidebar-widget h3{font-family:var(--serif);font-size:1.05rem;color:var(--peacock-dark);margin-bottom:1rem;padding-bottom:.6rem;border-bottom:2px solid var(--cream-2)}
.sidebar-widget ul{list-style:none}
.sidebar-widget li{padding:.5rem 0;border-bottom:1px dashed var(--line);font-size:.86rem}
.sidebar-widget li:last-child{border-bottom:none}
.sidebar-widget a{color:var(--ink);transition:color .2s}
.sidebar-widget a:hover{color:var(--saffron-dark)}
.blog-layout{display:grid;grid-template-columns:1fr 300px;gap:2.5rem;align-items:start}

/* Article */
.article{max-width:760px;margin-inline:auto}
.article-head{margin-bottom:2rem}
.article-head .blog-meta{margin-bottom:1rem}
.article-head h1{font-family:var(--serif);font-size:clamp(1.5rem,3.5vw,2.2rem);line-height:1.5;color:var(--ink)}
.article-hero{aspect-ratio:16/8;border-radius:var(--radius);background:linear-gradient(140deg,var(--peacock),var(--saffron));margin-bottom:2rem;display:grid;place-items:center;color:rgba(255,255,255,.6);font-size:3rem}
.article-body p{color:var(--ink-soft);margin-bottom:1.2rem;line-height:1.95}
.article-body h2{font-family:var(--serif);font-size:1.4rem;color:var(--peacock-dark);margin:2.2rem 0 .9rem}
.article-body blockquote{border-left:4px solid var(--saffron);background:var(--cream-2);padding:1rem 1.4rem;border-radius:0 10px 10px 0;color:var(--ink);margin:1.4rem 0;font-size:.95rem}

/* ===== FAQ ===== */
.faq-list{max-width:820px;margin-inline:auto}
.faq-item{background:#fff;border-radius:14px;box-shadow:var(--shadow-sm);border:1px solid var(--line);margin-bottom:1rem;overflow:hidden}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.3rem 1.5rem;cursor:pointer;font-weight:700;color:var(--ink);font-size:.98rem;list-style:none}
.faq-q::-webkit-details-marker{display:none}
.faq-q .q-mark{flex-shrink:0;color:var(--saffron);font-family:var(--serif);font-weight:900;font-size:1.2rem}
.faq-q .plus{flex-shrink:0;width:22px;height:22px;position:relative;transition:transform .3s}
.faq-q .plus::before,.faq-q .plus::after{content:"";position:absolute;background:var(--peacock);border-radius:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-q .plus::before{width:14px;height:2px}
.faq-q .plus::after{width:2px;height:14px;transition:transform .3s}
.faq-item.open .plus::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--ink-soft)}
.faq-item.open .faq-a{max-height:400px}
.faq-a-inner{padding:0 1.5rem 1.4rem;font-size:.9rem;line-height:1.85}

/* ===== CTA band ===== */
.cta-band{background:linear-gradient(135deg,var(--peacock),var(--peacock-dark));color:#fff;text-align:center;padding:clamp(3rem,6vw,5rem) 0}
.cta-band h2{font-family:var(--serif);font-size:clamp(1.5rem,3.4vw,2.2rem);margin-bottom:1rem;line-height:1.5}
.cta-band p{color:rgba(255,255,255,.85);max-width:38em;margin:0 auto 2rem}

/* ===== Contact (連絡先ブロック・フォーム無し) ===== */
.contact-card{
  max-width:680px;margin:0 auto;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid var(--line);overflow:hidden;
}
.contact-card-head{
  background:linear-gradient(135deg,var(--peacock),var(--peacock-dark));color:#fff;
  padding:2.2rem 2rem;text-align:center;
}
.contact-card-head .cc-mark{width:60px;height:60px;border-radius:16px;margin:0 auto 1rem;background:linear-gradient(135deg,var(--saffron),var(--gold));display:grid;place-items:center;font-family:var(--serif);font-weight:900;font-size:1.5rem;box-shadow:var(--shadow-sm)}
.contact-card-head h2{font-family:var(--serif);font-size:1.4rem;margin-bottom:.3rem}
.contact-card-head p{color:rgba(255,255,255,.85);font-size:.9rem}
.contact-card-body{padding:2rem clamp(1.4rem,4vw,2.4rem)}

/* SNS buttons (主役) */
.sns-label{text-align:center;font-size:.82rem;letter-spacing:.1em;color:var(--ink-soft);margin-bottom:1rem;font-weight:700}
.sns-buttons{display:flex;flex-direction:column;gap:.85rem;margin-bottom:2rem}
.sns-btn{
  display:flex;align-items:center;gap:1rem;padding:1rem 1.3rem;border-radius:14px;
  font-weight:700;color:#fff;transition:transform .25s ease,box-shadow .25s ease;box-shadow:var(--shadow-sm);
}
.sns-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.sns-btn .sns-ico{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.22);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0}
.sns-btn .sns-tx{display:flex;flex-direction:column;line-height:1.3}
.sns-btn .sns-tx small{font-weight:400;font-size:.74rem;opacity:.85}
.sns-btn .sns-arrow{margin-left:auto;font-size:1.1rem;opacity:.8}
.sns-line{background:#06C755}
.sns-ig{background:linear-gradient(135deg,#feda75,#d62976 50%,#4f5bd5)}
.sns-x{background:#111}
.sns-mail{background:var(--saffron)}

/* Contact info rows */
.contact-rows{border-top:1px solid var(--line);padding-top:1.6rem}
.contact-row{display:flex;gap:1rem;padding:.8rem 0;border-bottom:1px dashed var(--line);align-items:baseline}
.contact-row:last-child{border-bottom:none}
.contact-row .cr-label{flex-shrink:0;width:88px;font-size:.76rem;color:#fff;background:var(--peacock);padding:.3em .6em;border-radius:6px;text-align:center;font-weight:700}
.contact-row .cr-value{color:var(--ink);font-size:.94rem}
.contact-row .cr-value a{color:var(--peacock);font-weight:700}
.contact-row .cr-value small{display:block;color:var(--saffron-dark);font-size:.74rem}

/* Contact — 3-column dark band (連絡先 / LINE / 営業時間) */
.contact-dark{background:var(--peacock-dark);color:#fff;padding:clamp(2.6rem,6vw,4.5rem) 0}
.contact-cols{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.cc-col .cc-h{font-family:var(--serif);font-weight:900;color:#fff;font-size:1.5rem;margin-bottom:1.5rem}
.cc-info{list-style:none;display:flex;flex-direction:column;gap:1rem}
.cc-info li{color:rgba(255,255,255,.8);font-size:.92rem;line-height:1.75}
.cc-info li strong{color:#fff;font-size:1.02rem}
.cc-info a{color:#fff;border-bottom:1px solid rgba(255,255,255,.25)}
.cc-info a:hover{border-color:var(--saffron)}
.cc-ic{display:inline-block;width:1.5em;color:var(--saffron)}
.cc-sns{margin-top:1.8rem;display:flex;gap:.8rem}
.cc-sns-btn{width:46px;height:46px;border-radius:50%;background:#fff;color:#111;display:grid;place-items:center;font-size:1.15rem;transition:transform .25s}
.cc-sns-btn:hover{transform:translateY(-3px)}
.cc-line-col{text-align:center}
.cc-line-col .cc-h{text-align:left}
.cc-line-col .line-qr{margin:0 auto 1.2rem}
.cc-hours{list-style:none;display:flex;flex-direction:column;gap:1.1rem}
.cc-hours li{display:flex;flex-direction:column;gap:.2rem;border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:1rem}
.cc-hours li:last-child{border-bottom:none}
.cc-hours li span{color:rgba(255,255,255,.55);font-size:.85rem;letter-spacing:.04em}
.cc-hours li strong{color:#fff;font-size:1.15rem;font-weight:700}
.cc-note{color:rgba(255,255,255,.5);font-size:.78rem;margin-top:1.2rem}

/* 準備中 (coming soon) */
.coming-soon{max-width:560px;margin:0 auto;text-align:center;padding:clamp(2rem,5vw,3rem) 0}
.coming-soon .cs-badge{display:inline-block;font-family:"Cormorant Garamond",serif;font-size:1rem;letter-spacing:.3em;text-transform:uppercase;color:var(--saffron);font-weight:700;margin-bottom:1.2rem}
.coming-soon h2{font-family:var(--serif);font-size:clamp(1.8rem,5vw,2.6rem);color:var(--peacock-dark);margin-bottom:1.2rem}
.coming-soon p{color:var(--ink-soft);font-size:1rem;margin-bottom:2rem}
.coming-soon .cs-icon{font-size:3.4rem;margin-bottom:1rem}

/* Map placeholder */
.map-placeholder{
  max-width:680px;margin:2rem auto 0;aspect-ratio:16/7;border-radius:var(--radius);
  background:repeating-linear-gradient(45deg,var(--cream-2),var(--cream-2) 14px,#fff 14px,#fff 28px);
  border:1px dashed var(--line);display:grid;place-items:center;text-align:center;color:var(--ink-soft);
}
.map-placeholder span{font-size:.85rem;background:rgba(255,255,255,.85);padding:.6em 1.1em;border-radius:8px}

/* ===== Responsive (sub-pages) ===== */
@media(max-width:980px){
  .message-grid{grid-template-columns:1fr}
  .message-photo{position:static;max-width:280px;margin-inline:auto}
  .value-cards{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .blog-layout{grid-template-columns:1fr}
  .service-detail{grid-template-columns:1fr}
  .service-detail .sd-media{order:-1!important;max-width:480px}
}
@media(max-width:760px){
  .info-table th{width:38%;font-size:.86rem}
  .info-table th,.info-table td{padding:.9rem 1rem}
}
@media(max-width:540px){
  .blog-grid{grid-template-columns:1fr}
}
