
:root{
  --black:#050505;
  --ink:#111111;
  --muted:#6b7280;
  --line:#e7e2d7;
  --gold:#c8a96b;
  --gold-dark:#a9894f;
  --bg:#ffffff;
  --soft:#f7f5f1;
  --dark:#07101a;
  --container:1180px;
}

*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  height:100%;
  padding-top:env(safe-area-inset-top);
}
body{
  margin:0;
  min-height:100%;
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  font-family:-apple-system,BlinkMacSystemFont,"Noto Sans JP","Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:#fff;
  line-height:1.75;
  letter-spacing:.03em;
}
main{
  flex:1 0 auto;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,textarea{font:inherit}

.container{
  width:min(var(--container), calc(100% - 56px));
  margin:0 auto;
}

.site-header{
  position:fixed;
  inset:0 0 auto 0;
  height:86px;
  z-index:50;
  background:rgba(7,16,26,.38);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.14);
  transition:.3s ease;
}
.site-header:not(.is-scrolled) .global-nav a{color:#fff}
.site-header:not(.is-scrolled) .global-nav a::after{background:#fff}
.site-header.is-scrolled{
  height:72px;
  background:rgba(255,255,255,.82);
  border-bottom:1px solid rgba(200,169,107,.18);
  box-shadow:0 10px 30px rgba(0,0,0,.06);
}
.site-header.is-scrolled .global-nav a{color:inherit}
.site-header.is-scrolled .global-nav a::after{background:var(--gold)}
.header-inner{
  height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
}
.logo img{width:225px;height:auto}
.global-nav{display:flex;align-items:center;gap:34px;font-weight:700;font-size:14px;list-style:none;margin:0;padding:0}
.global-nav a{position:relative}
.global-nav a::after{
  content:"";
  position:absolute;
  left:0;right:100%;bottom:-8px;
  height:1px;background:var(--gold);
  transition:.25s ease;
}
.global-nav a:hover::after{right:0}
.header-cta{
  background:linear-gradient(135deg,var(--gold),#dfc083);
  color:#fff;
  padding:13px 22px;
  border-radius:2px;
  font-size:14px;
  font-weight:700;
}
.menu-btn{display:none}

.hero{
  min-height:760px;
  padding-top:86px;
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
  background-color:#fff;
  background-image:url("../images/hero-warehouse-fade.jpg");
  background-size:cover;
  background-repeat:no-repeat;
  background-position:right -120px center;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:linear-gradient(
    90deg,
    rgba(255,255,255,.92) 0%,
    rgba(255,255,255,.82) 22%,
    rgba(255,255,255,.55) 42%,
    rgba(255,255,255,.18) 62%,
    rgba(255,255,255,.02) 82%,
    rgba(255,255,255,0) 100%
  );
}
.hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  z-index:2;
  height:120px;
  background:linear-gradient(to bottom,rgba(255,255,255,0),#fff);
  pointer-events:none;
}
.hero-content{
  position:relative;
  z-index:3;
  max-width:620px;
  padding:92px 0 120px;
}
.eyebrow{
  color:var(--gold-dark);
  font-size:13px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:20px;
}
.hero h1,.page-hero h1{
  font-size:clamp(42px,6vw,72px);
  line-height:1.16;
  letter-spacing:.01em;
  margin:0 0 24px;
  font-weight:900;
}
.hero p{
  font-size:22px;
  font-weight:800;
  margin:0 0 38px;
}
.btn-row{display:flex;gap:16px;flex-wrap:wrap}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:210px;
  min-height:58px;
  padding:15px 26px;
  border-radius:2px;
  border:1px solid transparent;
  font-weight:800;
  transition:.25s ease;
}
.btn-gold{
  color:#fff;
  background:linear-gradient(135deg,var(--gold),#b59255);
  box-shadow:0 12px 30px rgba(200,169,107,.32);
}
.btn-dark{color:#fff;background:#111}
.btn-outline{
  border-color:rgba(0,0,0,.2);
  color:#111;
  background:rgba(255,255,255,.55);
}
.btn:hover{transform:translateY(-3px)}
.section{padding:92px 0}
.section-title{text-align:center;margin-bottom:54px}
.section-title .eyebrow{margin-bottom:12px;color:var(--gold-dark)}
.section-title h2{font-size:30px;margin:0;font-weight:900}
.section-title .bar{
  width:42px;height:2px;background:var(--gold);
  margin:16px auto 0;
}
.service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  align-items:stretch;
}
.service-card{
  display:flex;
  flex-direction:column;
  height:100%;
  padding:10px 46px 28px;
  border-right:1px solid var(--line);
  position:relative;
  transition:transform .28s ease,box-shadow .28s ease;
}
.service-card:last-child{border-right:0}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 40px rgba(0,0,0,.06);
  z-index:1;
}
.service-icon{
  margin-bottom:28px;
  color:#c8a96b;
  display:flex;
  align-items:center;
  justify-content:flex-start;
}
.service-icon svg{
  width:42px;
  height:42px;
}
.service-icon svg :is(path,circle,line,polyline,polygon,rect){
  stroke-width:1.6;
}
.service-card h3{
  font-size:24px;
  margin:0 0 14px;
  transform:translateY(-2px);
}
.service-card p{
  font-size:15px;
  margin:0 0 22px;
  color:#333;
  min-height:120px;
  flex-grow:1;
}
.service-card img{
  aspect-ratio:16 / 9;
  width:100%;
  height:auto;
  object-fit:cover;
  border-radius:2px;
  margin-top:auto;
}
.strength-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}
.strength-card{
  padding:34px 30px;
  border:1px solid var(--line);
  background:#fff;
}
.strength-card h3{margin:0 0 12px;font-size:21px}
.strength-card p{margin:0;color:#444;font-size:15px}
.mangosteen-section{
  background:#040405;
  color:#fff;
  min-height:620px;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
}
.mangosteen-section::before{
  content:"";
  position:absolute;inset:0;
  background:url("../images/mangosteen-hero.jpg") center/cover no-repeat;
  opacity:.92;
}
.mangosteen-section .container{position:relative;z-index:2}
.mangosteen-copy{max-width:520px}
.brand-label{
  color:#bfc3ca;
  font-size:13px;
  letter-spacing:.28em;
  margin-bottom:10px;
}
.mangosteen-copy h2{
  font-size:clamp(36px,5vw,66px);
  letter-spacing:.18em;
  margin:0 0 24px;
  font-weight:500;
}
.mangosteen-copy .lead{
  font-size:30px;
  line-height:1.5;
  font-weight:700;
  margin-bottom:24px;
}
.mangosteen-copy p{color:#e8e8e8}
.flow{
  background:#fff;
  border-top:1px solid #eee;
  border-bottom:1px solid #eee;
  padding:34px 0;
}
.flow-list{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  font-weight:800;
}
.flow-item{display:flex;align-items:center;gap:10px;color:#333}
.flow-arrow{color:#aaa}
.cta-section{
  position:relative;
  padding:76px 0;
  text-align:center;
  color:#fff;
  background:linear-gradient(135deg,#08111c,#111923);
  overflow:hidden;
}
.cta-section::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(circle at 20% 20%,rgba(200,169,107,.18),transparent 30%),
             radial-gradient(circle at 80% 0%,rgba(255,255,255,.08),transparent 24%);
}
.cta-section .container{position:relative}
.cta-section h2{font-size:32px;margin:0 0 14px}
.cta-section p{margin:0 0 26px;color:#e5e7eb}

.site-footer{
  background:#050505;
  color:#fff;
  padding:26px 0;
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;gap:22px;
}
.footer-logo img{width:170px;height:auto;display:block}
.footer-nav{display:flex;gap:28px;font-size:13px;color:#ddd;list-style:none;margin:0;padding:0}
.copyright{font-size:12px;color:#aaa}

/* page */
.page-hero{
  padding:180px 0 94px;
  background:#f7f5f1;
  position:relative;
  overflow:hidden;
}
.page-hero.with-image{
  min-height:520px;
  display:flex;align-items:center;
  color:#fff;
  background:#07101a;
}
.page-hero.with-image::before{
  content:"";
  position:absolute;inset:0;
  background:var(--page-img) center/cover no-repeat;
  opacity:.48;
}
.page-hero.with-image::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(0,0,0,.72),rgba(0,0,0,.22));
}
.page-hero .container{position:relative;z-index:2}
.page-hero p{font-size:20px;font-weight:700;max-width:720px}
.two-col{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:56px;
  align-items:center;
}
.two-col img{border-radius:2px;box-shadow:0 28px 60px rgba(0,0,0,.1)}
.content-block h2{font-size:34px;line-height:1.35;margin:0 0 18px}
.content-block p{color:#444}
.list-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:30px;
}
.list-item{
  padding:22px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:800;
}
.process{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.process-card{
  padding:28px;
  background:#fff;
  border:1px solid var(--line);
}
.process-card .num{color:var(--gold);font-weight:900;margin-bottom:10px}
.dark-band{background:#050505;color:#fff}
.dark-band p{color:#ddd}
.gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.gallery img{height:260px;width:100%;object-fit:cover}
.contact-layout{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:52px;
}
.contact-info{
  background:#050505;
  color:#fff;
  padding:42px;
}
.form{
  display:grid;
  gap:18px;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.form label{font-weight:800;font-size:14px}
.form input,.form textarea,.form select{
  width:100%;
  border:1px solid #ddd;
  background:#fff;
  min-height:54px;
  padding:14px 16px;
  border-radius:2px;
}
.form textarea{min-height:180px;resize:vertical}
.form-field{display:grid;gap:8px}
.fade-up{opacity:0;transform:translateY(24px);transition:.7s ease}
.fade-up.is-visible{opacity:1;transform:translateY(0)}

/* Contact Form 7 */
.wpcf7-form{display:grid;gap:18px}
.wpcf7-form p{margin:0}
.wpcf7-form .wpcf7-form-control-wrap{display:block}
.wpcf7-form input:not([type="submit"]),
.wpcf7-form textarea,
.wpcf7-form select{
  width:100%;
  border:1px solid #ddd;
  background:#fff;
  min-height:54px;
  padding:14px 16px;
  border-radius:2px;
}
.wpcf7-form textarea{min-height:180px;resize:vertical}
.wpcf7-submit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:210px;
  min-height:58px;
  padding:15px 26px;
  border:1px solid transparent;
  border-radius:2px;
  font-weight:800;
  color:#fff;
  background:linear-gradient(135deg,var(--gold),#b59255);
  box-shadow:0 12px 30px rgba(200,169,107,.32);
  cursor:pointer;
}

/* TOP — 運営事業・ブランド */
.section--brands{
  background:#fff;
  border-top:1px solid rgba(231,226,215,.65);
}
.biz-brands-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(28px,4vw,56px);
  align-items:start;
}
.biz-brands-col{
  padding-top:8px;
}
.biz-brands-cat{
  margin:0 0 28px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--gold-dark);
  padding-bottom:16px;
  border-bottom:1px solid var(--gold);
}
.brand-cards{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.brand-card{
  display:block;
  padding:26px 24px;
  border:1px solid var(--line);
  background:#fff;
}
.brand-card__name{
  display:block;
  font-size:15px;
  font-weight:800;
  letter-spacing:.14em;
  margin-bottom:10px;
  color:var(--ink);
}
.brand-card__desc{
  margin:0;
  font-size:14px;
  color:#555;
  line-height:1.65;
  font-weight:500;
}
.brand-card__links{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:20px;
}
.brand-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px 15px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  border:1px solid rgba(231,226,215,.95);
  border-radius:999px;
  background:#fff;
  color:#444;
  transition:border-color .22s ease,color .22s ease,transform .22s ease,box-shadow .22s ease;
}
.brand-pill:hover{
  border-color:var(--gold);
  color:var(--gold-dark);
  transform:translateY(-2px);
  box-shadow:0 6px 18px rgba(0,0,0,.05);
}
.brand-pill:focus-visible{
  outline:1px solid var(--gold);
  outline-offset:2px;
}
.biz-pillar-list{
  margin:0;
  padding:0;
  list-style:none;
}
.biz-pillar-item{
  display:flex;
  align-items:center;
  gap:16px;
  padding:22px 0;
  border-bottom:1px solid rgba(231,226,215,.9);
  font-size:16px;
  font-weight:600;
  color:var(--ink);
  letter-spacing:.02em;
}
.biz-pillar-item:last-child{border-bottom:0;padding-bottom:0}
.biz-pillar-item:first-child{padding-top:4px}
.biz-pillar-glyph{
  flex-shrink:0;
  width:36px;
  height:1px;
  background:linear-gradient(90deg,var(--gold),rgba(200,169,107,.2));
}
/* Root cause: `.wpcf7-form input` (class+element) had higher specificity than
   `.wpcf7-submit` and forced submit background to white. This block fixes it
   only inside contact page layout. */
.contact-layout .wpcf7-submit{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;

    width:100% !important;
    height:64px !important;

    background:#c8a96b !important;
    color:#ffffff !important;

    border:none !important;
    border-radius:0 !important;

    font-size:16px !important;
    font-weight:700 !important;
    letter-spacing:.08em !important;

    cursor:pointer !important;

    appearance:none !important;
    -webkit-appearance:none !important;

    opacity:1 !important;
    visibility:visible !important;

    transition:.3s ease !important;
}

.contact-layout .wpcf7-submit:hover{
    background:#b89554 !important;
}

.contact-layout .wpcf7-spinner{
    display:none !important;
}

html,
body{
    overflow-x:hidden;
    overflow-y:visible !important;
}

main{
    overflow:visible !important;
}

.site-footer{
    position:relative;
    z-index:1;
    overflow:visible !important;
}

.grecaptcha-badge{
    position:fixed !important;

    right:20px !important;
    bottom:20px !important;

    z-index:2147483647 !important;

    overflow:visible !important;

    opacity:1 !important;
    visibility:visible !important;

    transform:none !important;

    pointer-events:auto !important;
}

iframe[src*="recaptcha"]{
    position:fixed !important;
    z-index:2147483647 !important;
    transform:none !important;
}