/* ========================================
   Salon Web Design — Light Luxury Refined
   明るく洗練された、エステサロン向け信頼サイト
======================================== */

:root{
  /* ── Light palette ── */
  --white:#fff;
  --cream:#fdfcfa;
  --light:#f7f3ee;
  --light-soft:#f0ebe4;
  --warm:#e8e0d6;
  --greige:#d4cac0;

  /* ── Dark (footer only — warm brown) ── */
  --dark:#443c34;
  --dark-soft:#4e453c;
  --dark-line:rgba(255,255,255,.1);

  /* ── Accent ── */
  --accent:#b07f58;
  --accent-hover:#9a6f4c;
  --accent-light:rgba(176,127,88,.1);
  --accent-glow:rgba(176,127,88,.06);

  /* ── Text ── */
  --text:#38332e;
  --text-sub:#887e74;
  --text-light:#a8a098;
  --text-on-dark:#ede8e2;
  --text-on-dark-sub:rgba(237,232,226,.5);

  /* ── Shared ── */
  --radius:12px;
  --radius-lg:16px;
  --shadow:0 2px 16px rgba(56,51,46,.05);
  --shadow-md:0 8px 32px rgba(56,51,46,.07);
  --shadow-lg:0 16px 48px rgba(56,51,46,.1);
  --container:1100px;
  --transition:.35s cubic-bezier(.25,.46,.45,.94);

  /* ── Wireframe compat ── */
  --bg:#fcfaf8;--bg-soft:#f6f1ec;--sub:#6c625b;
  --line:#e8ddd3;--accent-dark:#9f745a;
  --wf-placeholder:#e0dbd6;--wf-placeholder-text:#a09890;--wf-border:#d5cec6;
}

/* ---- Reset & Base ---- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'DM Sans',-apple-system,BlinkMacSystemFont,"Hiragino Sans",sans-serif;
  color:var(--text);
  background:var(--cream);
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,p{margin-top:0}
p{color:inherit}
.container{width:min(var(--container),calc(100% - 48px));margin:0 auto}


/* ================================================================
   HEADER
================================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background var(--transition), border-color var(--transition), box-shadow var(--transition);
  background:rgba(253,252,250,.6);
  backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(253,252,250,.96);
  backdrop-filter:blur(20px);
  border-bottom-color:rgba(212,202,192,.35);
  box-shadow:0 1px 16px rgba(56,51,46,.04);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  min-height:76px;gap:20px;
}
.logo{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-weight:400;font-size:1.2rem;
  letter-spacing:.2em;
  color:var(--text);
}
.nav{display:flex;gap:28px;font-size:.84rem;color:var(--text-sub);letter-spacing:.06em;font-weight:400}
.nav a{transition:color var(--transition);position:relative}
.nav a::after{
  content:"";position:absolute;bottom:-2px;left:0;right:0;
  height:1px;background:var(--accent);
  transform:scaleX(0);transform-origin:right;
  transition:transform var(--transition);
}
.nav a:hover::after,.nav a.is-current::after{transform:scaleX(1);transform-origin:left}
.nav a:hover,.nav a.is-current{color:var(--text)}
.header-cta{
  display:inline-flex;align-items:center;justify-content:center;
  height:40px;padding:0 22px;border-radius:6px;
  background:var(--accent);color:var(--white);
  font-size:.8rem;font-weight:600;letter-spacing:.08em;
  transition:all var(--transition);
}
.header-cta:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px rgba(176,127,88,.2)}
.menu-toggle{
  display:none;background:none;border:none;
  color:var(--text);cursor:pointer;font-size:1.3rem;
}
.mobile-menu{
  display:none;
  background:var(--cream);
  border-top:1px solid var(--warm);
  padding:16px 20px;
}
.mobile-menu.is-open{display:grid;gap:12px}
.mobile-menu a{padding:8px 0;font-size:1rem;color:var(--text-sub)}
.mobile-menu a:hover{color:var(--text)}


/* ================================================================
   EYEBROW — Decorative with accent line
================================================================ */
.eyebrow{
  font-size:.72rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--accent);
  display:flex;align-items:center;gap:12px;
  margin-bottom:12px;
}
.eyebrow-line{
  display:inline-block;width:28px;height:1px;
  background:var(--accent);
}


