/*
Theme Name: Trinity Leap
Theme URI: https://trinityleap.com/
Author: Trinity Leap
Author URI: https://trinityleap.com/
Description: Trinity Leap 公式WordPressテーマ。音楽・映像・AI・アプリ開発を横断するクリエイティブテックブランド向け。カスタマイザー対応、Contact Form 7対応。
Version: 1.0.1
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: trinity-leap
Tags: business, portfolio, one-column, custom-colors, custom-logo, custom-menu, featured-images, theme-options, threaded-comments, translation-ready
*/

/* ================================================================
   CSS VARIABLES (Trinity Leap design system)
   ================================================================ */
:root{
  --bg:#FCFEF7;
  --bg-2:#F1F8DC;
  --bg-3:#F8FCEB;
  --ink:#1A2014;
  --ink-2:#3D4530;
  --muted:#7B8270;
  --line:rgba(26,32,20,.08);
  --line-strong:rgba(26,32,20,.18);

  --dark-bg:#1A2614;
  --dark-text:#EAF0DD;
  --dark-muted:#8B9580;
  --dark-line:rgba(255,255,255,.1);

  --lime:#9ED430;
  --lime-deep:#6FA612;
  --lime-darker:#4F7A08;
  --lime-soft:#E8F4C8;
  --lime-softer:#F4FAE0;

  --sky:#5DD3E8;
  --sky-deep:#2BB5CC;
  --sky-soft:#E5F6FA;

  --brand-grad:linear-gradient(90deg,#6FA612 0%,#9ED430 60%,#C5E670 100%);

  --en:'Inter', sans-serif;
  --jp:'Noto Sans JP', sans-serif;
  --mono:'JetBrains Mono', monospace;
}

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

/* WordPress required */
.alignleft{float:left;margin-right:1em;}
.alignright{float:right;margin-left:1em;}
.aligncenter{display:block;margin-left:auto;margin-right:auto;}
.screen-reader-text{
  border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);
  height:1px;margin:-1px;overflow:hidden;padding:0;
  position:absolute !important;width:1px;word-wrap:normal !important;
}
.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{
  position:fixed;top:1rem;left:1rem;
  width:auto;height:auto;padding:.7rem 1rem;
  background:var(--ink);color:#fff;z-index:9999;
}

/* ================================================================
   HEADER
   ================================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem;
  padding:1.1rem 2.5rem;
  background:rgba(252,254,247,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.site-logo{
  display:flex;align-items:center;gap:.7rem;
  font-family:var(--en);font-weight:600;font-size:1.05rem;
  color:var(--ink);
}
.site-logo-img{height:38px;width:auto;display:block;}
.site-logo-text{font-family:var(--en);font-weight:600;font-size:1.05rem;}

.nav-main{
  display:flex;justify-content:center;gap:2.2rem;
  font-size:.85rem;font-weight:500;font-family:var(--en);
  list-style:none;
}
.nav-main a{position:relative;padding:.3rem 0;color:var(--ink-2);transition:color .2s;letter-spacing:.02em;}
.nav-main a:hover, .nav-main .current-menu-item a, .nav-main .current_page_item a{color:var(--sky-deep);}
.nav-main a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--brand-grad);transition:width .3s;}
.nav-main a:hover::after, .nav-main .current-menu-item a::after, .nav-main .current_page_item a::after{width:100%;}

.nav-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.65rem 1.2rem;
  background:var(--brand-grad);background-size:200% auto;background-position:left center;
  color:#fff;border-radius:6px;
  font-family:var(--en);font-size:.78rem;font-weight:500;letter-spacing:.05em;
  transition:all .3s;
}
.nav-cta:hover{background-position:right center;transform:translateY(-1px);box-shadow:0 6px 18px rgba(111,166,18,.3);}
.nav-cta::after{content:'→';font-family:var(--mono);}

@media(max-width:980px){
  .site-header{grid-template-columns:auto auto;padding:1rem 1.2rem;}
  .nav-main{display:none;}
  .nav-cta{padding:.55rem 1rem;font-size:.72rem;}
}

/* ================================================================
   HERO
   ================================================================ */
