/*
Theme Name: Cocoon Child
Template: cocoon-master
*/

/* ═══ HICHIKU — COMMON STYLESHEET ═══ */
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;700&family=Noto+Serif+JP:wght@300;400;500&family=Outfit:wght@200;300;400;500;600;700&display=swap');

:root {
  --navy:      #0c1827;
  --navy-mid:  #132235;
  --navy-2:    #002d5a;
  --gold:      #c9a55a;
  --gold-lt:   #e4c07a;
  --cream:     #f5f1ec;
  --cream-2:   #ede7df;
  --white:     #ffffff;
  --text:      #1c1c1c;
  --text-mid:  #555;
  --ease:      cubic-bezier(.25,.46,.45,.94);
  --ease2:     cubic-bezier(.77,0,.175,1);
  --fs-serif:  'Shippori Mincho','Yu Mincho',serif;
  --fs-body:   'Noto Serif JP','Yu Mincho',serif;
  --fs-sans:   'Outfit',sans-serif;
}

/* ── RESET（Cocoon の全スタイルを無効化） ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--fs-body);color:var(--text);overflow-x:hidden;background:#fff}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* Cocoon の不要な出力を非表示 */
#wpadminbar{display:none!important}
.entry-title,.breadcrumb-navi,.sns-share,.related-entry-heading,.comment-title,
.footer-wrapper,.navi-footer,.site-header,.header-container,
.global-nav,.sidebar,.widget,.cocoon-block-shortcode{display:none!important}
#container,#main,#primary,.content-area,.main-content,.site-content{
  display:block!important;padding:0!important;margin:0!important;
  max-width:none!important;width:100%!important;float:none!important;
}

/* ── HEADER ── */
#header{
  position:fixed;top:0;left:0;width:100%;z-index:2000;
  padding:16px 5%;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(12,24,39,.95);backdrop-filter:blur(12px);
  box-shadow:0 2px 30px rgba(0,0,0,.25);
  transition:padding .4s var(--ease);
}
#header.scrolled{padding:11px 5%}
.logo{display:flex;align-items:center;gap:12px}
.logo img{width:40px;filter:brightness(0) invert(1);opacity:.9}
.logo-name{font-family:var(--fs-serif);font-size:16px;letter-spacing:.18em;color:var(--white);font-weight:500}
.header-nav{display:flex;align-items:center;gap:32px}
.header-nav a{font-family:var(--fs-sans);font-size:11px;letter-spacing:.2em;color:rgba(255,255,255,.7);transition:color .3s;text-transform:uppercase}
.header-nav a:hover{color:var(--gold)}
.header-nav a.active{color:var(--gold)}
.nav-cta{border:1px solid var(--gold);color:var(--gold) !important;padding:7px 18px;transition:background .3s,color .3s !important}
.nav-cta:hover{background:var(--gold);color:var(--navy) !important}
.menu-btn{width:26px;height:17px;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between}
.menu-btn span{display:block;height:1px;background:var(--white);transition:transform .4s var(--ease2),opacity .3s,width .3s}
.menu-btn span:nth-child(3){width:60%;margin-left:auto}
.menu-btn.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.menu-btn.open span:nth-child(2){opacity:0}
.menu-btn.open span:nth-child(3){width:100%;transform:translateY(-8px) rotate(-45deg)}

/* ── SIDE MENU ── */
#overlay{position:fixed;inset:0;z-index:1500;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:.4s}
#overlay.show{opacity:1;visibility:visible}
#side-menu{
  position:fixed;top:0;right:-100%;width:min(420px,90vw);height:100vh;
  background:var(--navy);z-index:1600;
  padding:90px 44px 60px;overflow-y:auto;
  transition:right .6s var(--ease2);
  border-left:1px solid rgba(201,165,90,.15);
}
#side-menu.open{right:0}
.menu-group{margin-bottom:40px}
.menu-group .label{font-family:var(--fs-sans);font-size:10px;letter-spacing:.35em;color:var(--gold);margin-bottom:12px;text-transform:uppercase;border-bottom:1px solid rgba(201,165,90,.2);padding-bottom:7px}
.menu-group a{display:block;font-family:var(--fs-serif);font-size:16px;color:rgba(255,255,255,.75);padding:8px 0;letter-spacing:.08em;border-bottom:1px solid rgba(255,255,255,.06);transition:color .3s,padding-left .3s}
.menu-group a:hover{color:var(--gold);padding-left:8px}
.menu-recruit-link{margin-top:36px;padding:22px;background:var(--gold);text-align:center;font-family:var(--fs-serif);font-size:15px;color:var(--navy);letter-spacing:.15em;transition:background .3s;display:block}
.menu-recruit-link:hover{background:var(--gold-lt)}