/* ================================================================
   HERO — Light luxury split with photo frame
================================================================ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;
  background:var(--cream);
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 50% at 70% 45%, rgba(176,127,88,.05) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 10% 80%, rgba(212,202,192,.2) 0%, transparent 50%);
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;
  align-items:center;
  min-height:100vh;
  padding:100px 0 60px;
}
.hero-content{max-width:500px}
.hero-eyebrow{
  font-size:.68rem;letter-spacing:.35em;
  color:var(--accent);text-transform:uppercase;
  display:flex;align-items:center;gap:14px;
  margin-bottom:24px;
}
.hero-eyebrow-line{
  display:inline-block;width:32px;height:1px;
  background:linear-gradient(90deg, var(--accent), transparent);
}
.hero h1{
  font-family:'Zen Old Mincho','Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(2rem,3.8vw,2.9rem);
  line-height:1.6;
  color:var(--text);
  letter-spacing:.06em;
  margin-bottom:22px;
}
.hero-text{
  font-size:.9rem;
  color:var(--text-sub);
  line-height:2;
  margin-bottom:36px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn-hero{
  display:inline-flex;align-items:center;justify-content:center;
  height:52px;padding:0 34px;
  font-size:.86rem;font-weight:600;letter-spacing:.06em;
  border-radius:8px;transition:all var(--transition);
}
.btn-hero-primary{
  background:var(--accent);color:var(--white);border:none;
  box-shadow:0 4px 20px rgba(176,127,88,.2);
}
.btn-hero-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 8px 28px rgba(176,127,88,.25)}
.btn-hero-secondary{
  background:transparent;color:var(--text);
  border:1px solid var(--greige);
}
.btn-hero-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

/* Hero photo frame — layered design */
.hero-visual{
  position:relative;
  display:flex;justify-content:center;align-items:center;
}
.hero-photo-frame{
  position:relative;
  width:100%;max-width:420px;
  aspect-ratio:3/4;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.hero-photo{
  width:100%;height:100%;
  background:linear-gradient(160deg, var(--light-soft) 0%, var(--warm) 100%);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-light);font-size:.78rem;letter-spacing:.3em;
  text-transform:uppercase;
}
.hero-visual-accent{
  position:absolute;
  top:-16px;right:-16px;
  width:70%;height:80%;
  border:1px solid var(--greige);
  border-radius:var(--radius-lg);
  z-index:-1;
}

.hero-scroll{
  position:absolute;bottom:32px;right:40px;z-index:3;
  font-size:.58rem;letter-spacing:.35em;color:var(--text-light);
  writing-mode:vertical-rl;
}
.hero-scroll span{display:block}
.hero-scroll::after{
  content:"";display:block;
  width:1px;height:36px;
  background:linear-gradient(180deg, var(--greige), transparent);
  margin:12px auto 0;
}


/* ================================================================
   SECTIONS — Shared
================================================================ */
.section{padding:100px 0}
.section-white{background:var(--white);color:var(--text)}
.section-cream{background:var(--cream);color:var(--text)}
.section-light{background:var(--light);color:var(--text)}
.section-light-soft{background:var(--light-soft);color:var(--text)}
.section-warm{background:var(--cream);color:var(--text);
  border-top:1px solid rgba(212,202,192,.3);
  border-bottom:1px solid rgba(212,202,192,.3);
}

/* backward compat */
.section-dark{background:var(--dark);color:var(--text-on-dark)}
.section-dark-soft{background:var(--dark-soft);color:var(--text-on-dark)}
.section-light-warm{background:var(--light-soft);color:var(--text)}

.section-heading{
  max-width:640px;margin-bottom:52px;
}
.section-heading.center{text-align:center;margin-left:auto;margin-right:auto}
.section-heading h2{
  font-family:'Zen Old Mincho','Cormorant Garamond',serif;
  font-weight:500;
  font-size:clamp(1.5rem,2.8vw,2.2rem);
  line-height:1.5;
  letter-spacing:.05em;
  color:var(--text);
  margin-bottom:10px;
}
.section-heading p{
  font-size:.9rem;line-height:1.9;
  color:var(--text-sub);
}


