@charset "UTF-8";
/*
Theme Name: Fizi Theme
Theme URI: https://fizi.example.com/
Author: Fizi Inc.
Author URI: https://fizi.example.com/
Description: 株式会社Fizi公式WordPressテーマ。「価値を生み出す側へ」を体現するブランドサイト用カスタムテーマ。B · PAPER POP デザインを採用し、SNS・AI・クリエイター・プロダクト事業を訴求します。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.1
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: fizi
Tags: business, custom-colors, custom-menu, threaded-comments, translation-ready
*/

/* ========= Design Tokens ========= */
:root{
  --cream:#f1ece0;
  --cream-2:#e8e1d1;
  --ink:#141414;
  --ink-soft:#2a2620;
  --muted:#6e6555;
  --line:#d9d1be;
  --red:#e84a2e;
  --blue:#2a55d4;
  --yellow:#f5c11a;
  --orange:#f57a2a;
  --green:#2e8c5c;
  --pink:#ec5e8c;
  --font-jp:"Noto Sans JP",sans-serif;
  --font-jp-serif:"Shippori Mincho",serif;
  --font-display:"Anton",sans-serif;
  --font-archivo:"Archivo",sans-serif;
  --pad:clamp(20px,4vw,64px);
}

/* ========= Reset & Base ========= */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-jp);
  font-weight:400;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}

/* ========= Header ========= */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:100;
  padding:20px var(--pad);
  display:flex;justify-content:space-between;align-items:center;
  transition:all .3s ease;
}
.site-header.scrolled{
  background:rgba(241,236,224,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  padding:14px var(--pad);
}
.site-logo{
  font-family:var(--font-display);
  font-size:30px;letter-spacing:.04em;
  color:var(--ink);
}
.site-logo .dot{
  display:inline-block;width:10px;height:10px;
  background:var(--red);border-radius:50%;
  vertical-align:middle;margin-left:6px;
}
.site-nav ul{list-style:none;display:flex;gap:32px;align-items:center;margin:0;padding:0;}
.site-nav a{
  font-family:var(--font-archivo);font-size:13px;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;
  position:relative;padding:6px 0;
}
.site-nav a::after{
  content:"";position:absolute;left:0;bottom:0;
  width:0;height:2px;background:var(--red);transition:width .3s;
}
.site-nav a:hover::after,
.site-nav .current-menu-item > a::after,
.site-nav a.active::after{width:100%;}
.site-nav .nav-cta{
  background:var(--ink);color:var(--cream);
  padding:10px 20px;border-radius:100px;
  font-family:var(--font-archivo);font-size:12px;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  transition:all .25s;
}
.site-nav .nav-cta:hover{background:var(--red);}
.site-nav .nav-cta::after{display:none;}
.menu-toggle{display:none;font-size:24px;color:var(--ink);}
@media (max-width:900px){
  .site-nav ul{display:none;}
  .menu-toggle{display:block;}
}

/* ========= Page Hero (Sub pages) ========= */
.page-hero{padding:160px var(--pad) 80px;position:relative;overflow:hidden;}
.page-hero-inner{max-width:1320px;margin:0 auto;position:relative;z-index:1;}
.breadcrumb{
  font-family:var(--font-archivo);font-style:italic;
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);margin-bottom:24px;
}
.breadcrumb a{color:var(--red);}
.page-hero h1{
  font-family:var(--font-display);
  font-size:clamp(72px,14vw,200px);
  font-weight:400;line-height:.9;letter-spacing:.02em;
  margin-bottom:16px;
}
.page-hero .jp{
  font-family:var(--font-jp-serif);
  font-size:clamp(24px,3.5vw,40px);font-weight:700;
  color:var(--red);margin-bottom:32px;letter-spacing:.04em;
}
.page-hero p{
  font-family:var(--font-jp-serif);font-size:18px;
  color:var(--ink-soft);max-width:720px;line-height:2;
}
.blob-decor{position:absolute;border-radius:50%;}
.blob-yellow{background:var(--yellow);opacity:.55;}
.blob-red{background:var(--red);opacity:.85;}
.blob-blue{background:var(--blue);opacity:.7;mix-blend-mode:multiply;}