/* ── PAGE HERO ── */
.page-hero{
  position:relative;height:52vh;min-height:320px;
  display:flex;align-items:flex-end;overflow:hidden;
  background:var(--navy);
}
.page-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.35) saturate(.7);
  transform:scale(1.05);
  transition:transform 8s linear;
}
.page-hero:hover .page-hero-bg{transform:scale(1)}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,24,39,.3) 0%,rgba(12,24,39,.75) 100%)}
.page-hero-content{
  position:relative;z-index:2;padding:0 8% 64px;
  opacity:0;transform:translateY(20px);
  animation:phFadeUp .9s var(--ease) .3s forwards;
}
@keyframes phFadeUp{to{opacity:1;transform:none}}
.page-hero-label{font-family:var(--fs-sans);font-size:10px;letter-spacing:.5em;color:var(--gold);text-transform:uppercase;margin-bottom:14px}
.page-hero-title{font-family:var(--fs-serif);font-size:clamp(32px,4vw,56px);font-weight:500;color:var(--white);letter-spacing:.08em;line-height:1.3}
.page-hero-rule{width:32px;height:2px;background:var(--gold);margin-top:20px}
.breadcrumb{display:flex;gap:12px;align-items:center;font-family:var(--fs-sans);font-size:10px;letter-spacing:.2em;color:rgba(255,255,255,.4);margin-bottom:16px}
.breadcrumb a{color:rgba(255,255,255,.4);transition:color .3s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{color:rgba(255,255,255,.2)}

/* ── SECTION COMMON ── */
.sec{padding:100px 8%;position:relative}
.sec-sm{padding:80px 8%}
.sec-label{font-family:var(--fs-sans);font-size:10px;letter-spacing:.45em;color:var(--gold);text-transform:uppercase;margin-bottom:12px}
.sec-heading{font-family:var(--fs-serif);font-size:clamp(26px,3vw,42px);font-weight:500;letter-spacing:.06em;line-height:1.4;color:var(--navy)}
.sec-heading.light{color:var(--white)}
.sec-rule{width:36px;height:2px;background:var(--gold);margin:20px 0 28px}
.sec-sub{font-size:14px;color:var(--text-mid);letter-spacing:.06em;line-height:2;margin-top:8px}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .85s var(--ease),transform .85s var(--ease);will-change:opacity,transform}
.reveal.visible{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .85s var(--ease),transform .85s var(--ease);will-change:opacity,transform}
.reveal-left.visible{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity .85s var(--ease),transform .85s var(--ease);will-change:opacity,transform}
.reveal-right.visible{opacity:1;transform:none}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;gap:12px;background:var(--navy);color:var(--white);font-family:var(--fs-sans);font-size:11px;letter-spacing:.3em;text-transform:uppercase;padding:18px 44px;transition:background .3s,transform .2s}
.btn-primary:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-gold{display:inline-flex;align-items:center;gap:12px;background:var(--gold);color:var(--navy);font-family:var(--fs-sans);font-size:11px;letter-spacing:.3em;text-transform:uppercase;padding:18px 44px;font-weight:600;transition:background .3s,transform .2s}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px)}
.btn-outline{display:inline-flex;align-items:center;gap:10px;font-family:var(--fs-sans);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--navy-2);border-bottom:1px solid var(--navy-2);padding-bottom:3px;transition:color .3s,border-color .3s,gap .3s}
.btn-outline:hover{color:var(--gold);border-color:var(--gold);gap:18px}
.btn-outline.light{color:rgba(255,255,255,.7);border-color:rgba(255,255,255,.3)}
.btn-outline.light:hover{color:var(--gold);border-color:var(--gold)}

/* ── FOOTER ── */
footer{background:var(--navy);padding:56px 8% 32px;border-top:1px solid rgba(201,165,90,.1)}
.footer-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;margin-bottom:44px;flex-wrap:wrap}
.footer-brand .logo{margin-bottom:14px}
.footer-brand p{font-size:12px;color:rgba(255,255,255,.3);letter-spacing:.06em;line-height:1.9;max-width:260px}
.footer-links{display:flex;gap:56px;flex-wrap:wrap}
.footer-col h5{font-family:var(--fs-sans);font-size:10px;letter-spacing:.35em;color:var(--gold);margin-bottom:14px;text-transform:uppercase}
.footer-col a{display:block;font-family:var(--fs-body);font-size:12px;color:rgba(255,255,255,.38);margin-bottom:9px;letter-spacing:.06em;transition:color .3s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-copy{font-family:var(--fs-sans);font-size:10px;letter-spacing:.2em;color:rgba(255,255,255,.18)}
.footer-tel{font-family:var(--fs-sans);font-size:12px;letter-spacing:.1em;color:rgba(255,255,255,.3)}

/* ── CONTACT STRIP ── */
.contact-strip{background:var(--cream);padding:80px 8%;display:flex;flex-direction:column;align-items:center;text-align:center}
.contact-strip h2{font-family:var(--fs-serif);font-size:clamp(22px,2.8vw,36px);color:var(--navy);letter-spacing:.08em;margin-bottom:12px}
.contact-strip p{font-size:14px;color:var(--text-mid);letter-spacing:.06em;line-height:2;margin-bottom:40px}
.contact-strip .cta-btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* ── MOBILE ── */
@media(max-width:900px){.header-nav{display:none}.sec{padding:72px 6%}.footer-links{gap:28px}}
@media(max-width:600px){.sec{padding:60px 5%}.page-hero-content{padding:0 6% 48px}.contact-strip .cta-btns{flex-direction:column;width:100%;max-width:320px}.btn-primary,.btn-gold{width:100%;justify-content:center}}

/* ── Contact Form 7 カスタマイズ ── */
.wpcf7-form .form-group{margin-bottom:28px}
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea{
  width:100%;padding:14px 16px;
  background:var(--white);
  border:1px solid rgba(12,24,39,.12);
  font-family:var(--fs-body);font-size:14px;color:var(--text);
  letter-spacing:.04em;outline:none;
  transition:border-color .3s,box-shadow .3s;
  appearance:none;
}
.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,165,90,.1)}
.wpcf7-form textarea{height:160px;resize:vertical}
.wpcf7-form input[type="submit"]{
  width:100%;padding:20px;background:var(--navy);color:var(--white);border:none;cursor:pointer;
  font-family:var(--fs-sans);font-size:12px;letter-spacing:.35em;text-transform:uppercase;
  transition:background .3s,transform .2s;margin-top:8px;
}
.wpcf7-form input[type="submit"]:hover{background:var(--navy-2);transform:translateY(-2px)}
.wpcf7-not-valid-tip{color:#c0392b;font-size:12px;margin-top:4px}
.wpcf7-response-output{padding:12px 16px;margin-top:16px;font-size:13px}
