/*
Theme Name: MA-JUNCTION
Theme URI: https://ma.undefinedrule.com/
Author: MA-JUNCTION
Description: MA-JUNCTION オリジナルテーマ
Version: 1.2
Text Domain: ma-junction
*/

:root {
  --cream: #F5F0E8; --warm-white: #FAF8F4; --beige: #E8DFD0;
  --sand: #C9B99A; --taupe: #9B8E7E; --stone: #6B6059;
  --charcoal: #2C2826; --black: #1A1714; --accent: #8B7355;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;background:var(--warm-white);color:var(--charcoal);overflow-x:hidden;cursor:none}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

/* CURSOR */
.cursor{width:8px;height:8px;background:var(--charcoal);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transition:transform .15s ease;transform:translate(-50%,-50%)}
.cursor-ring{width:32px;height:32px;border:1px solid var(--taupe);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transition:transform .4s ease,opacity .3s ease;transform:translate(-50%,-50%)}

/* NAV */
#main-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 48px;display:flex;justify-content:space-between;align-items:center;background:rgba(250,248,244,.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(201,185,154,.2)}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-text{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:20px;letter-spacing:.18em;color:var(--charcoal);line-height:1}
.nav-links{display:flex;gap:0;list-style:none;align-items:center}
.nav-links li a{display:flex;align-items:center;padding:8px 0;margin:0 18px;position:relative;overflow:hidden}
.nav-links li a span{font-size:11px;font-weight:300;letter-spacing:.22em;color:var(--stone);text-transform:uppercase;transition:color .3s;display:inline-block;transform:translateX(0);opacity:1}
.nav-links li a:hover span{color:var(--charcoal)}
.nav-links li a::before{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent);transition:width .4s ease}
.nav-links li a:hover::before{width:100%}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-hamburger span{display:block;width:24px;height:1px;background:var(--charcoal);transition:all .3s}
.nav-hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.nav-mobile{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--charcoal);z-index:99;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.nav-mobile.open{opacity:1;pointer-events:all}
.nav-mobile ul{list-style:none;text-align:center}
.nav-mobile ul li{margin-bottom:32px}
.nav-mobile ul a{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:300;color:var(--cream);letter-spacing:.1em}

/* HERO — no animation delay on initial state, content starts visible */
#hero{min-height:100vh;position:relative;overflow:hidden;background:var(--cream);display:flex;align-items:center}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(201,185,154,.3) 0%,transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(155,142,126,.15) 0%,transparent 50%)}
.hero-content{position:relative;z-index:2;padding:0 60px;width:100%;padding-top:76px}
.hero-eyebrow{font-size:11px;font-weight:300;letter-spacing:.35em;color:var(--taupe);text-transform:uppercase;margin-bottom:16px;opacity:0;animation:heroFadeUp 1s cubic-bezier(.22,1,.36,1) .2s forwards}
.hero-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(48px,8vw,110px);line-height:1.05;color:var(--charcoal);margin-bottom:24px}
.hero-char{display:inline-block;opacity:0;transform:translateY(20px);animation:charFadeUp .6s cubic-bezier(.22,1,.36,1) forwards}
@keyframes charFadeUp{to{opacity:1;transform:translateY(0)}}
.hero-sub{max-width:460px;font-size:13px;font-weight:300;line-height:2;color:var(--stone);margin-bottom:36px}
.hero-cta{display:inline-flex;align-items:center;gap:16px;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--charcoal);transition:gap .3s}
.hero-cta:hover{gap:28px}
.hero-cta::after{content:'';display:block;width:60px;height:1px;background:var(--charcoal);transition:width .3s}
.hero-cta:hover::after{width:80px}
.hero-float{position:absolute;right:72px;top:50%;transform:translateY(-50%);writing-mode:vertical-rl;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;letter-spacing:.3em;color:var(--sand);opacity:0;animation:heroFadeIn 1.5s ease 1.4s forwards}
.hero-year{position:absolute;right:52px;bottom:48px;font-size:10px;letter-spacing:.3em;color:var(--taupe);opacity:0;animation:heroFadeIn 1.5s ease 1.6s forwards}

/* SHARED */
.section-label{font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--taupe);margin-bottom:12px}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s ease,transform .9s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.15s}
.reveal-delay-2{transition-delay:.3s}
.reveal-delay-3{transition-delay:.45s}