/* ========= HOME Hero ========= */
.hero{
  min-height:100vh;
  padding:140px var(--pad) 80px;
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:48px;align-items:center;
  position:relative;overflow:hidden;
}
@media (max-width:900px){.hero{grid-template-columns:1fr;padding-top:120px;}}
.hero-content{position:relative;z-index:2;}
.hero-eyebrow{
  font-family:var(--font-archivo);font-style:italic;
  font-size:13px;letter-spacing:.25em;text-transform:uppercase;
  color:var(--ink);margin-bottom:24px;
  display:inline-flex;align-items:center;gap:12px;
}
.hero-eyebrow::before{content:"";width:32px;height:2px;background:var(--red);}
.hero h1{
  font-family:var(--font-display);
  font-size:clamp(56px,11vw,160px);
  font-weight:400;line-height:.92;letter-spacing:.02em;
  color:var(--ink);margin-bottom:8px;
}
.hero h1 .accent{color:var(--red);}
.hero-jp{
  font-family:var(--font-jp-serif);
  font-size:clamp(32px,5vw,64px);font-weight:700;
  color:var(--ink);line-height:1.2;letter-spacing:.04em;
  margin-bottom:32px;
}
.hero-jp .marker{background:linear-gradient(transparent 60%,var(--yellow) 60%);padding:0 6px;}
.hero-tagline{
  font-family:var(--font-jp-serif);
  font-size:clamp(16px,1.6vw,18px);font-weight:500;
  color:var(--ink-soft);max-width:520px;margin-bottom:48px;line-height:2;
}
.hero-cta{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;background:var(--ink);color:var(--cream);
  font-family:var(--font-archivo);font-size:13px;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;
  transition:all .3s ease;
}
.hero-cta::after{content:"→";font-size:18px;transition:transform .25s;}
.hero-cta:hover{background:var(--red);}
.hero-cta:hover::after{transform:translateX(6px);}

.hero-visual{position:relative;height:480px;width:100%;}
@media (max-width:900px){.hero-visual{height:320px;}}
.hero-blob{position:absolute;border-radius:50%;}
.hero-blob-red{width:55%;aspect-ratio:1;background:var(--red);top:5%;right:5%;animation:float 8s ease-in-out infinite;}
.hero-blob-yellow{width:30%;aspect-ratio:1;background:var(--yellow);bottom:18%;right:28%;z-index:2;animation:float 10s ease-in-out infinite -2s;}
.hero-blob-blue{width:38%;aspect-ratio:1;background:var(--blue);bottom:8%;right:8%;animation:float 12s ease-in-out infinite -4s;}
@keyframes float{0%,100%{transform:translate(0,0) rotate(0);}50%{transform:translate(-8px,-12px) rotate(2deg);}}

/* Marquee strip */
.hero-strip{
  position:absolute;bottom:0;left:0;width:100%;
  background:var(--ink);color:var(--cream);
  padding:14px 0;overflow:hidden;
  border-top:2px solid var(--red);
}
.marquee{
  display:flex;gap:48px;white-space:nowrap;
  animation:scroll 30s linear infinite;
  font-family:var(--font-archivo);font-size:13px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
}
.marquee span{display:inline-flex;align-items:center;gap:48px;}
.marquee span::after{content:"●";color:var(--red);font-size:8px;}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ========= Section base ========= */
.section{padding:120px var(--pad);position:relative;}
.container{max-width:1320px;margin:0 auto;}
.section-head{margin-bottom:64px;}
.section-eyebrow{
  font-family:var(--font-archivo);font-style:italic;
  font-size:13px;color:var(--red);
  letter-spacing:.2em;text-transform:uppercase;
  margin-bottom:16px;
  display:inline-flex;align-items:center;gap:12px;
}
.section-eyebrow::before{content:"●";font-size:8px;}
.section-title{
  font-family:var(--font-display);
  font-size:clamp(48px,7vw,110px);
  font-weight:400;line-height:.95;letter-spacing:.01em;
  color:var(--ink);
}
.section-title-jp{
  font-family:var(--font-jp-serif);
  font-size:clamp(28px,4vw,48px);
  font-weight:700;line-height:1.2;
  color:var(--ink);margin-bottom:24px;
}