.hero{
  position:relative;min-height:100vh;
  padding:9rem 2.5rem 6rem;
  display:flex;align-items:center;
  background:var(--bg);overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(900px 500px at 90% 15%, rgba(158,212,48,.20), transparent 60%),
    radial-gradient(500px 320px at 8% 75%, rgba(93,211,232,.12), transparent 65%);
}
.hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(26,32,20,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26,32,20,.025) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 40%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 40%, #000 30%, transparent 80%);
}
.hero-inner{max-width:1280px;margin:0 auto;width:100%;position:relative;z-index:2;}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;color:var(--ink-2);text-transform:uppercase;
  margin-bottom:2rem;padding:.4rem .8rem;
  border:1px solid var(--line-strong);border-radius:100px;
  background:rgba(255,255,255,.5);
}
.hero-eyebrow .dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--sky);box-shadow:0 0 10px var(--sky);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}

.hero-en{font-family:var(--en);font-weight:500;font-size:clamp(1rem,1.4vw,1.2rem);letter-spacing:.01em;color:var(--ink-2);margin-bottom:1.5rem;}
.hero-en .x{
  background:linear-gradient(90deg,var(--sky-deep) 0%,var(--lime-deep) 50%,var(--lime) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700;
}
.hero-h1{
  font-family:var(--jp);font-weight:900;
  font-size:clamp(2.4rem,5.5vw,5.2rem);
  line-height:1.25;letter-spacing:-.01em;color:var(--ink);
  margin-bottom:2rem;max-width:1100px;
}
.hero-h1 .grad{
  background:linear-gradient(90deg,var(--sky-deep) 0%,var(--lime-deep) 45%,var(--lime) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-lede{font-size:1.05rem;line-height:2;color:var(--ink-2);max-width:680px;margin-bottom:3rem;}

.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:5rem;}
.btn-primary, .btn-ghost{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1rem 1.6rem;
  font-family:var(--en);font-size:.85rem;font-weight:500;letter-spacing:.03em;
  border-radius:8px;transition:all .3s;
}
.btn-primary{background:var(--brand-grad);background-size:200% auto;background-position:left center;color:#fff;border:none;}
.btn-primary:hover{background-position:right center;transform:translateY(-2px);box-shadow:0 10px 28px rgba(111,166,18,.28);}
.btn-ghost{border:1px solid var(--line-strong);color:var(--ink);background:rgba(255,255,255,.7);}
.btn-ghost:hover{background:var(--bg);border-color:var(--lime-deep);color:var(--lime-darker);}
.btn-primary::after, .btn-ghost::after{content:'→';font-family:var(--mono);}

.hero-meta{
  display:grid;grid-template-columns:repeat(3,auto);gap:0;
  border-top:1px solid var(--line);padding-top:2rem;max-width:780px;
}
.hero-meta div{padding-right:3rem;}
.hero-meta div + div{padding-left:3rem;border-left:1px solid var(--line);}
.hero-meta b{display:block;font-family:var(--en);font-weight:500;font-size:.95rem;color:var(--ink);margin-bottom:.3rem;}
.hero-meta span{font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;}
@media(max-width:780px){
  .hero-meta{grid-template-columns:1fr;}
  .hero-meta div{padding:1rem 0;border-left:none !important;border-bottom:1px solid var(--line);}
  .hero-meta div:last-child{border-bottom:none;}
}

.scroll-cue{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:.65rem;letter-spacing:.3em;color:var(--muted);text-transform:uppercase;z-index:3;
}
.scroll-cue::after{
  content:'';display:block;width:1px;height:36px;
  background:linear-gradient(180deg,var(--muted),transparent);
  margin:.7rem auto 0;
}

/* ================================================================
   SECTION SHELL
   ================================================================ */
section{padding:7rem 2.5rem;position:relative;}
.container{max-width:1280px;margin:0 auto;}
.sec-head{display:grid;grid-template-columns:auto 1fr auto;gap:3rem;align-items:end;margin-bottom:4rem;}
.sec-eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--sky-deep);text-transform:uppercase;margin-bottom:.7rem;}
.sec-title-block .sec-en{font-family:var(--en);font-weight:500;font-size:.95rem;letter-spacing:.05em;color:var(--muted);margin-bottom:.4rem;}
.sec-title-block h2{font-family:var(--jp);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.6rem);line-height:1.4;letter-spacing:.01em;}
.sec-action{font-family:var(--en);font-size:.82rem;letter-spacing:.05em;font-weight:500;padding-bottom:.3rem;border-bottom:1px solid currentColor;transition:color .2s;}
.sec-action:hover{color:var(--sky-deep);}
@media(max-width:780px){.sec-head{grid-template-columns:1fr;gap:1rem;}.sec-action{justify-self:start;}}