/* ABOUT */
#about{background:var(--charcoal);color:var(--cream);padding:120px 60px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
#about .section-label{color:var(--sand)}
.about-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(36px,4.5vw,64px);line-height:1.15;margin-bottom:28px;color:var(--cream)}
.about-title em{font-style:italic;color:var(--sand)}
.about-body{font-size:13px;font-weight:300;line-height:2.2;color:var(--beige);margin-bottom:16px}
.about-values{display:flex;flex-direction:column;gap:24px;padding-top:40px;border-top:1px solid rgba(201,185,154,.2)}
.value-item{display:flex;align-items:flex-start;gap:20px;overflow:hidden}
.value-num{font-family:'Cormorant Garamond',serif;font-size:11px;letter-spacing:.2em;color:var(--sand);padding-top:4px;flex-shrink:0}
.value-text{font-size:13px;font-weight:300;line-height:1.9;color:var(--beige)}

/* TICKER */
.philosophy-strip{background:var(--beige);padding:44px 0;overflow:hidden}
.strip-track{display:flex;align-items:center;gap:48px;white-space:nowrap;animation:ticker 30s linear infinite}
.strip-word{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:26px;color:var(--stone);flex-shrink:0;
  opacity:0;transform:translateX(-32px);transition:opacity .55s ease,transform .55s ease}
.philosophy-strip.in-view .strip-word{opacity:1;transform:translateX(0)}
.philosophy-strip.in-view .strip-word:nth-child(4n+1){transition-delay:.0s}
.philosophy-strip.in-view .strip-word:nth-child(4n+3){transition-delay:.08s}
.philosophy-strip.in-view .strip-word:nth-child(4n+5){transition-delay:.16s}
.philosophy-strip.in-view .strip-word:nth-child(4n+7){transition-delay:.24s}
.strip-icon{flex-shrink:0;color:var(--taupe);width:22px;height:22px;vertical-align:middle}

/* BUSINESS */
#business{background:var(--warm-white);padding:120px 60px}
.business-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px}
.business-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(36px,4.5vw,60px);line-height:1.15;color:var(--charcoal)}
.business-title em{font-style:italic;color:var(--accent)}
.business-desc{max-width:280px;font-size:13px;font-weight:300;line-height:2;color:var(--taupe);text-align:right}
/* Grid: always white bg so odd cards don't show beige gap */
.business-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--warm-white)}
.biz-card{background:var(--warm-white);padding:56px 48px;position:relative;overflow:hidden;transition:background .5s;border:1px solid var(--beige)}
.biz-card:hover{background:var(--cream)}
.biz-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--accent);transition:height .5s}
.biz-card:hover::before{height:100%}
/* Last odd card: centered, half-width */
.biz-card--last-odd{grid-column:1 / -1;max-width:calc(50% - 1px);margin:0 auto;width:100%}
.biz-number{font-family:'Cormorant Garamond',serif;font-size:72px;font-weight:300;line-height:1;color:var(--beige);position:absolute;top:36px;right:36px;transition:color .5s}
.biz-card:hover .biz-number{color:var(--sand)}
.biz-tag{font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.biz-name{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;line-height:1.2;color:var(--charcoal);margin-bottom:20px}
.biz-body{font-size:13px;font-weight:300;line-height:2;color:var(--stone);max-width:340px}
.biz-detail{margin-top:28px;padding-top:28px;border-top:1px solid var(--beige)}
.biz-detail-item{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--taupe);margin-bottom:8px}
.biz-detail-item::before{content:'';width:20px;height:1px;background:var(--sand);flex-shrink:0}

