/*!
 * Theme Name: 國清尚之建築設計事務所
 * Description: WordPress theme for 國清尚之建築設計事務所 — built from v4 mockup
 * Version: 1.0.0
 * Author: World Link Co., Ltd.
 * Text Domain: kunikiyo
 */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;background:#ffffff;}
body{
  font-family:'Yu Gothic Medium','YuGothic','Yu Gothic','Hiragino Sans','Noto Sans JP',sans-serif;
  background:#ffffff;
  color:#1a1a1a;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  /* Perimeter white frame — page bg shows around the content */
  padding:18px;
}
@media (max-width:768px){ body{ padding:10px; } }
:root{
  --bg:#ffffff;
  --white:#ffffff;
  --ink:#1a1a1a;
  --mid:#5c5c5c;
  --muted:#9c9c9c;
  --rule:rgba(26,26,26,.09);
  --ink2:#2a2a2a;
  --serif:'Yu Gothic Medium','YuGothic','Yu Gothic','Hiragino Sans','Noto Sans JP',sans-serif;
  --mono:'DM Mono',monospace;
  --max:1160px;
}

/* ── Nav ── */
nav{
  position:fixed;top:18px;left:18px;right:18px;z-index:200;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.1rem 2.5rem;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(12px);
  border-bottom:.5px solid var(--rule);
  transition:background .4s;
}
@media (max-width:768px){ nav{ top:10px;left:10px;right:10px;padding:.85rem 1rem; } }
nav.solid{
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(16px);
  border-bottom:.5px solid var(--rule);
}
.logo{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;
  color:var(--ink);text-decoration:none;
  transition:color .4s;
}
/* Logo image (custom logo) — works for both <img> and inline SVG */
.logo img,
.custom-logo,
.custom-logo-link img,
.custom-logo-link svg{
  display:block;
  height:32px;
  width:auto;
  max-width:200px;
  fill:var(--ink) !important;
  color:var(--ink) !important;
}
/* When SVG Support inlines the SVG, force fill on every path/shape */
.logo svg path,
.logo svg rect,
.logo svg polygon,
.logo svg circle,
.custom-logo path,
.custom-logo rect,
.custom-logo polygon,
.custom-logo circle{
  fill:var(--ink) !important;
}
@media (max-width:768px){
  .logo img,
  .custom-logo,
  .custom-logo-link img,
  .custom-logo-link svg{
    height:26px;
    max-width:160px;
  }
}
nav.solid .logo{ text-shadow:none; }
nav.solid .logo{ color:var(--ink); }
.nav-links{display:flex;gap:2.5rem;list-style:none;}
.nav-links a{
  font-size:.7rem;letter-spacing:.08em;font-weight:400;
  color:var(--mid);text-decoration:none;
  transition:color .2s;
}
.nav-links a:hover{ color:var(--ink); }
nav.solid .nav-links a{ text-shadow:none !important; }
nav.solid .nav-links a{ color:var(--mid); }
.nav-links a:hover{ color:var(--white); }
nav.solid .nav-links a:hover{ color:var(--ink); }
.nav-btn{
  font-size:.65rem;letter-spacing:.08em;font-weight:400;
  color:var(--ink);
  border:.5px solid rgba(26,26,26,.25);
  padding:.45rem 1.15rem;border-radius:2px;
  text-decoration:none;transition:all .2s;
  background:transparent;
}
.nav-btn:hover{ background:var(--ink);color:var(--white); }
nav.solid .nav-btn{
  color:var(--ink);
  border-color:rgba(26,26,26,.2);
  background:transparent;
}
.nav-btn:hover{ background:rgba(255,255,255,.15); }
nav.solid .nav-btn:hover{ background:var(--ink);color:var(--white); }

/* ── Hero — split layout: text + image side by side, centered ── */
.hero{
  position:relative;
  min-height:calc(100vh - 36px);
  background:#ffffff;
  display:flex;align-items:center;justify-content:center;
  padding:7rem 3rem 4rem;
}
@media (max-width:1024px){ .hero{ padding:6rem 2rem 3rem; } }
@media (max-width:768px){
  .hero{
    min-height:calc(100vh - 20px);       /* body has 10px padding × 2 on mobile */
    min-height:calc(100dvh - 20px);      /* modern: accounts for browser chrome */
    padding:5rem 1.5rem;                 /* symmetric top/bottom for true center */
  }
}

.hero-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:3rem;
  width:100%;
}
.hero-inner > .hero-content{ width:100%;align-items:center;text-align:center; }
.hero-inner > .hero-photo-wrap{ width:100%; }
@media (max-width:900px){
  .hero-inner{ gap:2rem; }
}

/* Image side — half width, centered, contained */
.hero-photo-wrap{
  display:flex;align-items:center;justify-content:center;
  order:1;
  width:100%;
}
.hero-photo-wrap img{
  display:block;
  width:605px;
  max-width:90%;
  aspect-ratio:1200/720;
  object-fit:cover;
  object-position:center center;
  height:auto;
  /* taller frame — emphasizes verticality and presence */
  filter:saturate(.82) contrast(1.02);
}
@media (max-width:900px){
  .hero-photo-wrap img{ width:90%; }
}

/* Text side */
.hero-content{
  order:2;
  display:flex;flex-direction:column;align-items:center;
  gap:1rem;
  text-align:center;
}

.hero-left{ width:100%;display:flex;flex-direction:column;align-items:center;text-align:center; }
.hero-eyebrow{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;
  color:var(--muted);
  margin-bottom:1.5rem;
  display:flex;align-items:center;justify-content:center;gap:.75rem;
}
.hero-eyebrow::before{
  content:'';display:block;
  width:24px;height:.5px;
  background:var(--muted);flex-shrink:0;
}

.hero-title-wrap{
  width:100%;
  text-align:center;
  margin-bottom:1rem;
}
.hero-title{
  display:inline-block;
  font-family:var(--serif);
  font-size:clamp(1.4rem,4.1vw,2.4rem);
  font-weight:500;line-height:1.55;letter-spacing:.12em;
  color:var(--ink);
  margin:0;
  white-space:nowrap;
}
@media (max-width:768px){
  .hero-title{
    white-space:normal;
    text-align:center;
    letter-spacing:.08em;
  }
}
.hero-sub{
  font-size:.66rem;letter-spacing:.1em;
  color:var(--muted);
  font-family:var(--mono);
  margin-top:1.25rem;
  padding-top:1.25rem;
  border-top:.5px solid var(--rule);
  width:100%;max-width:300px;
  text-align:center;
}
.hero-right{
  display:flex;flex-direction:column;align-items:center;gap:.55rem;
  margin-top:1.5rem;
  width:100%;max-width:300px;
}