section.light-2{background:var(--bg-2);}

/* ================================================================
   ABOUT
   ================================================================ */
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:5rem;align-items:start;}
.about-lead{font-size:clamp(1.2rem,1.8vw,1.5rem);font-weight:500;line-height:1.85;color:var(--ink);margin-bottom:2rem;}
.about-lead .grad-text{
  background:linear-gradient(90deg,var(--sky-deep) 0%,var(--lime-deep) 50%,var(--lime) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700;
}
.about-side p{font-size:.95rem;line-height:2;color:var(--ink-2);margin-bottom:1.2rem;}
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);margin-top:3rem;padding-top:2rem;}
.about-stats div{padding-right:1.5rem;}
.about-stats div + div{border-left:1px solid var(--line);padding-left:1.5rem;}
.about-stats b{display:block;font-family:var(--en);font-weight:600;font-size:2rem;line-height:1;color:var(--sky-deep);margin-bottom:.5rem;}
.about-stats span{font-family:var(--mono);font-size:.68rem;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;}
@media(max-width:980px){
  .about-grid{grid-template-columns:1fr;gap:2.5rem;}
  .about-stats{grid-template-columns:1fr 1fr;}
  .about-stats div:nth-child(3){border-left:none;padding-left:0;}
}
@media(max-width:580px){
  .about-stats{grid-template-columns:1fr;}
  .about-stats div + div{border-left:none;padding-left:0;border-top:1px solid var(--line);padding-top:1.2rem;margin-top:1.2rem;}
}

/* ================================================================
   BUSINESS
   ================================================================ */
.biz-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);border-left:1px solid var(--line);
}
.biz-card{
  padding:2.5rem 2rem;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg);transition:background .3s ease;
  position:relative;overflow:hidden;
}
.biz-card::before{
  content:'';position:absolute;top:0;left:0;width:0;height:2px;
  background:var(--brand-grad);transition:width .4s ease;
}
.biz-card:hover::before{width:100%;}
.biz-card:hover{background:var(--bg-2);}
.biz-num{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--sky-deep);margin-bottom:1.2rem;display:block;}
.biz-en{font-family:var(--en);font-weight:600;font-size:1.05rem;color:var(--ink);margin-bottom:.3rem;}
.biz-card h3{font-family:var(--jp);font-weight:700;font-size:1.2rem;margin-bottom:1rem;line-height:1.5;}
.biz-card p{font-size:.88rem;line-height:1.85;color:var(--ink-2);}
@media(max-width:980px){.biz-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:580px){.biz-grid{grid-template-columns:1fr;}}

/* ================================================================
   PRODUCT (KuroBuddy compact)
   ================================================================ */