/* ================================================================
   SERVICES — Cards with top accent line
================================================================ */
.service-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.service-card{
  position:relative;
  background:var(--white);
  border:1px solid rgba(212,202,192,.4);
  border-radius:var(--radius);
  padding:36px 28px 32px;
  box-shadow:var(--shadow);
  transition:transform var(--transition),box-shadow var(--transition);
  overflow:hidden;
}
.service-card-accent{
  position:absolute;top:0;left:28px;right:28px;
  height:2px;
  background:linear-gradient(90deg, var(--accent), rgba(176,127,88,.2));
  border-radius:0 0 2px 2px;
}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.service-card-num{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.1rem;font-weight:300;letter-spacing:.1em;
  color:var(--accent);margin-bottom:18px;
}
.service-card h3{
  font-size:1.05rem;font-weight:600;
  color:var(--text);margin-bottom:10px;
  letter-spacing:.02em;
}
.service-card p{
  font-size:.86rem;line-height:1.9;
  color:var(--text-sub);margin-bottom:18px;
}
.service-card .tags{display:flex;flex-wrap:wrap;gap:6px}
.service-card .tag{
  font-size:.68rem;padding:5px 11px;border-radius:4px;
  background:var(--accent-light);color:var(--accent);
  letter-spacing:.03em;font-weight:500;
}
.service-more{
  text-align:center;margin-top:40px;
}
.service-more a{
  font-size:.84rem;color:var(--accent);letter-spacing:.1em;
  border-bottom:1px solid rgba(176,127,88,.3);
  padding-bottom:3px;transition:all var(--transition);
}
.service-more a:hover{border-color:var(--accent);letter-spacing:.13em}


/* ================================================================
   WORKS — Elevated cards
================================================================ */
.works-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.works-card{
  display:block;
  background:var(--white);
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(212,202,192,.35);
  box-shadow:var(--shadow);
  transition:transform var(--transition),box-shadow var(--transition);
}
.works-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-lg);
}
.works-photo{
  aspect-ratio:4/3;
  background:linear-gradient(135deg, var(--light-soft) 0%, var(--warm) 100%);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-light);font-size:.78rem;letter-spacing:.15em;
}
.works-photo img{width:100%;height:100%;object-fit:cover;display:block}
.works-card-body{padding:20px 24px}
.works-card-body h3{
  font-size:.95rem;font-weight:600;margin-bottom:4px;
  color:var(--text);
}
.works-card-body p{
  font-size:.8rem;color:var(--text-sub);margin-bottom:0;
}
.works-actions{text-align:center;margin-top:40px}


/* ================================================================
   REASONS — Refined cards
================================================================ */
.reason-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:22px;
}
.reason-card{
  background:var(--white);
  border:1px solid rgba(212,202,192,.4);
  border-radius:var(--radius);
  padding:30px 28px;
  display:flex;gap:20px;align-items:flex-start;
  box-shadow:var(--shadow);
  transition:transform var(--transition),box-shadow var(--transition);
}
.reason-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}
.reason-num{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:2rem;font-weight:300;
  color:var(--accent);
  line-height:1;flex-shrink:0;min-width:40px;
  opacity:.7;
}
.reason-card h3{
  font-size:.98rem;font-weight:600;
  color:var(--text);margin-bottom:8px;
}
.reason-card p{
  font-size:.84rem;line-height:1.9;
  color:var(--text-sub);margin-bottom:0;
}


/* ================================================================
   CTA — Warm card on cream
================================================================ */
.cta-section{
  padding:100px 0;
  background:var(--light);
  text-align:center;
}
.cta-inner{
  background:var(--white);
  border:1px solid rgba(212,202,192,.4);
  border-radius:var(--radius-lg);
  padding:64px 48px;
  box-shadow:var(--shadow-md);
  max-width:720px;
  margin:0 auto;
}
.cta-section .eyebrow{justify-content:center}
.cta-section h2{
  font-family:'Zen Old Mincho','Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(1.4rem,2.6vw,2rem);
  color:var(--text);
  line-height:1.6;letter-spacing:.05em;
  margin-bottom:16px;
}
.cta-section p{
  font-size:.9rem;color:var(--text-sub);
  line-height:1.95;margin-bottom:32px;
  max-width:520px;margin-left:auto;margin-right:auto;
}
.cta-actions{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;
}
.btn-cta{
  display:inline-flex;align-items:center;justify-content:center;
  height:52px;padding:0 36px;border-radius:8px;
  font-size:.88rem;font-weight:600;letter-spacing:.06em;
  transition:all var(--transition);
}
.btn-cta-primary{
  background:var(--accent);color:var(--white);border:none;
  box-shadow:0 4px 20px rgba(176,127,88,.2);
}
.btn-cta-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 8px 28px rgba(176,127,88,.25)}
.btn-cta-secondary{
  background:transparent;color:var(--text);
  border:1px solid var(--greige);
}
.btn-cta-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}