/* CONTACT */
#contact{background:var(--cream);text-align:center;padding:140px 60px;position:relative;overflow:hidden}
#contact::before{content:'CONTACT';font-family:'Cormorant Garamond',serif;font-size:clamp(80px,14vw,180px);font-weight:300;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--beige);white-space:nowrap;pointer-events:none;opacity:.5}
.contact-label{color:var(--taupe)}
.contact-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(32px,4.5vw,56px);line-height:1.2;color:var(--charcoal);margin:16px 0 20px;position:relative}
.contact-sub{font-size:13px;font-weight:300;line-height:2;color:var(--taupe);margin-bottom:48px;position:relative}
.contact-btn{display:inline-block;padding:18px 56px;border:1px solid var(--charcoal);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--charcoal);position:relative;overflow:hidden;transition:color .4s}
.contact-btn::before{content:'';position:absolute;inset:0;background:var(--charcoal);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.contact-btn:hover{color:var(--cream)}
.contact-btn:hover::before{transform:scaleX(1)}
.contact-btn span{position:relative;z-index:1}
.contact-tel{margin-top:24px;font-size:12px;letter-spacing:.15em;color:var(--taupe);position:relative}
.contact-tel a{color:var(--taupe)}

/* FOOTER */
#main-footer{background:var(--black);padding:36px 60px;display:flex;justify-content:space-between;align-items:center}
.footer-logo{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:18px;letter-spacing:.15em;color:var(--sand)}
.footer-copy{font-size:11px;letter-spacing:.1em;color:var(--stone)}

/* COMPANY PAGE */
.company-page{background:var(--warm-white);min-height:100vh;padding:160px 60px 120px}
.company-page-inner{max-width:900px;margin:0 auto}
.company-page .section-label{color:var(--taupe)}
.company-page-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(28px,7vw,72px);line-height:1.1;color:var(--charcoal);margin-bottom:64px}
.company-page-title em{font-style:italic;color:var(--accent)}
.company-table{width:100%;border-collapse:collapse}
.company-table tr{border-bottom:1px solid var(--beige)}
.company-table th{font-size:11px;font-weight:300;letter-spacing:.15em;color:var(--taupe);padding:24px 0;width:30%;text-align:left;vertical-align:top}
.company-table td{font-size:14px;font-weight:300;color:var(--charcoal);padding:24px 0;line-height:1.9}
.company-table a{color:var(--accent);border-bottom:1px solid rgba(139,115,85,.3);transition:border-color .3s}
.company-table a:hover{border-color:var(--accent)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroFadeIn{from{opacity:0}to{opacity:1}}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* MOBILE */
@media(max-width:768px){
  body{cursor:auto;overflow-x:hidden}
  .cursor,.cursor-ring{display:none}
  #main-nav{padding:16px 20px}
  .nav-links{display:none}
  .nav-hamburger{display:flex}

  /* HERO */
  .hero-content{padding:0 20px;padding-top:80px}
  .hero-eyebrow{font-size:10px;letter-spacing:.25em}
  .hero-float,.hero-year{display:none}

  /* HOME ABOUT */
  #about{grid-template-columns:1fr;gap:40px;padding:72px 20px}

  /* HOME BUSINESS */
  #business{padding:72px 20px}
  .business-header{flex-direction:column;align-items:flex-start;gap:16px}
  .business-desc{text-align:left;max-width:100%}
  .business-grid{grid-template-columns:1fr}
  .biz-card{padding:32px 20px}
  .biz-card--last-odd{max-width:100%;grid-column:auto}
  .biz-name{font-size:22px}
  .biz-number{font-size:48px;top:16px;right:16px}

  /* CONTACT */
  #contact{padding:80px 20px}

  /* FOOTER */
  #main-footer{flex-direction:column;gap:12px;text-align:center;padding:32px 20px}

  /* COMPANY PAGE */
  .company-page{padding:100px 20px 80px}
  .company-page-inner{width:100%;max-width:100%}
  .company-page-title{font-size:clamp(24px,10vw,48px);word-break:keep-all;overflow-wrap:break-word}
  .company-table{width:100%}
  .company-table tr{display:flex;flex-direction:column;padding:16px 0;border-bottom:1px solid var(--beige)}
  .company-table th{width:100%;padding:0 0 6px 0;font-size:10px}
  .company-table td{padding:0;word-break:break-all}

  /* INNER PAGES (About / Business) */
  .inner-page{padding:100px 20px 80px;overflow-x:hidden}
  .inner-page-inner{width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}
  .inner-page-title{font-size:clamp(22px,8vw,40px);word-break:keep-all;overflow-wrap:break-word;margin-bottom:28px}
  .inner-page-sub{max-width:100%;font-size:13px}

  /* ABOUT PAGE */
  .about-page-grid{grid-template-columns:1fr;gap:36px}
  .about-page-values{gap:16px}
  .value-item{gap:12px}
  .value-text{font-size:13px;word-break:break-all}
}

/* CONTACT PAGE */
.contact-page{background:var(--warm-white);min-height:100vh;padding:160px 60px 120px}
.contact-page-inner{max-width:1100px;margin:0 auto}
.contact-page-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(36px,5vw,68px);line-height:1.1;color:var(--charcoal);margin-bottom:16px}
.contact-page-title em{font-style:italic;color:var(--accent)}
.contact-page-sub{font-size:13px;font-weight:300;line-height:2;color:var(--taupe);margin-bottom:64px;max-width:600px}
.contact-page-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:40px}
.contact-info-item{}
.contact-info-label{font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--taupe);margin-bottom:8px}
.contact-info-value{font-size:14px;font-weight:300;color:var(--charcoal);line-height:1.9}
.contact-info-value a{color:var(--accent);border-bottom:1px solid rgba(139,115,85,.3);transition:border-color .3s}
.contact-info-value a:hover{border-color:var(--accent)}
.contact-form-wrap .wpcf7-form{display:flex;flex-direction:column;gap:0}
.contact-form-wrap .wpcf7-form p{margin-bottom:24px}
.contact-form-wrap label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--taupe);display:block;margin-bottom:8px}
.contact-form-wrap input[type=text],
.contact-form-wrap input[type=email],
.contact-form-wrap input[type=tel],
.contact-form-wrap textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--beige);padding:12px 0;font-family:'Noto Sans JP',sans-serif;font-size:14px;font-weight:300;color:var(--charcoal);outline:none;transition:border-color .3s;border-radius:0}
.contact-form-wrap input:focus,
.contact-form-wrap textarea:focus{border-bottom-color:var(--accent)}
.contact-form-wrap textarea{min-height:140px;resize:vertical}
.contact-form-wrap input[type=submit]{margin-top:16px;padding:18px 56px;background:transparent;border:1px solid var(--charcoal);font-family:'Noto Sans JP',sans-serif;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--charcoal);cursor:pointer;transition:background .4s,color .4s;align-self:flex-start}
.contact-form-wrap input[type=submit]:hover{background:var(--charcoal);color:var(--cream)}
.contact-form-notice{background:var(--cream);border:1px solid var(--beige);padding:32px;font-size:13px;font-weight:300;color:var(--stone);line-height:2}
@media(max-width:768px){
  .contact-page{padding:120px 24px 80px}
  .contact-page-grid{grid-template-columns:1fr;gap:48px}
}

