/*
Theme Name: SHINZO Neumorphic
Theme URI: https://www.shinzo-creative.jp/
Author: SHINZO / Claude
Description: 株式会社SHINZO コーポレートサイト用ニューモーフィズム・テーマ。実績(work)・メンバー(member)・お知らせ(news)をCMS管理。SEO/構造化データ対応。
Version: 1.1.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: shinzo
*/

:root{
  --surface:#faf6ea; --surface-press:#f4eedf;
  --ink:60,55,45; --ink-deep:45,40,32; --hi:255,255,255;
  --text:#574f41; --text-soft:#8b8270; --text-faint:#a59c89;
  --f-jp:'Noto Sans JP', sans-serif; --f-jost:'Jost', sans-serif;
  --emboss:1px 1px 2px rgba(var(--ink),.30), -1px -1px 1.5px rgba(var(--hi),.92);
  --emboss-lg:2px 2px 5px rgba(var(--ink),.20), -2px -2px 4px rgba(var(--hi),.96);
  --emboss-xl:3px 3px 8px rgba(var(--ink),.20), -3px -3px 6px rgba(var(--hi),.97);
  --raise:-6px -6px 14px rgba(var(--hi),.97), 6px 6px 14px rgba(var(--ink),.13);
  --raise-lg:-8px -8px 20px rgba(var(--hi),.92), 9px 9px 22px rgba(var(--ink),.13);
  --raise-hover:-7px -7px 16px rgba(var(--hi),1), 7px 7px 17px rgba(var(--ink),.17);
  --press:inset 4px 4px 9px rgba(var(--ink),.16), inset -4px -4px 9px rgba(var(--hi),.9);
  --inset-tile:inset -4px -4px 10px rgba(var(--hi),.20), inset 5px 5px 13px rgba(var(--ink-deep),.32);
  --inset-field:inset 3px 3px 7px rgba(var(--ink),.13), inset -3px -3px 7px rgba(var(--hi),.92);
  --header-h:76px;
}
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 20px);-webkit-text-size-adjust:100%;}
body{margin:0;background:var(--surface);color:#fff;font-family:var(--f-jp);font-weight:400;line-height:1.85;letter-spacing:.015em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:rgba(var(--ink),.14);}

.emboss{color:#fff;text-shadow:var(--emboss);}
.emboss-lg{color:#fff;text-shadow:var(--emboss-lg);}
.emboss-xl{color:#fff;text-shadow:var(--emboss-xl);}
.muted{color:#fff;text-shadow:var(--emboss);}

.wrap{width:100%;max-width:1440px;margin-inline:auto;padding-inline:clamp(22px,7vw,100px);}
.section{padding-block:clamp(64px,9vw,120px);}
.section-tight{padding-block:clamp(48px,6vw,88px);}
.divider{height:1px;border:0;margin:0;background:rgba(var(--ink),.10);box-shadow:0 -1px 0 rgba(var(--hi),.85);}

.eyebrow{font-family:var(--f-jost);font-weight:500;font-size:12px;letter-spacing:.24em;text-transform:uppercase;margin:0;color:#fff;text-shadow:var(--emboss);}
.h-hero{font-family:var(--f-jp);font-weight:500;margin:.18em 0 0;font-size:clamp(40px,7.6vw,84px);line-height:1.12;letter-spacing:-.02em;color:#fff;text-shadow:var(--emboss-xl);}
.h-page{font-family:var(--f-jp);font-weight:500;margin:.32em 0 0;font-size:clamp(34px,5.6vw,64px);line-height:1.16;letter-spacing:-.02em;color:#fff;text-shadow:var(--emboss-xl);}
.h-section{font-family:var(--f-jp);font-weight:500;margin:.30em 0 0;font-size:clamp(27px,3.9vw,46px);line-height:1.28;letter-spacing:-.015em;color:#fff;text-shadow:var(--emboss-lg);}
.h-sub{font-family:var(--f-jp);font-weight:500;margin:0;font-size:clamp(19px,2.2vw,23px);line-height:1.42;color:#fff;text-shadow:var(--emboss);}
.lead{max-width:640px;margin:1.6em 0 0;font-size:clamp(15px,1.15vw,16.5px);line-height:2;color:#fff;text-shadow:var(--emboss);}
.numeral{font-family:var(--f-jost);font-weight:500;letter-spacing:-.012em;line-height:.9;color:#fff;text-shadow:var(--emboss-lg);}

.btn{display:inline-flex;align-items:center;gap:.7em;cursor:pointer;background:var(--surface);border:none;border-radius:44px;padding:16px 30px;font-family:var(--f-jp);font-weight:500;font-size:15px;color:#fff;text-shadow:var(--emboss);box-shadow:var(--raise);transition:box-shadow .25s ease, transform .25s ease;}
.btn .arw{font-family:var(--f-jost);}
.btn:hover{transform:translateY(-1px);box-shadow:var(--raise-hover);background:#c2402c;color:#fff;text-shadow:none;}
.btn:hover .arw{color:#fff;}
.btn:active{transform:translateY(0);box-shadow:var(--press);}
.btn-sm{padding:13px 24px;font-size:14px;}
.pill{display:inline-flex;align-items:center;gap:.5em;cursor:pointer;background:var(--surface);border:none;border-radius:44px;padding:11px 22px;font-family:var(--f-jp);font-weight:500;font-size:13.5px;color:#fff;text-shadow:var(--emboss);box-shadow:var(--raise);transition:box-shadow .22s ease;}
.pill.is-active{box-shadow:var(--press);}
.tag{display:inline-flex;align-items:center;border-radius:30px;padding:9px 18px;font-family:var(--f-jp);font-weight:500;font-size:13px;letter-spacing:.02em;color:#fff;text-shadow:var(--emboss);background:var(--surface);box-shadow:var(--raise);}

.tile{position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(var(--hi),.45);box-shadow:var(--inset-tile);}
.tile::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:var(--inset-tile);pointer-events:none;}
.tile-initial{position:absolute;inset:0;z-index:1;display:grid;place-items:center;font-family:var(--f-jp);font-weight:500;font-size:clamp(54px,7vw,84px);color:rgba(255,255,255,.92);text-shadow:2px 3px 10px rgba(0,0,0,.28), -1px -1px 2px rgba(255,255,255,.25);}
.tile-photo{position:absolute;inset:0;z-index:1;width:100%;height:100%;object-fit:cover;}
.t-terracotta{background-image:linear-gradient(144deg,rgb(201,138,94) 15%,rgb(126,74,48) 85%);}
.t-steel{background-image:linear-gradient(144deg,rgb(110,138,156) 15%,rgb(54,72,88) 85%);}
.t-green{background-image:linear-gradient(144deg,rgb(74,130,118) 15%,rgb(32,69,63) 85%);}
.t-wine{background-image:linear-gradient(144deg,rgb(168,106,124) 15%,rgb(87,51,65) 85%);}
.t-sand{background-image:linear-gradient(144deg,rgb(196,170,118) 15%,rgb(120,96,52) 85%);}
.t-slate{background-image:linear-gradient(144deg,rgb(120,124,134) 15%,rgb(56,58,68) 85%);}
.ratio-43{aspect-ratio:560/403;} .ratio-portrait{aspect-ratio:292/388;} .ratio-wide{aspect-ratio:16/7;}

.panel{background:var(--surface);border-radius:22px;box-shadow:var(--raise-lg);padding:clamp(26px,3.4vw,44px);}
.panel-inset{background:var(--surface);border-radius:18px;box-shadow:var(--press);padding:clamp(22px,3vw,36px);}

.site-header{position:fixed;top:0;left:0;right:0;z-index:60;height:var(--header-h);background:var(--surface);display:flex;align-items:center;transition:box-shadow .3s ease;}
.site-header.scrolled{box-shadow:0 6px 18px rgba(var(--ink),.08);}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.brand{font-family:var(--f-jost);font-weight:500;font-size:19px;letter-spacing:.20em;color:#fff;text-shadow:var(--emboss);}
.nav{display:flex;align-items:center;gap:34px;}
.nav a{font-family:var(--f-jost);font-weight:500;font-size:13.5px;letter-spacing:.04em;color:#fff;text-shadow:var(--emboss);opacity:.78;transition:opacity .2s ease;}
.nav a:hover,.nav a.current-menu-item{opacity:1;}
.nav-toggle{display:none;background:var(--surface);border:none;border-radius:50%;width:46px;height:46px;cursor:pointer;box-shadow:var(--raise);}

.hero{padding-top:calc(var(--header-h) + clamp(70px,11vw,150px));padding-bottom:clamp(60px,9vw,120px);}
.page-hero{padding-top:calc(var(--header-h) + clamp(56px,9vw,104px));padding-bottom:clamp(40px,5vw,64px);}
.hero .lead,.page-hero .lead{margin-top:1.7em;}
.hero-actions,.cta-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:40px;}

.grid{display:grid;gap:clamp(24px,3vw,40px);}
.cols-2{grid-template-columns:repeat(2,1fr);} .cols-3{grid-template-columns:repeat(3,1fr);} .cols-4{grid-template-columns:repeat(4,1fr);}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:clamp(36px,5vw,56px);}
.viewall,.backlink{font-family:var(--f-jost);font-weight:500;font-size:13.5px;letter-spacing:.06em;color:#fff;text-shadow:var(--emboss);}

.work-card{display:block;}
.work-card .tile{transition:transform .35s ease;} .work-card:hover .tile{transform:translateY(-4px);}
.work-card .cat{font-family:var(--f-jost);font-weight:500;font-size:11px;letter-spacing:.18em;margin:22px 0 0;color:#fff;text-shadow:var(--emboss);}
.work-card .title{margin:10px 0 0;font-family:var(--f-jp);font-weight:500;font-size:23px;line-height:1.45;color:#fff;text-shadow:var(--emboss);}
.work-card .desc{margin:12px 0 0;font-size:14px;line-height:1.75;color:#fff;text-shadow:var(--emboss);max-width:560px;}
.scope{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}

.svc{display:grid;grid-template-columns:200px 1fr;gap:clamp(20px,3vw,48px);padding-block:clamp(36px,5vw,56px);border-top:1px solid rgba(var(--ink),.10);}
.svc:first-of-type{border-top:0;}
.svc .no{font-size:clamp(54px,7vw,80px);}
.svc .svc-en{font-family:var(--f-jost);font-weight:500;font-size:12px;letter-spacing:.16em;margin:8px 0 0;color:#fff;text-shadow:var(--emboss);}
.svc .svc-ttl{font-family:var(--f-jp);font-weight:500;font-size:clamp(24px,2.8vw,28px);color:#fff;text-shadow:var(--emboss);margin:0;}
.svc .svc-body{font-size:15px;line-height:1.95;max-width:560px;margin:14px 0 0;color:#fff;text-shadow:var(--emboss);}
.deliverables{list-style:none;padding:0;margin:22px 0 0;display:flex;flex-wrap:wrap;gap:9px;}

.news-row{display:grid;grid-template-columns:120px 90px 1fr 24px;align-items:center;gap:24px;padding:22px 0;border-bottom:1px solid rgba(var(--ink),.10);transition:opacity .2s ease;}
.news-row:hover{opacity:.62;}
.news-row .date{font-family:var(--f-jost);font-weight:500;font-size:14px;color:#fff;text-shadow:var(--emboss);}
.news-row .ncat{font-family:var(--f-jost);font-weight:500;font-size:11px;letter-spacing:.1em;color:#fff;text-shadow:var(--emboss);}
.news-row .ntitle{font-size:15.5px;color:#fff;text-shadow:var(--emboss);line-height:1.5;}
.news-row .arw{font-family:var(--f-jost);justify-self:end;color:#fff;text-shadow:var(--emboss);}

.member .photogap{height:16px;}
.member .name{margin:0;font-family:var(--f-jp);font-weight:500;font-size:18px;color:#fff;text-shadow:var(--emboss);}
.member .role{margin:6px 0 0;font-family:var(--f-jost);font-weight:500;font-size:11px;letter-spacing:.14em;color:#fff;text-shadow:var(--emboss);}
.member .bio{margin:12px 0 0;font-size:13.5px;line-height:1.85;color:#fff;text-shadow:var(--emboss);}

.prose{max-width:720px;}
.prose p{margin:0 0 1.5em;font-size:16px;line-height:2.05;color:#fff;text-shadow:var(--emboss);}
.prose h2{margin:2.4em 0 .9em;font-family:var(--f-jp);font-weight:500;font-size:clamp(21px,2.4vw,26px);color:#fff;text-shadow:var(--emboss);line-height:1.5;}
.prose h3{margin:2em 0 .7em;font-family:var(--f-jp);font-weight:500;font-size:18px;color:#fff;text-shadow:var(--emboss);}
.prose ul,.prose ol{margin:0 0 1.6em;padding-left:1.3em;}
.prose li{margin:.5em 0;font-size:15.5px;line-height:1.95;color:#fff;text-shadow:var(--emboss);}
.prose blockquote{margin:1.8em 0;padding:20px 26px;border-radius:14px;box-shadow:var(--press);color:#fff;text-shadow:var(--emboss);font-size:15px;}

.doc{max-width:760px;}
.doc h2{margin:2.6em 0 .8em;font-family:var(--f-jp);font-weight:500;font-size:clamp(18px,2vw,21px);color:#fff;text-shadow:var(--emboss);}
.doc h2:first-of-type{margin-top:0;}
.doc p,.doc li{font-size:15px;line-height:1.95;color:#fff;text-shadow:var(--emboss);}
.doc p{margin:0 0 1.2em;} .doc ul,.doc ol{margin:0 0 1.3em;padding-left:1.3em;} .doc li{margin:.45em 0;}

.info-table{width:100%;border-collapse:collapse;}
.info-table th,.info-table td{text-align:left;vertical-align:top;padding:20px 0;border-bottom:1px solid rgba(var(--ink),.10);}
.info-table th{width:200px;font-family:var(--f-jp);font-weight:500;font-size:13px;letter-spacing:.04em;color:#fff;text-shadow:var(--emboss);}
.info-table td{font-size:15px;color:#fff;text-shadow:var(--emboss);line-height:1.85;}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.4vw,28px);}
.field-row{display:flex;flex-direction:column;gap:10px;} .field-row.full{grid-column:1 / -1;}
.label{font-family:var(--f-jp);font-weight:500;font-size:13px;letter-spacing:.03em;color:#fff;text-shadow:var(--emboss);}
.field,.wpcf7-form input[type=text],.wpcf7-form input[type=email],.wpcf7-form input[type=tel],.wpcf7-form textarea,.wpcf7-form select{width:100%;background:var(--surface);border:none;border-radius:14px;padding:15px 18px;font-family:var(--f-jp);font-size:15px;color:var(--text);box-shadow:var(--inset-field);transition:box-shadow .2s ease;}
.wpcf7-form textarea{min-height:160px;resize:vertical;line-height:1.8;}
.field:focus,.wpcf7-form :focus{outline:none;box-shadow:inset 4px 4px 9px rgba(var(--ink),.18), inset -4px -4px 9px rgba(var(--hi),.95);}

.cta-band{text-align:center;} .cta-band .lead{margin-inline:auto;} .cta-band .cta-actions{justify-content:center;}

.site-footer{padding-top:clamp(56px,7vw,80px);padding-bottom:40px;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-block:clamp(48px,6vw,72px);}
.footer-brand .brand{font-size:30px;}
.footer-brand p{margin:22px 0 0;max-width:320px;font-size:14px;line-height:1.95;color:#fff;text-shadow:var(--emboss);}
.foot-col h4{margin:0 0 18px;font-family:var(--f-jost);font-weight:500;font-size:12px;letter-spacing:.16em;color:#fff;text-shadow:var(--emboss);}
.foot-col a{display:block;margin:0 0 13px;font-size:14.5px;color:#fff;text-shadow:var(--emboss);}
.copyright{font-family:var(--f-jost);font-weight:500;font-size:12.5px;letter-spacing:.04em;color:#fff;text-shadow:var(--emboss);padding-top:30px;display:block;}
.crumb{font-family:var(--f-jost);font-size:12px;letter-spacing:.08em;color:#fff;text-shadow:var(--emboss);margin-bottom:8px;}

@media (max-width:1024px){.footer-top{grid-template-columns:1fr 1fr;}.footer-brand{grid-column:1/-1;}}
@media (max-width:880px){
  :root{--header-h:64px;}
  .nav,.header-cta{display:none;} .nav-toggle{display:inline-flex;align-items:center;justify-content:center;}
  .cols-2,.cols-3,.cols-4{grid-template-columns:repeat(2,1fr);}
  .svc{grid-template-columns:1fr;gap:8px;} .form-grid{grid-template-columns:1fr;}
  .news-row{grid-template-columns:96px 1fr 18px;gap:14px 16px;} .news-row .ncat{display:none;}
  .info-table th{width:130px;}
}
@media (max-width:560px){.cols-3,.cols-4,.cols-2{grid-template-columns:1fr;} .hero-actions .btn{width:100%;justify-content:center;}}

/* ---- subtle scroll reveal (animation only; layout/design unchanged) ---- */
.js-anim .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform;}
.js-anim .reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.js-anim .reveal{opacity:1 !important;transform:none !important;transition:none !important;}}

/* =========================================================
   WHITE THEME OVERRIDE — 白背景 + 読みやすい濃い文字
   ========================================================= */
:root{ --surface:#ffffff; }
body{ background:#ffffff; color:#403a2e; }
.site-header{ background:#ffffff; }
/* 主要テキスト・見出し：濃いインク色、グロー無しで可読性確保 */
.emboss,.emboss-lg,.emboss-xl,.h-hero,.h-page,.h-section,.h-sub,.lead,.numeral,
.brand,.nav a,.viewall,.backlink,.btn,.tag,.pill,
.work-card .cat,.work-card .title,.work-card .desc,
.svc .svc-ttl,.svc .svc-body,
.news-row .ntitle,
.member .name,.member .bio,
.prose p,.prose h2,.prose h3,.prose li,.prose blockquote,
.doc h2,.doc p,.doc li,
.info-table td,
.foot-col a,
.label{ color:#403a2e !important; text-shadow:none !important; }
/* 補助ラベル：少し淡いブラウンで階層をつける（白地でも十分読める） */
.muted,.eyebrow,.svc .svc-en,.news-row .date,.news-row .ncat,.news-row .arw,
.member .role,.footer-brand p,.foot-col h4,.copyright,.info-table th,.crumb{ color:#7a7158 !important; text-shadow:none !important; }
/* 色付きタイル上の文字／ホバー時の白文字は白のまま維持 */
.tile-initial{ color:rgba(255,255,255,.95) !important; text-shadow:2px 3px 10px rgba(0,0,0,.28) !important; }
.tile-label{ color:rgba(255,255,255,.92) !important; }
.btn:hover,.btn:hover .arw{ color:#fff !important; }
/* 区切り線を白背景でも見えるよう少し濃く */
.divider,.svc,.news-row,.info-table th,.info-table td{ border-color:rgba(60,55,45,.12); }