.hero-meta-row{
  display:flex;align-items:center;gap:.6rem;
  font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;
  color:var(--muted);
}
.hero-cta{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;
  color:var(--ink);text-decoration:none;
  border-bottom:.5px solid var(--ink);
  padding-bottom:.2rem;margin-top:.85rem;
  transition:gap .2s;
}
.hero-cta:hover{ gap:.85rem; }
.hero-cta::after{content:'→';}

/* ── Scroll indicator ── */
.scroll-hint{
  position:absolute;bottom:1.75rem;left:50%;transform:translateX(-50%);
  z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
}
.scroll-line{
  width:.5px;height:36px;
  background:linear-gradient(to bottom,transparent,rgba(26,26,26,.3));
}
.scroll-txt{
  font-family:var(--mono);font-size:.52rem;letter-spacing:.12em;
  color:rgba(26,26,26,.35);
}

/* ── Sections ── */
.sec{padding:7rem 2.5rem;}
.sec-inner{max-width:var(--max);margin:0 auto;}
.sec-hdr{
  display:flex;align-items:baseline;gap:1.5rem;
  padding-bottom:.8rem;border-bottom:.5px solid var(--rule);
  margin-bottom:4rem;
}
.sec-num{font-family:var(--mono);font-size:.58rem;letter-spacing:.1em;color:var(--muted);}
.sec-title{font-family:var(--serif);font-size:clamp(1.25rem,3vw,1.6rem);font-weight:300;letter-spacing:.03em;}
.sec-en{font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;color:var(--muted);margin-left:auto;}
hr.rule{border:none;border-top:.5px solid var(--rule);margin:0;}

/* ── Philosophy strip ── */

/* ── Concept ── */
.concept-sec{background:var(--bg);}
.concept-layout{display:flex;flex-direction:column;gap:3.5rem;max-width:920px;margin:0 auto;}
.concept-anchor{
  font-family:var(--serif);
  font-size:clamp(1.05rem,2.4vw,1.9rem);
  font-weight:300;line-height:1.7;letter-spacing:.04em;
  color:var(--ink);text-align:center;display:block;max-width:780px;margin:0 auto 0;padding:1rem 0;
}
.concept-anchor .kw{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.9rem;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;
  color:var(--mid);margin-bottom:1.6rem;
  background:none;padding:0;
}
.concept-anchor .kw::before,
.concept-anchor .kw::after{
  content:'';display:block;
  width:28px;height:.5px;
  background:var(--muted);
  flex-shrink:0;
}
.concept-lead-label{
  display:block;
  font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;
  color:var(--muted);margin-bottom:1.2rem;
}
.concept-lead{
  font-family:var(--serif);
  font-size:clamp(1.2rem,2vw,1.6rem);
  font-weight:300;
  line-height:1.7;
  letter-spacing:.04em;
  color:var(--ink);
  padding-bottom:1.75rem;
  margin-bottom:1.5rem !important;
  border-bottom:.5px solid rgba(26,26,26,.12);
}
@media (max-width:768px){ .concept-lead{ font-size:1.15rem; } }
.concept-body p{
  font-size:.87rem;color:var(--mid);line-height:2.15;
  margin-bottom:1.6rem;
}
.concept-body p:last-child{margin:0;}
.concept-body .em{
  font-family:var(--serif);font-size:1rem;font-weight:300;
  color:var(--ink);line-height:1.8;display:block;
  border-left:1.5px solid var(--ink);padding-left:1.25rem;
  margin:2rem 0;
}

/* ── About ── */
.about-sec{background:var(--bg);}
.about-layout{display:grid;grid-template-columns:234px 1fr;gap:5rem;align-items:start;}
.about-visual{position:sticky;top:8rem;}
.about-photo{
  aspect-ratio:3/4;border-radius:2px;overflow:hidden;
  background:#c8c4be;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.about-photo-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center 22%;
  filter:saturate(.85) contrast(1.02);
  display:block;
}

.about-photo::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,#c4beb6 0%,#a8a29a 100%);
}
.about-photo-lbl{
  font-family:var(--mono);font-size:.55rem;letter-spacing:.1em;
  color:rgba(255,255,255,.35);z-index:1;position:relative;
}
.about-name{
  font-family:var(--serif);font-size:1.8rem;font-weight:300;
  letter-spacing:.04em;margin-bottom:.2rem;margin-top:3rem;
}
.about-name-en{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;
  color:var(--muted);display:block;margin-bottom:1.25rem;
}
.tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.75rem;}
.tag{
  font-family:var(--mono);font-size:.58rem;letter-spacing:.04em;
  padding:.25rem .7rem;border:.5px solid var(--rule);border-radius:2px;color:var(--mid);
}
.greeting-box{
  background:var(--white);border-radius:3px;padding:1.75rem 2rem;
  border-left:1.5px solid var(--ink2);margin-bottom:2rem;
}
.greeting-lbl{
  font-family:var(--mono);font-size:.56rem;letter-spacing:.1em;
  color:var(--muted);margin-bottom:1.6rem;
}
.greeting-body{
  font-size:.83rem;color:var(--mid);line-height:2.1;
}
.greeting-body p{margin-bottom:1.1rem;}
.greeting-body p:last-child{margin:0;}
.career-wrap{}
.career-lbl{
  font-family:var(--mono);font-size:.56rem;letter-spacing:.1em;
  color:var(--muted);margin-bottom:.85rem;
}
.career-row{
  display:grid;grid-template-columns:56px 1fr;gap:1rem;
  padding:.6rem 0;border-bottom:.5px solid var(--rule);
  font-size:.79rem;
}
.career-row:last-child{border:none;}
.career-yr{
  font-family:var(--mono);font-size:.66rem;color:var(--muted);
  padding-top:.1rem;
}