.product-section{
  background:var(--bg);position:relative;overflow:hidden;
}
.product-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(900px 500px at 80% 30%, rgba(158,212,48,.10), transparent 70%);
}
.prod-card{
  display:grid;grid-template-columns:120px 1fr;gap:2.5rem;align-items:center;
  padding:2.5rem;background:var(--bg-2);
  border:1px solid var(--line);border-radius:12px;
  position:relative;z-index:1;transition:border-color .3s,background .3s;
}
.prod-card:hover{border-color:rgba(158,212,48,.5);}
.prod-card-icon{
  width:120px;height:120px;border-radius:24px;overflow:hidden;
  background:#fff;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
}
.prod-card-icon img{width:100%;height:100%;object-fit:cover;}
.prod-card-tag{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.15em;color:var(--sky-deep);text-transform:uppercase;
  margin-bottom:1rem;
}
.prod-card-tag .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--sky);box-shadow:0 0 8px var(--sky);animation:pulse 2s ease-in-out infinite;}
.prod-card-name{
  font-family:var(--en);font-weight:700;font-size:clamp(1.8rem,3.2vw,2.6rem);
  line-height:1;letter-spacing:-.01em;margin-bottom:.6rem;
  display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap;
}
.prod-card-name .grad{
  background:linear-gradient(90deg,var(--sky-deep),var(--lime-deep) 50%,var(--lime));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.prod-card-name small{font-family:var(--jp);font-weight:500;font-size:.95rem;color:var(--ink-2);letter-spacing:.05em;}
.prod-card-desc{font-size:.95rem;line-height:1.9;color:var(--ink-2);margin-bottom:1.6rem;max-width:680px;}
.prod-card-actions{display:flex;gap:.8rem;flex-wrap:wrap;}
.prod-card-actions .btn-primary, .prod-card-actions .btn-ghost{padding:.8rem 1.4rem;font-size:.8rem;}

.prod-future{
  margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--line);
  display:grid;grid-template-columns:auto 1fr;gap:3rem;align-items:start;
  position:relative;z-index:1;
}
.prod-future-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--sky-deep);text-transform:uppercase;white-space:nowrap;}
.prod-future p{font-size:.92rem;line-height:1.95;color:var(--ink-2);max-width:780px;}

@media(max-width:780px){
  .prod-card{grid-template-columns:1fr;gap:1.5rem;padding:2rem;}
  .prod-card-icon{width:80px;height:80px;border-radius:18px;}
  .prod-future{grid-template-columns:1fr;gap:1rem;}
}

/* ================================================================
   VISION
   ================================================================ */