/* ================================================================
   FOOTER
================================================================ */
.site-footer{
  background:#4a4238;
  padding:56px 0 0;
  color:var(--text-on-dark);
}
.footer-grid{
  display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:28px;
}
.footer-grid h3{
  font-size:.85rem;font-weight:600;letter-spacing:.06em;
  margin-bottom:14px;color:var(--text-on-dark);
}
.footer-grid .logo{margin-bottom:8px;color:var(--text-on-dark)}
.footer-grid p{font-size:.85rem;color:var(--text-on-dark-sub);line-height:1.7}
.footer-grid li{margin-bottom:10px}
.footer-grid a{
  font-size:.88rem;color:var(--text-on-dark-sub);
  transition:color var(--transition);
}
.footer-grid a:hover{color:var(--text-on-dark)}
.footer-bottom{
  border-top:1px solid var(--dark-line);
  margin-top:36px;padding:20px 0 32px;
}
.footer-bottom p{margin:0;font-size:.82rem;color:var(--text-on-dark-sub)}


/* ================================================================
   SHARED BUTTONS
================================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:48px;padding:0 24px;border-radius:8px;
  border:1px solid transparent;font-weight:600;
  transition:all var(--transition);font-size:.88rem;letter-spacing:.04em;
}
.btn-primary{
  background:var(--accent);color:var(--white);
  box-shadow:0 4px 16px rgba(176,127,88,.15);
}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 8px 24px rgba(176,127,88,.2)}
.btn-secondary{
  background:transparent;border-color:var(--greige);
  color:var(--text);
}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}


/* ================================================================
   PHOTO PLACEHOLDER & IMAGE FALLBACK
   - 画像未設定時はプレースホルダーが表示される
   - img タグに差し替えると object-fit: cover で自動トリミング
================================================================ */
.photo-placeholder{
  background:var(--light-soft);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-light);font-size:.78rem;letter-spacing:.12em;
}
.wf-placeholder{
  background:var(--wf-placeholder,#e0dbd6);
  border:2px dashed var(--wf-border,#d5cec6);
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  color:var(--wf-placeholder-text,#a09890);font-size:.85rem;
  text-align:center;padding:16px;
}

/* --- ヒーロー画像: imgタグ差し替え対応 --- */
.hero-photo img{
  width:100%;height:100%;object-fit:cover;display:block;
}

/* --- プロフィール画像: imgタグ差し替え対応 --- */
.profile-grid img{
  width:100%;height:100%;object-fit:cover;display:block;
  border-radius:var(--radius);
  aspect-ratio:3/4;
}

/* --- QRコード画像: imgタグ差し替え対応 --- */
.contact-method-card img{
  display:block;max-width:100%;height:auto;border-radius:var(--radius-sm,6px);
}

.pc-br{display:inline}
.sp-br{display:none}
@media(max-width:640px){.pc-br{display:none}.sp-br{display:inline}}


/* ================================================================
   ANIMATION
================================================================ */
.fade-up{
  opacity:0;transform:translateY(24px);
  transition:opacity .8s ease, transform .8s ease;
}
.fade-up.is-visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.15s}
.delay-2{transition-delay:.3s}
.delay-3{transition-delay:.45s}


/* ================================================================
   RESPONSIVE
================================================================ */
@media (max-width:960px){
  .nav,.header-cta,.desktop-only{display:none}
  .menu-toggle{display:block}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-content{max-width:100%}
  .hero-visual{display:none}
  .service-cards{grid-template-columns:1fr}
  .works-grid{grid-template-columns:1fr 1fr}
  .reason-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .section{padding:80px 0}
  .cta-inner{padding:48px 32px}

  /* backward compat */
  .hero-grid-old,
  .service-overview-grid,
  .card-grid,
  .service-main-grid,
  .capability-grid,
  .reassure-grid,
  .contact-methods-grid,
  .profile-grid,.values-grid{
    grid-template-columns:1fr;
  }
  .works-detail-card{grid-template-columns:1fr}
}

@media (max-width:640px){
  .container{width:min(var(--container),calc(100% - 36px))}
  .header-inner{min-height:64px}
  .hero{min-height:auto}
  .hero-grid{min-height:auto;padding:110px 0 48px}
  .hero-content{padding:0}
  .hero h1{font-size:1.65rem}
  .hero-text br{display:none}
  .hero-scroll{display:none}
  .hero-actions{flex-direction:column;gap:12px}
  .btn-hero,.btn-cta{width:100%;justify-content:center}
  .service-cards{gap:16px}
  .works-grid{grid-template-columns:1fr}
  .works-detail-card .wf-placeholder{aspect-ratio:3/2;min-height:180px}
  .works-detail-body{padding:20px 20px 24px}
  .cta-actions{flex-direction:column;gap:12px}
  .cta-actions .btn-cta{width:100%}
  .cta-inner{padding:40px 24px}
  .section{padding:64px 0}
  .section-heading{margin-bottom:36px}

  /* backward compat */
  .btn{width:100%;min-height:46px;font-size:.95rem}
  .contact-form{padding:24px 20px}
  .contact-method-card{padding:24px 20px}
  .reassure-grid{grid-template-columns:1fr;gap:10px}
  .reassure-box{padding:28px 20px}
  .reassure-box h2{font-size:1.15rem;margin-bottom:20px}
  .reassure-item{padding:12px 14px}
  .reassure-item p{font-size:.84rem}
  .reassure-note{font-size:.86rem}
  .contact-methods-grid{gap:16px}
}


/* ================================================================
   BACKWARD COMPAT — Other pages
================================================================ */
.section-soft{background:var(--bg-soft)}
.info-card{
  background:var(--white);border:1px solid rgba(212,202,192,.5);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;
}
.card-grid{display:grid;gap:18px;grid-template-columns:repeat(3,1fr)}

.service-overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.service-overview-card{
  background:var(--white);border:1px solid rgba(212,202,192,.5);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;
}
.service-overview-card h3{margin-top:16px;font-size:1.2rem}
.service-overview-card .more-link{
  display:inline-block;margin-top:12px;color:var(--accent);font-weight:600;font-size:.95rem;
}

.page-hero{
  padding:140px 0 48px;background:var(--light-soft);text-align:center;
  color:var(--text);
}
.page-hero+.section{padding-top:48px}
.page-hero h1{margin-bottom:12px;max-width:none;
  font-family:'Zen Old Mincho','Cormorant Garamond',serif;font-weight:500;
  font-size:clamp(1.6rem,3vw,2.4rem);color:var(--text);letter-spacing:.05em;
}
.page-hero-text{max-width:640px;margin:0 auto;font-size:1rem;color:var(--text-sub)}
.page-hero .eyebrow{color:var(--accent);justify-content:center}

.page-light{background:var(--cream)}
.page-light .logo{color:var(--text)}
.page-light .nav a{color:var(--text-sub)}
.page-light .nav a:hover,.page-light .nav a.is-current{color:var(--text)}
.page-light .header-cta{background:var(--accent)}
.page-light .menu-toggle{color:var(--text)}
.page-light .mobile-menu{background:var(--cream);border-top-color:var(--warm)}
.page-light .mobile-menu a{color:var(--text-sub)}

.section-link{display:inline-block;margin-top:20px;color:var(--accent);font-weight:600;font-size:.95rem}
.section-link:hover{text-decoration:underline}
.center-actions{text-align:center;margin-top:28px}
.filter-bar{display:flex;justify-content:center;gap:10px;margin-bottom:36px;flex-wrap:wrap}
.filter-btn{padding:8px 18px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--sub);font-size:.92rem;font-weight:600;cursor:pointer;transition:.25s ease}
.filter-btn:hover{border-color:var(--accent);color:var(--accent)}
.filter-btn.is-active{background:var(--accent);color:var(--white);border-color:var(--accent)}

.works-note{
  text-align:right;margin-top:24px;
  font-size:.75rem;color:var(--text-light);letter-spacing:.03em;
}
.works-detail-grid{display:grid;gap:28px}
.works-detail-card{display:grid;grid-template-columns:.42fr .58fr;background:var(--white);border:1px solid rgba(212,202,192,.5);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.works-detail-card .wf-placeholder{border-radius:0;align-self:stretch}
.works-detail-card .works-detail-body{align-self:stretch}
.works-detail-card img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.works-detail-card.is-hidden{display:none}
.works-detail-body{padding:28px 32px 32px}
.works-detail-body h3{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:8px;letter-spacing:.02em}
.works-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.works-tag{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:600;background:var(--light-soft);color:var(--text-sub)}
.works-tag.tag-hp{background:rgba(176,127,88,.12);color:var(--accent)}
.works-tag.tag-lp{background:rgba(107,142,160,.15);color:#4a7a8c}
.works-meta{display:grid;grid-template-columns:auto 1fr;gap:4px 16px;margin:12px 0 16px;font-size:.88rem}
.works-meta dt{font-weight:700;color:var(--text)}
.works-meta dd{margin:0;color:var(--text-sub)}
.works-points{margin-top:16px;padding-top:16px;border-top:1px solid rgba(212,202,192,.4)}
.works-points h4{font-size:.92rem;margin:0 0 8px;color:var(--accent)}
.works-points ul{display:grid;gap:6px}
.works-points li{font-size:.86rem;line-height:1.8;color:var(--text-sub);padding-left:1.2em;position:relative}
.works-points li::before{content:"\2713";position:absolute;left:0;color:var(--accent);font-weight:700}

.works-sample-link{margin-top:20px;padding-top:20px;border-top:1px solid rgba(212,202,192,.4)}
.works-sample-link a{display:inline-flex;align-items:center;font-size:.88rem;font-weight:600;color:var(--accent);letter-spacing:.04em;transition:all var(--transition)}
.works-sample-link a:hover{color:var(--accent-hover);letter-spacing:.06em}

.service-main-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.service-main-card{background:var(--white);border:1px solid rgba(212,202,192,.5);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px 28px}
.service-main-icon{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:var(--light-soft);color:var(--accent);font-weight:800;font-size:1rem;letter-spacing:.04em;margin-bottom:16px}
.service-main-card h3{font-size:1.2rem;margin-bottom:10px}
.service-main-desc{margin-bottom:16px}
.service-main-tags{margin-bottom:10px}

.diff-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:16px}
.diff-table{width:100%;border-collapse:collapse;font-size:.92rem;background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.diff-table thead tr{background:var(--light-soft)}
.diff-table th{padding:14px 20px;text-align:left;font-weight:700;color:var(--text);border-bottom:2px solid rgba(212,202,192,.4);white-space:nowrap}
.diff-table th:first-child{width:120px}
.diff-table td{padding:14px 20px;border-bottom:1px solid rgba(212,202,192,.3);color:var(--text-sub);vertical-align:top}
.diff-table tbody tr:last-child td{border-bottom:none}
.diff-label{font-weight:700;color:var(--text);white-space:nowrap}
.diff-note{font-size:.88rem;color:var(--text-sub);text-align:center}

.capability-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.capability-card{background:var(--white);border:1px solid rgba(212,202,192,.5);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
.capability-num{font-size:.78rem;font-weight:800;letter-spacing:.1em;color:var(--accent);margin-bottom:10px}
.capability-card h3{font-size:1rem;margin-bottom:8px}

.flow-steps{display:grid;gap:0;max-width:720px;margin:0 auto}
.flow-step{display:grid;grid-template-columns:56px 1fr;gap:0;position:relative}
.flow-step:not(:last-child)::after{content:"";position:absolute;left:27px;top:52px;bottom:0;width:2px;background:rgba(212,202,192,.4)}
.flow-step-num{display:flex;align-items:flex-start;justify-content:center;padding-top:4px}
.flow-step-num::before{content:attr(class);display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--accent);color:var(--white);font-weight:800;font-size:.85rem;flex-shrink:0}
.flow-step-body{background:var(--white);border:1px solid rgba(212,202,192,.5);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px;margin-bottom:16px;margin-left:4px}
.flow-step-body h3{font-size:1rem;margin-bottom:6px}

.reassure-box{background:var(--white);border:1px solid rgba(212,202,192,.5);border-radius:var(--radius);box-shadow:var(--shadow);padding:40px;text-align:center}
.reassure-box h2{margin-bottom:28px}
.reassure-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px;text-align:left}
.reassure-item{display:flex;align-items:flex-start;gap:10px;background:var(--light-soft);border-radius:12px;padding:14px 16px}
.reassure-check{color:var(--accent);font-weight:800;font-size:1.1rem;flex-shrink:0;line-height:1.6}
.reassure-item p{margin:0;font-size:.88rem;color:var(--text);line-height:1.6}
.reassure-note{font-size:.92rem;color:var(--text-sub);margin:0;line-height:1.8}

.profile-grid{display:grid;grid-template-columns:.4fr .6fr;gap:40px;align-items:start}
.profile-name{font-size:1.3rem;font-weight:800;margin-bottom:4px;color:var(--text)}
.profile-title{font-size:.95rem;color:var(--accent);margin-bottom:16px}
.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.value-card{background:var(--white);border:1px solid rgba(212,202,192,.5);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
.value-num{font-size:.78rem;font-weight:800;letter-spacing:.1em;color:var(--accent);margin-bottom:10px}
.value-card h3{font-size:1rem;margin-bottom:8px}

.contact-methods-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.contact-method-card{background:var(--white);border:1px solid rgba(212,202,192,.5);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px;text-align:center}
.contact-method-card:first-child{border-color:rgba(176,127,88,.3)}
.contact-method-card h3{font-size:1.1rem;margin-bottom:10px}
.contact-method-icon{font-size:2rem;margin-bottom:14px;line-height:1}
.contact-form-wrap{max-width:680px;margin:8px auto 0}
.contact-form{background:var(--white);border:1px solid rgba(212,202,192,.5);border-radius:var(--radius);box-shadow:var(--shadow);padding:40px 40px 32px}
.form-field{display:grid;gap:8px;margin-bottom:24px}
.form-field:last-of-type{margin-bottom:28px}
.form-label{font-size:.9rem;font-weight:700;color:var(--text)}
.form-label .required{color:var(--accent);margin-left:4px;font-size:.8rem}
.form-input,.form-textarea{width:100%;padding:12px 16px;border:1px solid rgba(212,202,192,.5);border-radius:8px;font-size:1rem;background:var(--cream);color:var(--text);font-family:inherit;transition:border-color .2s ease,outline .2s ease}
.form-input:focus,.form-textarea:focus{outline:2px solid var(--accent);border-color:transparent}
.form-textarea{min-height:140px;resize:vertical}
.form-note{font-size:.88rem;color:var(--text-sub);margin-bottom:20px}

.service-usecase-list{display:grid;gap:8px}
.service-usecase-list li{font-size:.9rem;color:var(--text-sub);padding-left:1.2em;position:relative}
.service-usecase-list li::before{content:"・";position:absolute;left:0;color:var(--accent)}


/* ================================================================
   WHY CARDS — Profile page vertical layout
================================================================ */
.why-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.why-card{
  background:var(--white);
  border:1px solid rgba(212,202,192,.4);
  border-radius:var(--radius);
  padding:32px 30px 28px;
  box-shadow:var(--shadow);
  transition:transform var(--transition),box-shadow var(--transition);
  display:flex;
  flex-direction:column;
}
.why-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}
.why-num{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:.82rem;font-weight:300;letter-spacing:.15em;
  color:var(--accent);
  margin-bottom:14px;
  opacity:.7;
}
.why-card h3{
  font-size:1.02rem;font-weight:600;
  color:var(--text);
  margin-bottom:12px;
  letter-spacing:.02em;
  line-height:1.5;
}
.why-card p{
  font-size:.86rem;line-height:1.95;
  color:var(--text-sub);
  margin-bottom:0;
}


/* ================================================================
   BACKWARD COMPAT RESPONSIVE OVERRIDES
   (must come after backward compat definitions)
================================================================ */
@media (max-width:960px){
  .works-detail-card{grid-template-columns:1fr}
  .service-main-grid{grid-template-columns:1fr}
  .capability-grid{grid-template-columns:1fr}
  .reassure-grid{grid-template-columns:1fr}
  .contact-methods-grid{grid-template-columns:1fr}
  .profile-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
}


/* ================================================================
   DESIGN GALLERY — TCD style template cards
================================================================ */
.filter-wrap{display:grid;gap:18px;margin-bottom:24px}
.filter-group{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.filter-label{font-size:.78rem;font-weight:600;color:var(--text-sub);letter-spacing:.08em;min-width:44px}
.filter-wrap .filter-bar{justify-content:flex-start;margin-bottom:0;flex-wrap:wrap;gap:8px}
.filter-wrap .filter-btn{padding:7px 16px;font-size:.82rem}

.templates-note{font-size:.82rem;color:var(--text-sub);text-align:center;margin:0 0 36px;letter-spacing:.02em}

.templates-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px 28px}

/* --- Card: TCD style (header bar + screenshot + footer text) --- */
.template-card{
  display:flex;flex-direction:column;
  background:var(--white);
  border-radius:0;
  overflow:hidden;
  box-shadow:0 2px 16px rgba(56,51,46,.08);
  transition:transform var(--transition),box-shadow var(--transition);
  text-decoration:none;color:inherit;
}
.template-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(56,51,46,.14)}
.template-card.is-hidden{display:none}

/* --- Header bar: name + badge --- */
.template-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 20px 13px;
  background:var(--cream);
  border-bottom:1px solid rgba(212,202,192,.3);
}
.template-name{
  font-family:'DM Sans',sans-serif;
  font-size:.95rem;font-weight:700;
  color:var(--text);margin:0;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.template-badge{
  display:inline-block;padding:3px 10px;
  border-radius:4px;font-size:.64rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
}
.template-badge.tag-hp{background:rgba(176,127,88,.15);color:var(--accent)}
.template-badge.tag-lp{background:rgba(107,142,160,.18);color:#4a7a8c}

/* --- Thumbnail: screenshot preview --- */
.template-thumb{
  position:relative;aspect-ratio:16/10;overflow:hidden;
  background:var(--light-soft);
}
.template-thumb img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
  display:block;transition:transform .6s cubic-bezier(.25,.46,.45,.94);
}
.template-card:hover .template-thumb img{transform:scale(1.05)}

.template-placeholder{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.template-placeholder::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,transparent 0 20px,rgba(255,255,255,.06) 20px 22px);
}
.template-placeholder-name{
  position:relative;z-index:1;
  font-family:'DM Sans',sans-serif;
  font-size:1.3rem;font-weight:600;
  letter-spacing:.06em;
  text-align:center;padding:0 16px;
  text-shadow:0 1px 4px rgba(0,0,0,.1);
}

.template-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.45);
  display:flex;align-items:center;justify-content:center;
  color:var(--white);font-size:.82rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;
  opacity:0;transition:opacity var(--transition);
}
.template-card:hover .template-overlay{opacity:1}

/* --- Footer: description --- */
.template-body{padding:16px 20px 18px}
.template-meta{display:none}
.template-num{display:none}
.template-status{display:none}
.template-desc{
  font-size:.86rem;color:var(--text-sub);
  margin:0;line-height:1.6;text-align:center;
}

.templates-empty{
  text-align:center;font-size:.9rem;
  color:var(--text-sub);padding:48px 20px;
}

@media(max-width:960px){
  .templates-grid{grid-template-columns:repeat(2,1fr);gap:24px 20px}
  .filter-group{align-items:flex-start;flex-direction:column;gap:8px}
  .filter-label{min-width:auto}
}
@media(max-width:640px){
  .templates-grid{grid-template-columns:1fr;gap:20px}
  .template-placeholder-name{font-size:1.1rem}
  .template-header{padding:12px 16px 11px}
  .template-name{font-size:.85rem}
}