/* ── Column / Works ── */
.col-sec{background:var(--bg);}
/* Full-bleed grid — image-first like yoshirotten */
.col-grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2.5rem 1.5rem;
  max-width:1100px;
  margin:0 auto;
}
.col-card{
  display:block;text-decoration:none;
  position:relative;
  background:transparent;
}
.col-card:hover .col-overlay{opacity:1;}
.col-card:hover .col-arrow-btn{transform:translateX(4px);}
.col-thumb-wrap{
  aspect-ratio:3/2;
  overflow:hidden;
  position:relative;
}
.col-thumb-wrap::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(20,20,20,.28);
  pointer-events:none;
  z-index:1;
}
.col-thumb-bg{
  width:100%;height:100%;
  position:absolute;inset:0;
  transition:transform .5s ease;
}
.col-card:hover .col-thumb-bg{ transform:scale(1.03); }
.bg1{background:linear-gradient(145deg,#2a3028,#1c211b);}
.bg2{background:linear-gradient(145deg,#282e35,#1b2028);}
.bg3{background:linear-gradient(145deg,#2e2a35,#211b28);}
.bg4{background:linear-gradient(145deg,#35302a,#28221b);}
.bg5{background:linear-gradient(145deg,#2a3530,#1b2820);}
/* Grid lines in thumb */
.col-thumb-bg::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:24px 24px;
}
.col-overlay{
  position:absolute;inset:0;
  background:rgba(20,20,20,.55);
  opacity:0;transition:opacity .3s;
  display:flex;align-items:center;justify-content:center;
}
.col-overlay-txt{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;
  color:rgba(255,255,255,.7);
}
.col-info{
  padding:1.75rem 0 0;
  background:transparent;
}
.col-cat{
  font-family:var(--mono);font-size:.54rem;letter-spacing:.08em;
  color:var(--muted);margin-bottom:.95rem;
}
.col-title-sm{
  font-size:.78rem;font-weight:500;line-height:1.55;color:var(--ink);
  margin-bottom:.3rem;
}
.col-excerpt{
  font-size:.75rem;color:var(--mid);line-height:1.75;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.col-foot{
  display:flex;justify-content:flex-end;align-items:center;
  margin-top:.6rem;
}
.col-date{font-family:var(--mono);font-size:.54rem;color:var(--muted);}
.col-arrow-btn{
  font-size:.78rem;color:var(--muted);
  transition:transform .2s,color .2s;
}
.col-card:hover .col-arrow-btn{color:var(--ink);}
.col-more{
  text-align:center;padding:2.5rem 0 .5rem;
}

/* ── Contact ── */
.contact-sec{background:var(--bg);}
.contact-inner{max-width:680px;margin:0 auto;}
.contact-lead{
  font-family:var(--serif);font-size:1.4rem;font-weight:300;
  line-height:1.75;letter-spacing:.03em;
  text-align:center;margin-bottom:.8rem;
}
.contact-sub{
  font-size:.8rem;color:var(--mid);line-height:1.95;
  text-align:center;margin-bottom:2.5rem;
}
.form-box{
  background:var(--white);border-radius:3px;padding:2.25rem;
  border:.5px solid var(--rule);
}
.form-row{margin-bottom:1.25rem;}
.form-label{
  display:block;font-size:.68rem;letter-spacing:.05em;
  color:var(--mid);margin-bottom:.45rem;
}
.form-label .req{
  font-family:var(--mono);font-size:.56rem;
  color:var(--ink);margin-left:.3rem;opacity:.5;
}
.form-input{
  width:100%;padding:.65rem .9rem;
  border:.5px solid var(--rule);border-radius:2px;
  background:var(--bg);
  font-family:'Noto Sans JP',sans-serif;font-size:.82rem;color:var(--ink);
  outline:none;transition:border-color .2s,background .2s;
}
.form-input:focus{border-color:var(--ink);background:var(--white);}
select.form-input{cursor:pointer;}
textarea.form-input{min-height:100px;resize:vertical;}
.form-btn{
  width:100%;padding:.9rem;
  background:var(--ink);color:var(--white);
  font-family:'Noto Sans JP',sans-serif;font-size:.78rem;letter-spacing:.07em;
  border:none;border-radius:2px;cursor:pointer;transition:opacity .2s;
}
.form-btn:hover{opacity:.8;}
.form-note{
  font-family:var(--mono);font-size:.58rem;color:var(--muted);
  text-align:center;margin-top:.9rem;letter-spacing:.04em;
}

/* ── Footer ── */
footer{background:var(--ink);padding:2.25rem 2.5rem;}
.footer-in{
  max-width:var(--max);margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1.5rem;
}
.footer-logo{
  font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;
  color:rgba(255,255,255,.38);
}
.footer-links{display:flex;gap:1.75rem;}
.footer-links a{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.06em;
  color:rgba(255,255,255,.3);text-decoration:none;transition:color .2s;
}
.footer-links a:hover{color:rgba(255,255,255,.7);}
.footer-copy{
  font-family:var(--mono);font-size:.56rem;letter-spacing:.05em;
  color:rgba(255,255,255,.18);
}

/* ── Phase badge ── */
.phase-badge{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:100;
  background:rgba(26,26,26,.85);backdrop-filter:blur(8px);
  border-radius:2px;padding:.45rem .9rem;
  display:flex;flex-direction:column;gap:.15rem;
}
.pb-sub{font-family:var(--mono);font-size:.5rem;letter-spacing:.1em;color:rgba(255,255,255,.28);}
.pb-main{font-family:var(--mono);font-size:.6rem;letter-spacing:.06em;color:rgba(180,220,200,.85);}

/* ── Reveal ── */
.rv{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease;}
.rv.in{opacity:1;transform:none;}

/* ── Utility: PC-only line break ── */
.pc-only{display:inline;}
@media (max-width:768px){
  .pc-only{display:none;}
}

/* ── Mobile hamburger button (hidden on desktop) ── */
.nav-toggle{
  display:none;
  width:36px;height:36px;
  background:transparent;border:none;
  cursor:pointer;
  padding:0;margin-left:auto;
  position:relative;
  z-index:301;
}
.nav-toggle-line{
  display:block;
  position:absolute;left:6px;right:6px;
  height:1px;background:var(--ink);
  transition:transform .3s ease, opacity .2s ease, top .3s ease;
}
.nav-toggle-line:nth-child(1){top:12px;}
.nav-toggle-line:nth-child(2){top:18px;}
.nav-toggle-line:nth-child(3){top:24px;}
.nav-toggle[aria-expanded="true"] .nav-toggle-line:nth-child(1){top:18px;transform:rotate(45deg);}
.nav-toggle[aria-expanded="true"] .nav-toggle-line:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] .nav-toggle-line:nth-child(3){top:18px;transform:rotate(-45deg);}

/* ── Mobile menu drawer (hidden on desktop) ── */
.mobile-menu{
  display:none;
}
.mobile-menu-links{list-style:none;padding:0;margin:0;}

/* ── Responsive ── */
@media(max-width:768px){
  /* Hide desktop nav components */
  .nav-links{display:none;}
  .nav-btn{display:none;}
  /* Show hamburger */
  .nav-toggle{display:block;}

  /* Mobile menu drawer */
  .mobile-menu{
    display:block;
    position:fixed;
    top:0;left:0;right:0;bottom:0;
    background:rgba(255,255,255,.98);
    backdrop-filter:blur(20px);
    z-index:250;
    opacity:0;visibility:hidden;
    transition:opacity .35s ease, visibility .35s;
    overflow-y:auto;
  }
  .mobile-menu.open{
    opacity:1;visibility:visible;
  }
  .mobile-menu-inner{
    padding:6rem 2rem 3rem;
    max-width:480px;
    margin:0 auto;
    min-height:100%;
    display:flex;
    flex-direction:column;
  }
  .mobile-menu-links{
    list-style:none;padding:0;margin:0 0 2.5rem;
    border-top:.5px solid var(--rule);
  }
  .mobile-menu-links li{
    border-bottom:.5px solid var(--rule);
  }
  .mobile-menu-links a{
    display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
    padding:1.15rem .25rem;
    font-family:var(--serif);
    font-size:1.15rem;font-weight:300;letter-spacing:.04em;
    color:var(--ink);text-decoration:none;
    transition:opacity .2s;
  }
  .mobile-menu-links a:hover,
  .mobile-menu-links a:active{opacity:.55;}
  .mobile-menu-links a span{
    font-family:var(--serif);
    font-size:.7rem;font-weight:300;letter-spacing:.08em;
    color:var(--muted);
  }
  .mobile-menu-cta{
    display:block;
    text-align:center;
    padding:1.1rem 1.5rem;
    background:var(--ink);
    color:var(--white);
    font-family:var(--mono);
    font-size:.7rem;letter-spacing:.12em;
    text-decoration:none;
    border-radius:2px;
    margin-top:auto;
  }

  /* Lock scroll when menu is open */
  body.menu-open{overflow:hidden;}
}

@media(max-width:960px){
  .hero-photo-hint{display:none;}
  .concept-layout{grid-template-columns:1fr;gap:3rem;}
  .concept-anchor{position:static;}
  .about-layout{grid-template-columns:1fr;}
  .about-visual{position:static;}
  .about-photo{max-width:260px;}
  .col-grid-3{grid-template-columns:repeat(2,1fr);gap:2rem 1rem;max-width:none;}
}
@media(max-width:640px){
  nav{padding:.85rem 1.5rem;}
  .nav-links{display:none;}
  .hero-content{padding:0 1.5rem 3rem;}
  .sec{padding:3.5rem 1.25rem;}
  .col-grid-3{grid-template-columns:1fr;gap:2rem;}
  .sec-hdr{padding-top:1.25rem;padding-bottom:1.25rem;}
  .sec-num{font-size:.5rem;}
  .sec-en{font-size:.5rem;}
  .concept-anchor{padding:.5rem 0;}
  .concept-lead{font-size:1rem;}
  .concept-body{font-size:.85rem;}
  .about-photo{max-width:180px;margin:0 auto;}
  .about-name{font-size:1.5rem;text-align:center;}
  .about-name-en{text-align:center;}
  .tags{justify-content:center;}
  .greeting-box{padding:1.25rem 1.25rem;}
  .greeting-body{font-size:.8rem;line-height:1.95;}
  .career-row{padding:.8rem 0;font-size:.78rem;}
  .career-yr{min-width:60px;}
  .contact-lead{font-size:.82rem;line-height:2;}
  .contact-sub{font-size:.75rem;}
  .form-input{font-size:.85rem;padding:.75rem .9rem;}
  .col-more-link{font-size:.62rem;}
  .hero-meta-row{font-size:.55rem;}
  .hero-cta{font-size:.62rem;}
  .hero-eyebrow{font-size:.55rem;}
  .hero-sub{font-size:.55rem;}
  .scroll-hint{display:none;}
}
@media (max-width:768px){
  .desk-br{display:none;}
}

@media (max-width:480px){
  .col-grid-3{grid-template-columns:1fr;gap:1.75rem;}
  .sec{padding:3rem 1rem;}
  .sec-title{font-size:1.15rem;}
  .hero{padding:5rem 1rem;}
  .hero-photo-wrap img{width:100%;}
  .hero-title{font-size:clamp(1.15rem,5.5vw,1.5rem);letter-spacing:.06em;}
  .hero-eyebrow{font-size:.5rem;letter-spacing:.08em;}
  .concept-anchor{font-size:1rem;line-height:1.8;}
  .about-photo{max-width:160px;}
  .about-name{font-size:1.3rem;}
  .greeting-lbl{font-size:.5rem;margin-bottom:1rem;}
  .career-lbl{font-size:.5rem;}
  .ig-grid{gap:.4rem;}
}

/* ============================================================
 * Single Column Article Styles (for single.php)
 * (Imported from column-sample.html)
 * ============================================================ */

.article-hero{
  padding:9rem 2.5rem 4rem;
  max-width:920px;margin:0 auto;
  border-bottom:.5px solid var(--rule);
}

.crumb{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;
  color:var(--muted);margin-bottom:1.5rem;display:flex;gap:.6rem;align-items:center;
}

.crumb a{color:var(--mid);text-decoration:none;}

.crumb a:hover{color:var(--ink);}

.crumb .sep{color:var(--muted);}

.article-cat{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;
  color:var(--accent);margin-bottom:1rem;
}

.article-h1{
  font-family:var(--serif);font-weight:400;
  font-size:2.4rem;line-height:1.45;letter-spacing:.01em;color:var(--ink);
  margin-bottom:1.5rem;
}

.article-meta{
  display:flex;flex-wrap:wrap;gap:1.2rem;align-items:center;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;
  color:var(--mid);
  padding-top:.5rem;
}

.article-meta .dot{color:var(--muted);}

.article-author-mini{
  display:flex;align-items:center;gap:.7rem;
}

.article-author-mini-img{
  width:32px;height:32px;border-radius:50%;
  background:#ddd;background-size:cover;background-position:center 22%;
  border:.5px solid var(--rule);
}

.article-author-mini-name{
  font-family:var(--serif);font-size:.78rem;letter-spacing:.04em;
  color:var(--ink);font-weight:400;
}

.article-body{
  max-width:780px;margin:0 auto;padding:3.5rem 2.5rem 1rem;
}

.article-body p{
  font-size:.95rem;line-height:1.95;color:#2a2a2a;
  margin-bottom:1.4rem;letter-spacing:.01em;
}

.article-body ul, .article-body ol{
  margin:.5rem 0 1.6rem 1.5rem;
  font-size:.92rem;line-height:1.9;
}

.article-body ul li, .article-body ol li{
  margin-bottom:.5rem;
}

.lead{
  font-family:var(--serif);font-weight:300;
  font-size:1.15rem;line-height:1.95;color:var(--ink);letter-spacing:.02em;
  padding:1.5rem 0 2rem;
  border-bottom:.5px solid var(--rule);
  margin-bottom:2.5rem;
}

/* Scroll offset for anchored headings (TOC plugins) so they aren't hidden under sticky nav */
.article-body h2[id],
.article-body h3[id]{
  scroll-margin-top:5.5rem;
}

h2.section-h{
  font-family:var(--serif);font-weight:400;
  font-size:1.5rem;line-height:1.55;color:var(--ink);
  margin:3.5rem 0 1.25rem;letter-spacing:.01em;
  padding-bottom:.6rem;border-bottom:1.5px solid var(--ink);
}

h2.section-h .section-num{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;
  color:var(--muted);font-weight:400;
  display:block;margin-bottom:.4rem;
}

h3.sub-h{
  font-size:1.05rem;font-weight:500;color:var(--ink);
  margin:2.2rem 0 .85rem;letter-spacing:.01em;
}

/* ─── Default Gutenberg-rendered headings inside article body ─── */
/* (when no custom .section-h / .sub-h class is applied) */
.article-body h2:not(.section-h):not(.author-name):not(.cta-h){
  font-family:var(--serif);font-weight:400;
  font-size:1.5rem;line-height:1.55;color:var(--ink);
  letter-spacing:.01em;
  margin:5rem 0 1.5rem;          /* generous top space to separate sections */
  padding-bottom:.6rem;
  border-bottom:1.5px solid var(--ink);
}
.article-body h3:not(.sub-h):not(.author-name):not(.col-title-sm):not(.cta-h){
  font-family:var(--serif);font-weight:500;
  font-size:1.1rem;line-height:1.6;color:var(--ink);
  letter-spacing:.01em;
  margin:3.5rem 0 1.1rem;        /* generous top space, smaller than h2 */
}

/* ─── Images inside article body ─── */
.article-body figure,
.article-body .wp-block-image{
  margin:2.5rem auto 3rem;       /* breathing room below image */
  max-width:100%;
}
.article-body figure img,
.article-body .wp-block-image img{
  display:block;
  width:100%;height:auto;
  border-radius:2px;
}
.article-body figcaption{
  margin-top:.85rem;
  font-family:var(--serif);font-size:.78rem;font-weight:300;
  color:var(--mid);text-align:center;line-height:1.7;
  letter-spacing:.02em;
}

/* If a heading immediately follows an image, give it extra space */
.article-body figure + h2,
.article-body .wp-block-image + h2{ margin-top:5.5rem; }
.article-body figure + h3,
.article-body .wp-block-image + h3{ margin-top:4rem; }

@media (max-width:768px){
  .article-body h2:not(.section-h):not(.author-name):not(.cta-h){
    margin:3.5rem 0 1.2rem;
    font-size:1.25rem;
  }
  .article-body h3:not(.sub-h):not(.author-name):not(.col-title-sm):not(.cta-h){
    margin:2.5rem 0 .9rem;
    font-size:1rem;
  }
  .article-body figure,
  .article-body .wp-block-image{
    margin:2rem auto 2.5rem;
  }
  .article-body figure + h2,
  .article-body .wp-block-image + h2{ margin-top:4rem; }
  .article-body figure + h3,
  .article-body .wp-block-image + h3{ margin-top:3rem; }
}

.article-body p{
  font-size:.95rem;line-height:1.95;color:#2a2a2a;
  margin-bottom:1.4rem;letter-spacing:.01em;
}

.article-body ul, .article-body ol{
  margin:.5rem 0 1.6rem 1.5rem;
  font-size:.92rem;line-height:1.9;
}

.article-body ul li, .article-body ol li{
  margin-bottom:.5rem;
}

.kw{ background:linear-gradient(transparent 60%,#ffe69c 60%); padding:0 2px; }

.kw-pill{
  display:inline-block;
  background:rgba(255,216,107,.12);color:#ffd86b;
  padding:.08rem .5rem;border-radius:2px;margin-right:.3rem;
  font-size:.55rem;
}

.quote-author{
  background:#fafaf9;
  border-left:3px solid var(--accent);
  padding:1.4rem 1.75rem;
  margin:1.8rem 0;
  font-family:var(--serif);font-size:.97rem;line-height:1.85;
  color:var(--ink);
}

.quote-source{
  display:block;margin-top:.85rem;
  font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;
  color:var(--mid);
}

.process-flow{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:.5rem;margin:2rem 0 2.4rem;
}

.process-stage{
  background:var(--white);
  border:.5px solid var(--rule);
  padding:1rem .9rem;
  border-radius:3px;
  position:relative;
}

.process-stage::after{
  content:'→';
  position:absolute;right:-12px;top:50%;transform:translateY(-50%);
  font-family:var(--mono);font-size:.85rem;color:var(--muted);
}

.process-stage:last-child::after{ display:none; }

.process-step{
  font-family:var(--mono);font-size:.55rem;letter-spacing:.12em;
  color:var(--muted);margin-bottom:.4rem;
}

.process-name{
  font-family:var(--serif);font-size:.92rem;line-height:1.4;
  color:var(--ink);font-weight:400;margin-bottom:.4rem;
}

.process-desc{
  font-size:.7rem;line-height:1.55;color:var(--mid);
}

.author-profile{
  background:var(--white);
  border:.5px solid var(--rule);
  border-radius:3px;
  padding:2rem 2.25rem;
  margin:3rem 0;
  display:grid;grid-template-columns:96px 1fr;gap:1.75rem;align-items:start;
}

.author-photo-lg{
  width:96px;height:96px;border-radius:50%;
  background:#ddd;background-size:cover;background-position:center 22%;
  border:.5px solid var(--rule);
}

.author-label{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;
  color:var(--muted);margin-bottom:.5rem;
}

.author-name{
  font-family:var(--serif);font-size:1.2rem;color:var(--ink);
  margin-bottom:.35rem;
}

.author-creds{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.06em;
  color:var(--mid);margin-bottom:.95rem;
}

.author-bio{
  font-size:.82rem;line-height:1.85;color:#2a2a2a;
}

.author-links{
  margin-top:.75rem;display:flex;gap:1.2rem;
  font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;
}

.author-links a{color:var(--accent);text-decoration:none;border-bottom:.5px solid transparent;transition:.2s;}

.author-links a:hover{border-bottom-color:var(--accent);}

.cta-box{
  background:var(--ink);color:var(--white);
  padding:2.5rem 2.5rem;border-radius:3px;
  margin:3rem 0;text-align:center;
}

.cta-eyebrow,
.article-body .cta-eyebrow{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;
  color:rgba(255,255,255,.7);margin-bottom:.85rem;
}

.cta-h{
  font-family:var(--serif);font-weight:300;
  font-size:1.35rem;line-height:1.6;color:var(--white);
  margin-bottom:1.25rem;
}

.cta-btn{
  display:inline-block;
  padding:.95rem 2.4rem;
  border:.5px solid rgba(255,255,255,.55);
  color:var(--white);text-decoration:none;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;
  transition:all .2s;
}

.cta-btn:hover{ background:var(--white);color:var(--ink); }

.sources{
  margin:3rem 0;padding:1.5rem 1.75rem;
  background:#fafaf9;border-radius:3px;
  font-size:.8rem;
}

.sources-label{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;
  color:var(--muted);margin-bottom:.75rem;
}

.sources ol{margin-left:1.25rem;line-height:1.8;}

.sources a{color:var(--mid);text-decoration:none;border-bottom:.5px dotted var(--mid);}

.sources a:hover{color:var(--ink);border-bottom-style:solid;}

.sources-label{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;
  color:var(--muted);margin-bottom:.75rem;
}

@media (max-width:768px){ .article-h1{font-size:1.55rem;} }

@media (max-width:768px){ .article-body{padding:2rem 1.25rem 1rem;} }

@media (max-width:768px){
  h2.section-h{font-size:1.2rem;}
}

@media (max-width:768px){
  .process-flow{grid-template-columns:1fr 1fr;gap:.4rem;}
}

@media (max-width:768px){
  .author-profile{grid-template-columns:1fr;text-align:center;}
}

/* ============================================================
 * Footer Styles
 * ============================================================ */
.site-footer{
  padding:3.5rem 2.5rem;
  border-top:.5px solid var(--rule);
  margin-top:5rem;
  text-align:center;
}
.footer-inner{
  max-width:var(--max);margin:0 auto;
}
.footer-copy{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;
  color:var(--muted);margin-bottom:.85rem;
}
.footer-links{
  list-style:none;display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;
  font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;
}
.footer-links a{color:var(--mid);text-decoration:none;}
.footer-links a:hover{color:var(--ink);}

/* ============================================================
 * Contact Section split layout (for partials/section-contact.php)
 * ============================================================ */
.contact-layout{
  display:grid;grid-template-columns:1fr 1.5fr;gap:5rem;
  align-items:start;
  max-width:var(--max);margin:0 auto;
}
/* Desktop: left column stays in view while the form scrolls */
@media (min-width:901px){
  .contact-lead-wrap{
    position:sticky;
    top:7rem;
    align-self:start;
  }
}
@media (max-width:900px){
  .contact-layout{grid-template-columns:1fr;gap:2rem;}
}
.contact-lead{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(.78rem,.95vw,.92rem);
  line-height:1.95;color:var(--ink);
  text-align:center;
  margin-bottom:1.25rem;
}
.contact-sub{
  font-size:.82rem;line-height:1.8;color:var(--mid);
}

/* ============================================================
 * Contact Form 7 integration — minimal, serif, refined
 * Matches the site's typographic and color language.
 * Scoped to .contact-form-wrap to avoid affecting other forms.
 * ============================================================ */

/* Wrapper reset */
.contact-form-wrap .wpcf7{ max-width:100%; }
.contact-form-wrap .wpcf7-form{ display:block; }
.contact-form-wrap .wpcf7-form p{ margin:0; }

/* Row layout */
.contact-form-wrap .cf-row{
  margin-bottom:1.5rem;
  display:block;
}
.contact-form-wrap .cf-grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.25rem;
  margin-bottom:1.5rem;
}
.contact-form-wrap .cf-grid-2 .cf-row{ margin-bottom:0; }
@media (max-width:640px){
  .contact-form-wrap .cf-grid-2{
    grid-template-columns:1fr;
    gap:0;
    margin-bottom:0;
  }
  .contact-form-wrap .cf-grid-2 .cf-row{ margin-bottom:1.5rem; }
}

/* Labels (field titles) */
.contact-form-wrap .cf-row > label{
  display:block;
  font-family:var(--mono);
  font-size:.62rem;
  letter-spacing:.14em;
  color:var(--mid);
  text-transform:uppercase;
  margin-bottom:.55rem;
  font-weight:400;
  line-height:1.4;
}

/* Required indicator */
.contact-form-wrap .cf-req{
  display:inline-block;
  margin-left:.55rem;
  padding:.12rem .5rem;
  font-family:var(--mono);
  font-size:.5rem;
  letter-spacing:.1em;
  background:var(--ink);
  color:var(--white);
  text-transform:uppercase;
  vertical-align:.1em;
  border-radius:1px;
}

/* Text-like inputs — underline style */
.contact-form-wrap input.wpcf7-text,
.contact-form-wrap input.wpcf7-email,
.contact-form-wrap input.wpcf7-tel,
.contact-form-wrap input.wpcf7-number,
.contact-form-wrap select.wpcf7-select{
  width:100%;
  font-family:var(--serif);
  font-size:.92rem;
  font-weight:300;
  line-height:1.6;
  color:var(--ink);
  background:transparent;
  border:none;
  border-bottom:.5px solid rgba(26,26,26,.18);
  border-radius:0;
  padding:.65rem .1rem;
  outline:none;
  transition:border-color .25s ease;
  -webkit-appearance:none;
  appearance:none;
}
.contact-form-wrap input.wpcf7-text:focus,
.contact-form-wrap input.wpcf7-email:focus,
.contact-form-wrap input.wpcf7-tel:focus,
.contact-form-wrap input.wpcf7-number:focus,
.contact-form-wrap select.wpcf7-select:focus{
  border-bottom-color:var(--ink);
}

/* Placeholders — quieter */
.contact-form-wrap input::placeholder,
.contact-form-wrap textarea::placeholder{
  color:rgba(26,26,26,.32);
  font-weight:300;
}

/* Select — custom chevron */
.contact-form-wrap select.wpcf7-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%231a1a1a' stroke-width='1' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right .3rem center;
  padding-right:1.5rem;
  cursor:pointer;
}

/* Textarea — bordered box */
.contact-form-wrap textarea.wpcf7-textarea{
  width:100%;
  font-family:var(--serif);
  font-size:.92rem;
  font-weight:300;
  line-height:1.85;
  color:var(--ink);
  background:transparent;
  border:.5px solid rgba(26,26,26,.18);
  border-radius:2px;
  padding:1rem 1.1rem;
  height:140px;
  min-height:100px;
  max-height:400px;
  resize:vertical;
  outline:none;
  transition:border-color .25s ease;
  -webkit-appearance:none;
  appearance:none;
}
.contact-form-wrap textarea.wpcf7-textarea:focus{
  border-color:var(--ink);
}

/* Checkbox list (ご希望の進め方) */
.contact-form-wrap .wpcf7-checkbox{
  display:flex;
  flex-direction:column;
  gap:.55rem;
  margin-top:.2rem;
}
.contact-form-wrap .wpcf7-list-item{
  margin:0 !important;
  display:block;
}
.contact-form-wrap .wpcf7-list-item label{
  display:flex;
  align-items:center;
  gap:.7rem;
  font-family:var(--serif);
  font-size:.86rem;
  font-weight:300;
  letter-spacing:0;
  color:var(--ink);
  text-transform:none;
  cursor:pointer;
  margin:0;
}
.contact-form-wrap .wpcf7-list-item input[type="checkbox"]{
  appearance:none;
  -webkit-appearance:none;
  width:16px;
  height:16px;
  border:.5px solid rgba(26,26,26,.4);
  border-radius:2px;
  background:transparent;
  cursor:pointer;
  position:relative;
  flex-shrink:0;
  margin:0;
  transition:border-color .2s ease, background .2s ease;
}
.contact-form-wrap .wpcf7-list-item input[type="checkbox"]:checked{
  background:var(--ink);
  border-color:var(--ink);
}
.contact-form-wrap .wpcf7-list-item input[type="checkbox"]:checked::after{
  content:'';
  position:absolute;
  left:4px;
  top:1px;
  width:5px;
  height:9px;
  border:solid #fff;
  border-width:0 1px 1px 0;
  transform:rotate(45deg);
}

/* Acceptance (プライバシーポリシー同意) */
.contact-form-wrap .cf-consent{
  margin:2rem 0 1.5rem;
  padding-top:1.75rem;
  border-top:.5px solid rgba(26,26,26,.08);
}
.contact-form-wrap .cf-consent .wpcf7-list-item label{
  font-size:.78rem;
  color:var(--mid);
}
.contact-form-wrap .cf-consent a{
  color:var(--ink);
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-thickness:.5px;
}
.contact-form-wrap .cf-consent a:hover{
  text-decoration-color:rgba(26,26,26,.4);
}

/* Submit button */
.contact-form-wrap .cf-submit{
  text-align:center;
  margin-top:2.25rem;
}
.contact-form-wrap input.wpcf7-submit{
  display:inline-block;
  min-width:280px;
  padding:1.05rem 2.5rem;
  font-family:var(--mono);
  font-size:.7rem;
  font-weight:400;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--white);
  background:var(--ink);
  border:.5px solid var(--ink);
  border-radius:2px;
  cursor:pointer;
  transition:background .25s ease, color .25s ease, transform .12s ease;
  -webkit-appearance:none;
  appearance:none;
}
.contact-form-wrap input.wpcf7-submit:hover{
  background:transparent;
  color:var(--ink);
}
.contact-form-wrap input.wpcf7-submit:active{ transform:scale(.98); }
.contact-form-wrap input.wpcf7-submit:disabled{ opacity:.5;cursor:wait; }
@media (max-width:640px){
  .contact-form-wrap input.wpcf7-submit{
    min-width:0;
    width:100%;
  }
}

/* Loading spinner */
.contact-form-wrap .wpcf7-spinner{
  display:none;
  margin:0 0 0 1rem;
  width:16px;height:16px;
  background:transparent;
  border:1px solid rgba(26,26,26,.2);
  border-top-color:var(--ink);
  border-radius:50%;
  animation:cf7-spin .8s linear infinite;
  vertical-align:-.25em;
}
.contact-form-wrap .wpcf7-spinner.is-active{ display:inline-block; }
@keyframes cf7-spin{ to{ transform:rotate(360deg); } }

/* Validation tips (under each field) */
.contact-form-wrap .wpcf7-not-valid-tip{
  display:block;
  margin-top:.45rem;
  font-family:var(--serif);
  font-size:.72rem;
  font-weight:300;
  letter-spacing:.02em;
  color:#c34;
}
.contact-form-wrap input.wpcf7-not-valid,
.contact-form-wrap textarea.wpcf7-not-valid,
.contact-form-wrap select.wpcf7-not-valid{
  border-color:#c34 !important;
}

/* Response output box (success / error after submit) */
.contact-form-wrap .wpcf7-response-output{
  margin:2rem 0 0 !important;
  padding:1.1rem 1.35rem !important;
  border-radius:2px !important;
  font-family:var(--serif);
  font-size:.84rem;
  line-height:1.75;
  border:none !important;
}
.contact-form-wrap .wpcf7 form.sent .wpcf7-response-output{
  background:#f1f5ec;
  color:#3a5a2a;
  border-left:3px solid #6a8a4a !important;
}
.contact-form-wrap .wpcf7 form.invalid .wpcf7-response-output,
.contact-form-wrap .wpcf7 form.unaccepted .wpcf7-response-output,
.contact-form-wrap .wpcf7 form.payment-required .wpcf7-response-output,
.contact-form-wrap .wpcf7 form.failed .wpcf7-response-output{
  background:#faf0ed;
  color:#8c3a2a;
  border-left:3px solid #c34 !important;
}

/* On mobile, ease the side-by-side gap so the form has breathing room */
@media (max-width:900px){
  .contact-form-wrap{ margin-top:.5rem; }
}

/* ============================================================
 * Archive pagination
 * ============================================================ */
.archive-pagination .nav-links{
  display:flex;justify-content:center;align-items:center;gap:.5rem;flex-wrap:wrap;
}
.archive-pagination .page-numbers{
  display:inline-block;padding:.5rem .85rem;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;
  color:var(--mid);text-decoration:none;
  border:.5px solid var(--rule);border-radius:2px;
  transition:all .2s;
}
.archive-pagination .page-numbers:hover,
.archive-pagination .page-numbers.current{
  background:var(--ink);color:var(--white);border-color:var(--ink);
}

/* ============================================================
 * Single post navigation (prev / next)
 * ============================================================ */
.single-nav{
  border-top:.5px solid var(--rule);
  padding:3rem 2.5rem;
  max-width:var(--max);margin:3rem auto 0;
}
.single-nav-inner{
  display:flex;justify-content:space-between;align-items:center;gap:2rem;
  flex-wrap:wrap;
  font-family:var(--serif);font-size:.9rem;
}
.single-nav a{color:var(--ink);text-decoration:none;border-bottom:.5px solid transparent;transition:border-color .2s;}
.single-nav a:hover{border-bottom-color:var(--ink);}
.snav-prev{flex:1;}
.snav-next{flex:1;text-align:right;}

/* ============================================================
 * Column "more" button on homepage column section
 * ============================================================ */
.col-more{margin-top:3rem;text-align:center;}
.col-more-btn{
  display:inline-block;
  padding:.85rem 2rem;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;
  color:var(--ink);text-decoration:none;
  border:.5px solid var(--ink);border-radius:2px;
  transition:all .2s;
}
.col-more-btn:hover{ background:var(--ink);color:var(--white); }


/* ============================================================
 * Works Grid (homepage section + archive)
 * ============================================================ */
.works-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem 1.5rem;
  max-width:1200px;
  margin:0 auto;
}
@media (max-width:900px){
  .works-grid{grid-template-columns:repeat(2,1fr);gap:1.75rem 1rem;}
}
@media (max-width:540px){
  .works-grid{grid-template-columns:1fr;gap:1.75rem;}
}

.work-card{
  display:block;
  text-decoration:none;
  background:transparent;
}

.work-thumb-wrap{
  aspect-ratio:4/3;
  overflow:hidden;
  position:relative;
  background:#eaeaea;
  border-radius:3px;
}
.work-thumb-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform .5s ease;
}
.work-card:hover .work-thumb-bg{ transform:scale(1.03); }

.work-thumb-placeholder{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;
  color:var(--muted);background:#f0eee9;
}

.work-info{
  padding:1rem 0 0;
}
.work-title{
  font-family:var(--serif);
  font-size:1rem;font-weight:400;line-height:1.55;color:var(--ink);
  margin-bottom:.5rem;letter-spacing:.02em;
}
.work-meta{
  display:flex;flex-wrap:wrap;gap:.6rem;
  font-family:var(--mono);font-size:.58rem;letter-spacing:.06em;
  color:var(--muted);
}
.work-meta span{position:relative;padding-right:.6rem;}
.work-meta span:not(:last-child)::after{
  content:'·';position:absolute;right:0;top:50%;transform:translateY(-50%);
}

/* Work details table on single-work.php */
.work-body .work-details-table{
  max-width:780px;
}

/* ============================================================
 * News List (homepage section + archive)
 * ============================================================ */
.news-list{
  list-style:none;
  max-width:920px;
  margin:0 auto;
  padding:0;
}
.news-item{
  border-bottom:.5px solid var(--rule);
}
.news-item:first-child{
  border-top:.5px solid var(--rule);
}
.news-link{
  display:flex;
  align-items:baseline;
  gap:1.25rem;
  padding:1.25rem 0;
  text-decoration:none;
  flex-wrap:wrap;
  transition:background .2s;
}
.news-link:hover{
  background:rgba(26,26,26,.02);
}
.news-date{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.08em;
  color:var(--muted);
  flex-shrink:0;
}
.news-cat{
  display:inline-block;
  font-family:var(--mono);font-size:.55rem;letter-spacing:.12em;
  color:var(--mid);
  border:.5px solid var(--rule);
  padding:.2rem .6rem;
  border-radius:1px;
  flex-shrink:0;
}
.news-title{
  font-size:.92rem;line-height:1.6;
  color:var(--ink);
  flex:1;
  min-width:200px;
}
.news-link:hover .news-title{
  text-decoration:underline;
  text-decoration-color:rgba(26,26,26,.2);
  text-underline-offset:3px;
}
@media (max-width:600px){
  .news-link{gap:.6rem;}
  .news-title{flex-basis:100%;margin-top:.4rem;}
}


/* ============================================================
 * Instagram Section
 * ============================================================ */
.ig-sec{background:var(--bg);}
.ig-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.85rem;
  max-width:920px;
  margin:0 auto;
}
@media (max-width:640px){
  .ig-grid{grid-template-columns:repeat(2,1fr);gap:.5rem;}
}
.ig-card{
  display:block;
  position:relative;
  overflow:hidden;
  border-radius:2px;
  transition:transform .35s ease, box-shadow .35s ease;
}
.ig-card:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(26,26,26,.08);
}
.ig-thumb{
  aspect-ratio:1/1;
  width:100%;
  background-size:cover;
  background-position:center;
  background-color:#dde4ea;
}

/* Smash Balloon plugin override — match our minimalist style */
.ig-feed-wrap{
  max-width:920px;
  margin:0 auto;
}
.ig-feed-wrap #sb_instagram{
  padding:0 !important;
  background:transparent !important;
}
.ig-feed-wrap #sb_instagram .sbi_item{
  border-radius:2px !important;
  overflow:hidden !important;
  transition:transform .35s ease, box-shadow .35s ease;
}
.ig-feed-wrap #sb_instagram .sbi_item:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(26,26,26,.08);
}
.ig-feed-wrap #sb_instagram .sbi_photo{
  border-radius:2px !important;
}