.vision{padding:9rem 2.5rem;}
.vision-inner{max-width:980px;margin:0 auto;text-align:center;}
.vision-eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--sky-deep);text-transform:uppercase;margin-bottom:1.5rem;}
.vision-h2{font-family:var(--jp);font-weight:700;font-size:clamp(1.8rem,3.6vw,2.8rem);line-height:1.5;margin-bottom:2.5rem;}
.vision-h2 .grad{
  background:linear-gradient(90deg,var(--sky-deep) 0%,var(--lime-deep) 50%,var(--lime) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.vision-inner p{font-size:1.05rem;line-height:2;color:var(--ink-2);margin-bottom:1.4rem;text-align:left;}
.vision-inner p:last-child{margin-bottom:0;}

/* ================================================================
   NEWS / WORKS
   ================================================================ */
.news-list{border-top:1px solid var(--line);}
.news-row{
  display:grid;grid-template-columns:130px 110px 1fr auto;
  gap:1.5rem;align-items:center;
  padding:1.4rem .5rem;
  border-bottom:1px solid var(--line);
  transition:padding .3s,background .3s;cursor:pointer;
  color:inherit;
}
.news-row:hover{padding-left:1.5rem;background:var(--bg-2);}
.news-date{font-family:var(--mono);font-size:.78rem;color:var(--muted);letter-spacing:.05em;}
.news-tag{font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;padding:.3rem .6rem;border-radius:4px;text-align:center;justify-self:start;font-weight:500;}
.news-tag.tag-music{background:rgba(158,212,48,.22);color:var(--lime-deep);}
.news-tag.tag-video{background:rgba(111,166,18,.14);color:var(--lime-darker);}
.news-tag.tag-product{background:var(--sky-soft);color:var(--sky-deep);}
.news-tag.tag-news{background:rgba(123,130,112,.15);color:var(--muted);}
.news-title{font-size:.95rem;color:var(--ink);font-weight:500;}
.news-arrow{font-family:var(--mono);color:var(--muted);}
.news-row:hover .news-arrow{color:var(--sky-deep);}
@media(max-width:780px){.news-row{grid-template-columns:90px 1fr auto;gap:1rem;}.news-tag{display:none;}}

/* ================================================================
   CONTACT (top page CTA block)
   ================================================================ */
.contact{
  padding:8rem 2.5rem;background:var(--bg);
  position:relative;overflow:hidden;
}
.contact::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(700px 400px at 15% 30%, rgba(158,212,48,.14), transparent 65%),radial-gradient(500px 320px at 85% 70%, rgba(93,211,232,.10), transparent 65%);
}
.contact-cta{max-width:880px;margin:0 auto;text-align:center;position:relative;z-index:1;}
.contact-cta .contact-eyebrow{margin-bottom:1.2rem;}
.contact-eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--sky-deep);text-transform:uppercase;margin-bottom:1.5rem;}
.contact-cta h2{font-family:var(--jp);font-weight:700;font-size:clamp(2rem,4vw,3rem);line-height:1.4;color:var(--ink);margin-bottom:1.2rem;}
.contact-cta p{font-size:1rem;line-height:1.95;color:var(--ink-2);margin:0 auto 2.5rem;max-width:680px;}
.contact-cta-btn{
  display:inline-flex;align-items:center;justify-content:space-between;gap:2rem;
  padding:1.4rem 2rem;min-width:340px;
  background:var(--brand-grad);background-size:200% auto;background-position:left center;
  color:#fff;border-radius:10px;
  font-family:var(--jp);font-weight:700;font-size:1.05rem;
  transition:all .3s;box-shadow:0 8px 24px rgba(111,166,18,.18);
}
.contact-cta-btn:hover{background-position:right center;transform:translateY(-3px);box-shadow:0 14px 36px rgba(111,166,18,.3);}
.contact-cta-btn .arr{font-family:var(--mono);font-size:1.3rem;}
.contact-cta-meta{display:flex;justify-content:center;margin-top:3.5rem;padding-top:2rem;border-top:1px solid var(--line);}
.contact-cta-meta div{padding:0 2.5rem;text-align:left;}
.contact-cta-meta div + div{border-left:1px solid var(--line);}
.contact-cta-meta .meta-label{display:block;font-family:var(--mono);font-size:.65rem;letter-spacing:.18em;color:var(--sky-deep);text-transform:uppercase;margin-bottom:.4rem;}
.contact-cta-meta .meta-value{font-size:.9rem;color:var(--ink);font-weight:500;}
@media(max-width:680px){
  .contact-cta-btn{min-width:0;width:100%;}
  .contact-cta-meta{flex-direction:column;}
  .contact-cta-meta div{padding:1.2rem 0;border-left:none !important;border-bottom:1px solid var(--line);}
  .contact-cta-meta div:last-child{border-bottom:none;}
}

/* ================================================================
   PAGE HEAD (lower pages: about, business, etc.)
   ================================================================ */