/* ========= Vision/Mission section ========= */
.section--cream2{background:var(--cream-2);}
.vm-tagline{
  font-family:var(--font-display);
  font-size:clamp(56px,11vw,180px);
  line-height:.9;letter-spacing:.01em;margin-bottom:48px;
}
.vm-tagline .accent{color:var(--red);}
.vm-tagline-jp{
  font-family:var(--font-jp-serif);
  font-size:clamp(28px,4vw,52px);
  font-weight:700;line-height:1.4;letter-spacing:.04em;
  margin-bottom:48px;max-width:1000px;
}
.vm-tagline-jp .marker{background:linear-gradient(transparent 60%,var(--yellow) 60%);padding:0 4px;}
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px;}
@media (max-width:768px){.vm-grid{grid-template-columns:1fr;}}
.vm-card{background:var(--cream);padding:48px 36px;border-radius:8px;border-left:8px solid var(--ink);}
.vm-card.is-v{border-left-color:var(--red);}
.vm-card.is-m{border-left-color:var(--blue);}
.vm-card-label{font-family:var(--font-display);font-size:64px;line-height:1;letter-spacing:.02em;margin-bottom:8px;}
.vm-card.is-v .vm-card-label{color:var(--red);}
.vm-card.is-m .vm-card-label{color:var(--blue);}
.vm-card-en{font-family:var(--font-archivo);font-style:italic;font-size:13px;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px;}
.vm-card-jp-label{font-family:var(--font-jp-serif);font-weight:700;font-size:18px;color:var(--ink);margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--line);}
.vm-card-text{font-family:var(--font-jp-serif);font-size:18px;line-height:1.95;font-weight:500;}

/* ========= Values ========= */
.values-list{display:flex;flex-direction:column;gap:0;border-top:2px solid var(--ink);}
.value-item{
  display:grid;
  grid-template-columns:120px 1fr 1.6fr;
  gap:32px;padding:40px 0;
  border-bottom:1px solid var(--line);
  align-items:start;
  transition:all .3s ease;
}
@media (max-width:768px){.value-item{grid-template-columns:60px 1fr;gap:16px;}.value-item .v-desc{grid-column:1/-1;margin-top:8px;}}
.value-item:hover{padding-left:16px;padding-right:16px;background:var(--cream-2);margin:0 -16px;}
.v-num{font-family:var(--font-display);font-size:64px;line-height:.85;letter-spacing:.02em;}
.value-item:nth-child(1) .v-num{color:var(--red);}
.value-item:nth-child(2) .v-num{color:var(--blue);}
.value-item:nth-child(3) .v-num{color:var(--yellow);}
.value-item:nth-child(4) .v-num{color:var(--orange);}
.value-item:nth-child(5) .v-num{color:var(--green);}
.v-title{font-family:var(--font-jp-serif);font-size:clamp(20px,2vw,28px);font-weight:700;line-height:1.4;color:var(--ink);}
.v-desc{font-family:var(--font-jp-serif);font-size:16px;line-height:1.95;color:var(--ink-soft);}

/* ========= Services ========= */
.section--dark{background:var(--ink);color:var(--cream);position:relative;overflow:hidden;}
.section--dark .section-eyebrow{color:var(--yellow);}
.section--dark .section-title{color:var(--cream);}
.section--dark::before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:var(--pink);opacity:.15;filter:blur(80px);top:-100px;right:-100px;}
.section--dark::after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:var(--blue);opacity:.18;filter:blur(60px);bottom:-100px;left:-50px;}
.services-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  margin-top:64px;
  border-top:1px solid rgba(241,236,224,.15);
  position:relative;z-index:1;
}
@media (max-width:768px){.services-grid{grid-template-columns:1fr;}}
.service-cell{
  padding:48px 32px;
  border-bottom:1px solid rgba(241,236,224,.15);
  transition:background .3s;cursor:pointer;
  position:relative;
}
.service-cell:nth-child(odd){border-right:1px solid rgba(241,236,224,.15);}
@media (max-width:768px){.service-cell:nth-child(odd){border-right:none;}}
.service-cell:hover{background:rgba(241,236,224,.04);}
.service-cell::before{content:"";display:block;width:48px;height:6px;margin-bottom:24px;}
.service-cell:nth-child(1)::before{background:var(--red);}
.service-cell:nth-child(2)::before{background:var(--pink);}
.service-cell:nth-child(3)::before{background:var(--yellow);}
.service-cell:nth-child(4)::before{background:var(--blue);}
.service-cell .num{font-family:var(--font-archivo);font-style:italic;font-size:13px;letter-spacing:.2em;color:rgba(241,236,224,.5);margin-bottom:8px;}
.service-cell h3{font-family:var(--font-display);font-size:32px;letter-spacing:.02em;margin-bottom:12px;}
.service-cell .jp{font-family:var(--font-jp-serif);font-weight:500;font-size:18px;color:var(--cream);margin-bottom:16px;}
.service-cell p{font-size:14px;color:rgba(241,236,224,.75);line-height:1.95;max-width:520px;}
.service-arrow{position:absolute;top:48px;right:32px;font-family:var(--font-archivo);font-size:20px;color:rgba(241,236,224,.4);transition:all .3s;}
.service-cell:hover .service-arrow{transform:translateX(6px);color:var(--cream);}