/* Hide ALL Smash Balloon default UI (header, follow button, load more, etc.)
   Covers multiple plugin versions and class naming conventions. */
.ig-sec .sbi_header,
.ig-sec .sb_instagram_header,
.ig-sec .sbi_header_wrap,
.ig-sec .sbi_header_text,
.ig-sec .sbi_header_img_hover,
.ig-sec .sbi_follow_btn,
.ig-sec .sbi_btn,
.ig-sec .sb-follow-btn,
.ig-sec #sbi_load,
.ig-sec .sbi_load_btn,
.ig-sec .sb_follow,
.ig-sec .sb_btn,
.ig-sec [class*="sbi_follow"],
.ig-sec [class*="follow_btn"],
.ig-sec [class*="follow-btn"],
.ig-sec [class*="sbi_load"],
.ig-sec [class*="sb-follow"],
.ig-sec [id*="sbi_load"]{
  display:none !important;
  visibility:hidden !important;
  height:0 !important;
  width:0 !important;
  margin:0 !important;
  padding:0 !important;
  overflow:hidden !important;
  pointer-events:none !important;
}

/* ────────────────────────────────────────────────────────────
   Instagram CTA — eyebrow label, prominent handle, refined button
   Wrapped under #igCta to win specificity vs plugin styles.
   ──────────────────────────────────────────────────────────── */