.page-head{
  padding:8rem 2.5rem 3rem;border-bottom:1px solid var(--line);
  background:var(--bg);position:relative;overflow:hidden;
}
.page-head::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(700px 350px at 90% -20%, rgba(158,212,48,.18), transparent 60%),
    radial-gradient(400px 250px at 5% 110%, rgba(93,211,232,.10), transparent 65%);
}
.page-head-inner{max-width:1100px;margin:0 auto;position:relative;z-index:1;}
.breadcrumb{display:flex;align-items:center;gap:.6rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;margin-bottom:1.5rem;flex-wrap:wrap;}
.breadcrumb a{color:var(--muted);transition:color .2s;}
.breadcrumb a:hover{color:var(--sky-deep);}
.breadcrumb span.current{color:var(--ink);}
.page-eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--sky-deep);text-transform:uppercase;margin-bottom:1rem;}
.page-title{font-family:var(--jp);font-weight:900;font-size:clamp(2.4rem,5vw,4rem);line-height:1.2;color:var(--ink);margin-bottom:1.2rem;}
.page-title .grad{
  background:linear-gradient(90deg,var(--sky-deep) 0%,var(--lime-deep) 50%,var(--lime) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.page-lead{font-size:1rem;line-height:1.95;color:var(--ink-2);max-width:680px;}

/* ================================================================
   GENERIC PAGE / ARTICLE CONTENT
   ================================================================ */
.page-content-wrap{padding:4rem 2.5rem 6rem;background:var(--bg);}
.page-content{max-width:880px;margin:0 auto;}
.page-content h2{font-family:var(--jp);font-weight:700;font-size:1.8rem;margin:3rem 0 1.2rem;line-height:1.5;}
.page-content h2:first-child{margin-top:0;}
.page-content h3{font-family:var(--jp);font-weight:700;font-size:1.3rem;margin:2.5rem 0 .8rem;line-height:1.6;}
.page-content p{font-size:1rem;line-height:2;color:var(--ink-2);margin-bottom:1.4rem;}
.page-content ul, .page-content ol{margin:1rem 0 1.5rem 1.5rem;line-height:2;color:var(--ink-2);}
.page-content li{margin-bottom:.4rem;}
.page-content a{color:var(--sky-deep);text-decoration:underline;text-underline-offset:3px;}
.page-content a:hover{color:var(--lime-deep);}
.page-content blockquote{border-left:3px solid var(--lime);padding:.8rem 0 .8rem 1.5rem;margin:1.8rem 0;font-style:italic;color:var(--ink-2);}
.page-content table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.93rem;}
.page-content th, .page-content td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--line);}
.page-content th{font-family:var(--mono);font-size:.72rem;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;font-weight:500;background:var(--bg-2);}

/* ================================================================
   CONTACT FORM (Contact Form 7 styling overrides)
   ================================================================ */
.contact-form-wrap{padding:5rem 2.5rem 6rem;background:var(--bg-2);}
.contact-form-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:start;}
@media(max-width:980px){.contact-form-grid{grid-template-columns:1fr;gap:2.5rem;}}

.form-side h3{font-family:var(--jp);font-weight:700;font-size:1.3rem;line-height:1.5;margin-bottom:1.2rem;}
.form-side > p{font-size:.92rem;line-height:1.95;color:var(--ink-2);margin-bottom:1.5rem;}
.side-list{list-style:none;border-top:1px solid var(--line);}
.side-list li{padding:1rem 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start;}
.side-list li .num{font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;color:var(--sky-deep);text-transform:uppercase;padding-top:.15rem;}
.side-list li b{display:block;font-weight:500;font-size:.95rem;margin-bottom:.2rem;color:var(--ink);}
.side-list li span{font-size:.82rem;color:var(--muted);line-height:1.7;}

.side-notes{margin-top:2rem;padding:1.4rem;background:var(--lime-softer);border:1px solid rgba(158,212,48,.3);border-radius:8px;}
.side-notes h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;color:var(--lime-darker);text-transform:uppercase;margin-bottom:.8rem;}
.side-notes ul{list-style:none;display:flex;flex-direction:column;gap:.5rem;}
.side-notes li{font-size:.82rem;color:var(--ink-2);line-height:1.7;padding-left:1.1rem;position:relative;}
.side-notes li::before{content:'—';position:absolute;left:0;color:var(--lime-deep);}