/* ========= Strengths ========= */
.strengths-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:64px;position:relative;z-index:1;}
@media (max-width:768px){.strengths-grid{grid-template-columns:1fr;}}
.strength-card{padding:36px 32px;border:1px solid rgba(241,236,224,.2);transition:all .3s;}
.strength-card:hover{background:rgba(241,236,224,.04);transform:translateY(-4px);}
.strength-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;color:var(--ink);margin-bottom:20px;}
.strength-card:nth-child(1) .strength-icon{background:var(--yellow);}
.strength-card:nth-child(2) .strength-icon{background:var(--red);color:var(--cream);}
.strength-card:nth-child(3) .strength-icon{background:var(--blue);color:var(--cream);}
.strength-card:nth-child(4) .strength-icon{background:var(--pink);color:var(--cream);}
.strength-card h3{font-family:var(--font-jp-serif);font-weight:700;font-size:22px;line-height:1.4;margin-bottom:12px;}
.strength-card p{font-size:14px;color:rgba(241,236,224,.75);line-height:1.95;}

/* ========= News list ========= */
.news-list{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px;}
@media (max-width:900px){.news-list{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.news-list{grid-template-columns:1fr;}}
.news-card{display:block;}
.news-thumb{aspect-ratio:4/3;background:linear-gradient(135deg,var(--red),#a82a18);margin-bottom:16px;overflow:hidden;position:relative;transition:transform .4s;}
.news-thumb img{width:100%;height:100%;object-fit:cover;}
.news-card:nth-child(2n) .news-thumb{background:linear-gradient(135deg,var(--blue),#1838a8);}
.news-card:nth-child(3n) .news-thumb{background:linear-gradient(135deg,var(--yellow),#c89800);}
.news-card:hover .news-thumb{transform:translateY(-4px);}
.news-meta{display:flex;gap:16px;align-items:center;font-family:var(--font-archivo);font-size:11px;color:var(--muted);letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px;}
.news-cat{background:var(--ink);color:var(--cream);padding:4px 10px;}
.news-title{font-family:var(--font-jp-serif);font-weight:700;font-size:18px;line-height:1.5;color:var(--ink);}
.news-card:hover .news-title{color:var(--red);}

/* ========= Profile table ========= */
.profile-table{background:var(--cream-2);border-radius:8px;overflow:hidden;}
.profile-row{display:grid;grid-template-columns:200px 1fr;gap:32px;padding:24px 32px;border-bottom:1px solid var(--line);align-items:start;}
.profile-row:last-child{border-bottom:none;}
@media (max-width:640px){.profile-row{grid-template-columns:1fr;gap:8px;padding:20px 24px;}}
.profile-row dt{font-family:var(--font-archivo);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);padding-top:4px;}
.profile-row dt::before{content:"— ";color:var(--red);}
.profile-row dd{font-family:var(--font-jp-serif);font-size:16px;font-weight:500;color:var(--ink);line-height:1.85;}
.profile-row dd small{display:block;font-family:var(--font-archivo);font-size:12px;color:var(--muted);margin-top:4px;font-style:italic;}
.nonpub{display:inline-block;background:rgba(110,101,85,.12);color:var(--muted);padding:2px 10px;border-radius:4px;font-family:var(--font-archivo);font-size:12px;font-weight:600;letter-spacing:.05em;}

/* ========= CTA Strip ========= */
.cta-strip{background:var(--red);color:var(--cream);padding:140px var(--pad);text-align:center;position:relative;overflow:hidden;}
.cta-strip::before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:var(--yellow);opacity:.15;top:-200px;left:-100px;}
.cta-strip::after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:var(--blue);opacity:.18;bottom:-150px;right:-80px;}
.cta-strip-inner{position:relative;z-index:1;}
.cta-strip h2{font-family:var(--font-display);font-size:clamp(56px,10vw,160px);font-weight:400;line-height:.92;letter-spacing:.02em;margin-bottom:32px;}
.cta-strip p{font-family:var(--font-jp-serif);font-size:18px;margin-bottom:48px;max-width:600px;margin-left:auto;margin-right:auto;line-height:2;}
.cta-btn{display:inline-flex;align-items:center;gap:14px;padding:22px 48px;background:var(--ink);color:var(--cream);font-family:var(--font-archivo);font-size:14px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;transition:all .3s;}
.cta-btn::after{content:"→";font-size:18px;transition:transform .25s;}
.cta-btn:hover{background:var(--cream);color:var(--red);}
.cta-btn:hover::after{transform:translateX(6px);}

/* ========= CEO Message ========= */
.ceo-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:64px;align-items:start;max-width:1100px;margin:0 auto;}
@media (max-width:768px){.ceo-grid{grid-template-columns:1fr;gap:32px;}}
.ceo-photo{aspect-ratio:3/4;background:linear-gradient(135deg,var(--ink),var(--ink-soft));position:relative;overflow:hidden;}
.ceo-photo img{width:100%;height:100%;object-fit:cover;}
.ceo-photo.placeholder::after{content:"代表者写真";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-jp);color:rgba(241,236,224,.4);font-size:14px;letter-spacing:.2em;}
.ceo-photo.placeholder::before{content:"";position:absolute;width:75%;aspect-ratio:1;background:var(--red);opacity:.55;border-radius:50%;top:10%;left:13%;}
.ceo-content h2{font-family:var(--font-display);font-size:clamp(40px,5vw,76px);line-height:1;letter-spacing:.02em;margin-bottom:8px;}
.ceo-content .jp{font-family:var(--font-jp-serif);font-size:22px;font-weight:700;margin-bottom:32px;color:var(--ink-soft);}
.ceo-content p{font-family:var(--font-jp-serif);font-size:16px;line-height:2.1;color:var(--ink-soft);margin-bottom:20px;}
.ceo-sign{margin-top:40px;padding-top:24px;border-top:1px solid var(--line);}
.ceo-sign-role{font-family:var(--font-archivo);font-style:italic;font-size:12px;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;margin-bottom:6px;}
.ceo-sign-name{font-family:var(--font-jp-serif);font-size:22px;font-weight:700;}
.ceo-sign-name small{font-family:var(--font-archivo);font-style:italic;font-weight:400;font-size:13px;color:var(--muted);margin-left:8px;letter-spacing:.05em;}

/* ========= Access ========= */
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
@media (max-width:768px){.access-grid{grid-template-columns:1fr;}}
.access-info{background:var(--cream);padding:40px;border-radius:8px;}
.access-info dl{display:flex;flex-direction:column;gap:20px;}
.access-info dt{font-family:var(--font-archivo);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;}
.access-info dd{font-family:var(--font-jp-serif);font-size:16px;font-weight:500;line-height:1.7;}
.map-frame{aspect-ratio:4/3;background:linear-gradient(135deg,var(--blue),#1838a8);border-radius:8px;position:relative;display:flex;align-items:center;justify-content:center;color:rgba(241,236,224,.7);font-family:var(--font-archivo);font-size:13px;letter-spacing:.2em;text-transform:uppercase;overflow:hidden;}
.map-frame iframe{width:100%;height:100%;border:0;}

/* ========= Single Post ========= */
.post-single{max-width:880px;margin:0 auto;padding:160px var(--pad) 120px;}
.post-meta{display:flex;gap:16px;align-items:center;font-family:var(--font-archivo);font-size:12px;color:var(--muted);letter-spacing:.15em;text-transform:uppercase;margin-bottom:24px;}
.post-cat{background:var(--ink);color:var(--cream);padding:4px 10px;}
.post-title{font-family:var(--font-jp-serif);font-weight:700;font-size:clamp(32px,5vw,56px);line-height:1.35;margin-bottom:32px;}
.post-content{font-family:var(--font-jp-serif);font-size:17px;line-height:2;}
.post-content h2{font-family:var(--font-display);font-size:32px;line-height:1.2;margin:48px 0 16px;letter-spacing:.02em;}
.post-content h3{font-family:var(--font-jp-serif);font-weight:700;font-size:22px;margin:32px 0 12px;border-left:4px solid var(--red);padding-left:16px;}
.post-content p{margin-bottom:24px;}
.post-content ul,.post-content ol{margin:0 0 24px 24px;}
.post-content li{margin-bottom:8px;}
.post-content a{color:var(--red);text-decoration:underline;text-underline-offset:4px;}
.post-content blockquote{border-left:4px solid var(--yellow);padding:16px 24px;background:var(--cream-2);margin:32px 0;font-style:italic;}
.post-content img{margin:32px 0;border-radius:6px;}

/* ========= Contact Form ========= */
.form-section{padding:80px var(--pad) 120px;border-top:1px solid var(--line);}
.form-inner{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:64px;}
@media (max-width:900px){.form-inner{grid-template-columns:1fr;gap:48px;}}
.form-side h2{font-family:var(--font-display);font-size:clamp(40px,5vw,72px);line-height:1;letter-spacing:.02em;margin-bottom:24px;}
.form-side .jp{font-family:var(--font-jp-serif);font-size:17px;line-height:2;color:var(--ink-soft);margin-bottom:32px;}
.info-block{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--line);}
.info-block:last-child{border-bottom:none;}
.info-label{font-family:var(--font-archivo);font-style:italic;font-size:11px;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;margin-bottom:8px;}
.info-value{font-family:var(--font-jp-serif);font-size:16px;line-height:1.7;font-weight:500;}
.info-value a{color:var(--red);}
.contact-form-wrap{background:var(--cream-2);padding:48px;border-radius:8px;}
@media (max-width:560px){.contact-form-wrap{padding:32px 24px;}}
.contact-form-wrap .wpcf7-form p{margin-bottom:24px;}
.contact-form-wrap label{display:block;font-family:var(--font-archivo);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);margin-bottom:8px;}
.contact-form-wrap input[type="text"],
.contact-form-wrap input[type="email"],
.contact-form-wrap input[type="tel"],
.contact-form-wrap select,
.contact-form-wrap textarea{
  width:100%;padding:14px 16px;background:var(--cream);
  border:1.5px solid var(--line);
  font-family:var(--font-jp);font-size:15px;color:var(--ink);
  border-radius:4px;transition:border-color .25s;
}
.contact-form-wrap input:focus,
.contact-form-wrap select:focus,
.contact-form-wrap textarea:focus{outline:none;border-color:var(--red);}
.contact-form-wrap textarea{min-height:140px;resize:vertical;}
.contact-form-wrap .wpcf7-submit{
  width:100%;padding:20px;
  background:var(--ink);color:var(--cream);
  font-family:var(--font-archivo);font-size:13px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  cursor:pointer;transition:all .25s;
}
.contact-form-wrap .wpcf7-submit:hover{background:var(--red);}

/* ========= Footer ========= */
.site-footer{background:var(--ink);color:var(--cream);padding:64px var(--pad) 32px;}
.footer-inner{max-width:1320px;margin:0 auto;}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:32px;padding-bottom:32px;border-bottom:1px solid rgba(241,236,224,.15);margin-bottom:24px;}
.footer-brand .brand{font-family:var(--font-display);font-size:32px;color:var(--cream);letter-spacing:.04em;}
.footer-brand .tag{font-family:var(--font-jp-serif);font-size:14px;color:rgba(241,236,224,.6);margin-top:8px;}
.footer-social{display:flex;gap:20px;}
.footer-social a{font-family:var(--font-archivo);font-size:12px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(241,236,224,.7);transition:color .2s;}
.footer-social a:hover{color:var(--yellow);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-family:var(--font-archivo);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:rgba(241,236,224,.5);}

/* ========= Reveal animations ========= */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease;}
.reveal.is-visible{opacity:1;transform:translateY(0);}
.reveal-d1{transition-delay:.1s;}
.reveal-d2{transition-delay:.2s;}
.reveal-d3{transition-delay:.3s;}

/* ========= Pagination ========= */
.pagination{display:flex;justify-content:center;gap:12px;margin-top:64px;}
.pagination a,.pagination span{padding:10px 16px;border:1.5px solid var(--ink);font-family:var(--font-archivo);font-size:13px;font-weight:600;letter-spacing:.1em;transition:all .2s;}
.pagination a:hover,.pagination .current{background:var(--ink);color:var(--cream);}

/* ========= Utilities ========= */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}