/* INNER PAGES (About / Business 固定ページ共通) */
.inner-page{background:var(--warm-white);min-height:100vh;padding:160px 60px 120px}
.inner-page-inner{max-width:900px;margin:0 auto}
.inner-page-inner--wide{max-width:1100px}
.inner-page-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(22px,5vw,72px);line-height:1.1;color:var(--charcoal);margin-bottom:48px}
.inner-page-title em{font-style:italic;color:var(--accent)}
.inner-page-sub{font-size:13px;font-weight:300;line-height:2;color:var(--taupe);margin-bottom:64px;max-width:600px}

/* About page */
.about-page-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.about-page-text{font-size:14px;font-weight:300;line-height:2.3;color:var(--stone);margin-bottom:24px}
.about-page-values{display:flex;flex-direction:column;gap:28px;padding-top:8px}

/* Business page — reuse existing .business-grid / .biz-card styles */
.inner-page .business-grid{margin-top:0}

/* 固定ページではrevealアニメーションを無効化して即表示 */
.inner-page .biz-card,
.inner-page .biz-card.reveal,
.inner-page .reveal {
  opacity: 1 !important;
  transform: none !important;
}

/* INNER PAGES モバイル上書き（必ずファイル末尾に配置） */
@media(max-width:768px){
  .inner-page{padding:100px 20px 80px;overflow-x:hidden}
  .inner-page-inner{width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}
  .inner-page-title{font-size:clamp(22px,8vw,36px) !important;word-break:keep-all;overflow-wrap:break-word;margin-bottom:24px}
  .inner-page-sub{max-width:100%}
  .about-page-grid{grid-template-columns:1fr;gap:36px}
  .about-page-values{gap:16px}
  .value-item{gap:12px}
  .value-text{word-break:break-all}
  .business-title{font-size:clamp(22px,8vw,36px) !important;word-break:keep-all;overflow-wrap:break-word}
}