/* CF7 form styling */
.contact-form-area{
  padding:2.5rem;background:var(--bg);
  border:1px solid var(--line);border-radius:12px;
  box-shadow:0 6px 30px rgba(26,32,20,.04);
}
.wpcf7-form p{margin-bottom:1.4rem;}
.wpcf7-form label{display:flex;flex-direction:column;gap:.5rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-2);font-weight:500;}
.wpcf7-form label .req{color:var(--sky-deep);font-style:normal;margin-left:.2rem;}
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form textarea,
.wpcf7-form select{
  width:100%;padding:.85rem 1rem;
  font-family:var(--jp);font-size:.95rem;color:var(--ink);
  background:var(--bg);border:1px solid var(--line-strong);border-radius:6px;
  transition:border-color .2s,box-shadow .2s;
  -webkit-appearance:none;appearance:none;
}
.wpcf7-form input:focus, .wpcf7-form textarea:focus, .wpcf7-form select:focus{
  outline:none;border-color:var(--lime-deep);box-shadow:0 0 0 3px rgba(158,212,48,.18);
}
.wpcf7-form textarea{resize:vertical;min-height:160px;font-family:var(--jp);line-height:1.7;}
.wpcf7-form input[type="checkbox"]{width:18px;height:18px;accent-color:var(--lime-deep);cursor:pointer;}
.wpcf7-form .wpcf7-list-item{display:inline-flex;align-items:center;gap:.5rem;margin:0 1rem 0 0;font-family:var(--jp);font-size:.88rem;text-transform:none;letter-spacing:0;}
.wpcf7-form input[type="submit"]{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:1.1rem 2rem;
  background:var(--brand-grad);background-size:200% auto;background-position:left center;
  color:#fff;border:none;border-radius:8px;
  font-family:var(--jp);font-weight:700;font-size:1rem;letter-spacing:.05em;
  cursor:pointer;transition:all .3s;width:auto;
}
.wpcf7-form input[type="submit"]:hover{background-position:right center;transform:translateY(-2px);box-shadow:0 10px 28px rgba(111,166,18,.28);}
.wpcf7 form .wpcf7-response-output{
  margin:1rem 0 0;padding:1rem 1.2rem;border-radius:6px;
  font-size:.88rem;line-height:1.6;
  border:1px solid;
}
.wpcf7 form.sent .wpcf7-response-output{background:var(--lime-soft);color:var(--lime-darker);border-color:rgba(158,212,48,.4);}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.failed .wpcf7-response-output{background:#FDECEC;color:#A01818;border-color:#F4B8B8;}
.wpcf7-not-valid-tip{color:#A01818;font-family:var(--jp);font-size:.78rem;letter-spacing:0;text-transform:none;font-weight:400;margin-top:.3rem;}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{
  background:var(--dark-bg);color:var(--dark-text);
  padding:4rem 2.5rem 2rem;position:relative;
}
.site-footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--brand-grad);
}
.foot-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem;}
.foot-brand{display:flex;align-items:center;gap:.7rem;color:var(--dark-text);font-family:var(--en);font-weight:600;font-size:1.1rem;margin-bottom:1rem;}
.foot-logo-img{height:48px;width:auto;display:block;background:#fff;padding:.5rem .8rem;border-radius:8px;}
.foot-tag{font-size:.85rem;line-height:1.85;max-width:340px;color:var(--dark-text);opacity:.7;}
.foot-status{margin-top:1rem;padding:.4rem .7rem;background:rgba(158,212,48,.08);border:1px solid rgba(158,212,48,.25);border-radius:4px;font-family:var(--mono);font-size:.65rem;letter-spacing:.15em;color:var(--lime);display:inline-block;}
.foot-col h5{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dark-text);margin-bottom:1.2rem;}
.foot-col ul{list-style:none;}
.foot-col a{display:block;color:rgba(234,240,221,.6);font-size:.88rem;padding:.32rem 0;transition:color .2s;}
.foot-col a:hover{color:var(--lime);}
.foot-bottom{max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:1px solid var(--dark-line);font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;color:var(--dark-muted);}
.foot-legal{display:flex;gap:1.5rem;list-style:none;}
.foot-legal a{color:var(--dark-muted);}
.foot-legal a:hover{color:var(--lime);}
@media(max-width:780px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem;}
  .foot-bottom{flex-direction:column;gap:1rem;text-align:center;}
  .foot-legal{flex-wrap:wrap;justify-content:center;}
}

/* ================================================================
   REVEAL ANIMATION
   ================================================================ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 1s ease,transform 1s ease;}
.reveal.in{opacity:1;transform:translateY(0);}