.ig-cta{
  margin-top:3.5rem;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1.1rem;
}

/* "—— FOLLOW ——" eyebrow, same language as PHILOSOPHY */
#igCta .ig-cta-eyebrow{
  display:flex;align-items:center;justify-content:center;gap:.9rem;
  font-family:var(--mono);font-size:.62rem;letter-spacing:.22em;
  color:var(--mid);
  text-transform:uppercase;
}
#igCta .ig-cta-eyebrow::before,
#igCta .ig-cta-eyebrow::after{
  content:'';display:block;
  width:28px;height:.5px;background:var(--muted);
  flex-shrink:0;
}

/* Handle as a quiet text-link, prefixed with @ via CSS */
#igCta .ig-cta-link{
  display:inline-block;
  font-family:var(--serif);font-weight:300;
  font-size:clamp(1.1rem,2vw,1.4rem);
  letter-spacing:.04em;line-height:1.4;
  color:var(--ink) !important;
  text-decoration:none !important;
  border:none !important;
  background:transparent !important;
  padding:0;
  position:relative;
  transition:opacity .25s ease;
}
#igCta .ig-cta-link:hover{ opacity:.6; }
#igCta .ig-cta-handle::before{
  content:'@';
  font-family:var(--mono);
  font-size:.75em;
  letter-spacing:0;
  margin-right:.18em;
  color:var(--muted);
  vertical-align:.04em;
}

/* Tagline */
#igCta .ig-cta-sub{
  font-family:var(--serif);
  font-size:.82rem;font-weight:300;
  color:var(--mid);
  letter-spacing:.06em;line-height:1.8;
  margin:0;
  max-width:32em;
}

/* Outlined ghost button — matches nav-btn / form CTA language */
#igCta .ig-cta-btn{
  display:inline-flex;align-items:center;gap:.65rem;
  margin-top:1rem;
  padding:.85rem 1.85rem;
  border:.5px solid var(--ink) !important;
  border-radius:2px;
  background:transparent !important;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;
  color:var(--ink) !important;
  text-decoration:none !important;
  text-transform:uppercase;
  transition:background .25s ease,color .25s ease,gap .25s ease;
}
#igCta .ig-cta-btn:hover{
  background:var(--ink) !important;
  color:var(--white) !important;
  gap:.95rem;
}

@media (max-width:640px){
  .ig-cta{ margin-top:2.5rem;gap:.9rem; }
  #igCta .ig-cta-link{ font-size:1.15rem; }
  #igCta .ig-cta-sub{ font-size:.76rem;padding:0 1rem; }
  #igCta .ig-cta-btn{ padding:.75rem 1.5rem;font-size:.6rem; }
}
