/* ========================================
   Uniseed Inc. — 共通スタイルシート
   Pattern-02（White Design）ベース
   ======================================== */

/* ========== リセット＆変数 ========== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#1a1a2e;
  --ink-light:#3d3d5c;
  --navy:#16213e;
  --navy-light:#2c3e6b;
  --silver:#8a8fa8;
  --mist:#c4c8d8;
  --cloud:#eef0f5;
  --snow:#f8f9fc;
  --white:#ffffff;
  --accent:#5c7cfa;
  --accent-pale:rgba(92,124,250,.08);
  --accent-hover:#4263eb;
  --font-en:'Cormorant Garamond',serif;
  --font-ja:'Noto Sans JP',sans-serif;
  --ease:cubic-bezier(0.23,1,0.32,1);
}
html{scroll-behavior:smooth;font-size:18px}
body{font-family:var(--font-ja);color:var(--ink);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:1140px;margin:0 auto;padding:0 40px}

/* ========== ヘッダー ========== */
.header{position:fixed;top:0;left:0;width:100%;z-index:100;padding:28px 0;transition:all .6s var(--ease)}
.header.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(20px);padding:16px 0;border-bottom:1px solid rgba(0,0,0,.04)}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1140px;margin:0 auto;padding:0 40px}
.logo{font-family:var(--font-en);font-weight:400;font-size:1.75rem;color:var(--ink);letter-spacing:.12em}
.logo span{font-weight:300;font-size:.625rem;display:block;letter-spacing:.25em;color:var(--silver);margin-top:2px;text-transform:uppercase}
.nav-list{display:flex;gap:36px;align-items:center}
.nav-link{font-size:.8125rem;color:var(--silver);font-weight:300;letter-spacing:.06em;transition:color .4s}
.nav-link:hover{color:var(--ink)}
.nav-link.active{color:var(--ink)}
.header-right{display:flex;align-items:center;gap:24px}
.lang-toggle{font-family:var(--font-en);font-size:.75rem;color:var(--silver);letter-spacing:.1em;cursor:pointer;border:none;background:none;transition:color .3s}
.lang-toggle:hover{color:var(--ink)}
.lang-sep{color:var(--mist)}
.lang-toggle.active{color:var(--ink)}
.hamburger{display:none;flex-direction:column;gap:6px;cursor:pointer;padding:8px;background:none;border:none}
.hamburger span{display:block;width:22px;height:1px;background:var(--ink);transition:all .4s var(--ease)}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ========== ナビドロップダウン ========== */
.nav-dropdown{position:relative}
.nav-dropdown>a{position:relative;z-index:112}
.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);min-width:280px;background:var(--white);border:1px solid var(--cloud);border-radius:4px;box-shadow:0 12px 40px rgba(0,0,0,.08);opacity:0;visibility:hidden;transition:all .35s var(--ease);pointer-events:none;padding:8px 0;z-index:110}
.nav-dropdown-menu::before{content:'';position:absolute;top:-16px;left:0;right:0;height:16px;z-index:111}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:auto}
.nav-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:.8125rem;font-weight:300;color:var(--ink-light);letter-spacing:.04em;transition:all .25s;text-decoration:none}
.nav-dropdown-item:hover{background:var(--snow);color:var(--ink)}
.nav-dropdown-num{font-family:var(--font-en);font-size:.6875rem;color:var(--mist);letter-spacing:.08em;min-width:20px}
.nav-dropdown-item--accent{position:relative}
.nav-dropdown-item--accent:hover{background:rgba(92,124,250,.04)}
.nav-dropdown-badge{font-size:.625rem;letter-spacing:.06em;color:var(--white);background:var(--accent);padding:2px 8px;border-radius:2px;margin-left:auto;white-space:nowrap}

/* ========== モバイルサブメニュー ========== */
.mobile-sub{display:flex;flex-direction:column;gap:12px;padding-left:20px;margin-top:-12px}
.mobile-sub a{font-size:.8125rem !important;color:var(--silver) !important;letter-spacing:.04em}
.mobile-sub a:hover{color:var(--ink) !important}
.mobile-sub-accent span{font-size:.625rem;color:var(--white);background:var(--accent);padding:2px 6px;border-radius:2px;margin-left:6px;vertical-align:middle}

/* ========== モバイルメニュー ========== */
.mobile-menu{position:fixed;inset:0;background:rgba(255,255,255,.98);z-index:99;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:28px;opacity:0;visibility:hidden;transition:all .5s var(--ease)}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{font-size:1rem;font-weight:300;color:var(--ink);letter-spacing:.08em}
.mobile-menu .mobile-lang{margin-top:20px;display:flex;gap:16px}
.mobile-menu .mobile-lang a{font-family:var(--font-en);font-size:.875rem;color:var(--silver)}
.mobile-menu .mobile-lang a.active{color:var(--ink)}

/* ========== トップページヒーロー ========== */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--white)}
.hero-orb{position:absolute;width:700px;height:700px;border-radius:50%;border:1px solid rgba(0,0,0,.1);top:50%;right:-10%;transform:translateY(-50%);animation:orbRotate 40s linear infinite}
.hero-orb::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;border:1px solid rgba(0,0,0,.12);top:50%;left:50%;transform:translate(-50%,-50%)}
.hero-orb::after{content:'';position:absolute;width:300px;height:300px;border-radius:50%;border:1px dashed rgba(92,124,250,.25);top:50%;left:50%;transform:translate(-50%,-50%)}
.hero-dot{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--accent);opacity:.6}
.hero-dot:nth-child(1){top:15%;right:30%}
.hero-dot:nth-child(2){top:65%;right:15%}
.hero-dot:nth-child(3){top:40%;right:45%}
@keyframes orbRotate{to{transform:translateY(-50%) rotate(360deg)}}
.hero-words{position:absolute;right:8%;top:20%;font-family:var(--font-en);font-size:.6875rem;letter-spacing:.25em;color:var(--ink-light);writing-mode:horizontal-tb;display:flex;flex-direction:column;gap:28px;text-transform:uppercase}
.hero-words span{opacity:0;animation:wordFade 1s var(--ease) forwards}
.hero-words span:nth-child(1){animation-delay:.8s}
.hero-words span:nth-child(2){animation-delay:1.1s}
.hero-words span:nth-child(3){animation-delay:1.4s}
.hero-words span:nth-child(4){animation-delay:1.7s}
@keyframes wordFade{to{opacity:1}}
.hero-content{position:relative;z-index:2;max-width:600px}
.hero-sub{font-family:var(--font-en);font-size:.6875rem;letter-spacing:.3em;color:var(--silver);text-transform:uppercase;margin-bottom:32px;opacity:0;animation:fadeIn .8s var(--ease) .3s forwards}
.hero-title{font-size:clamp(2rem,4.5vw,3.25rem);font-weight:300;line-height:1.7;color:var(--ink);margin-bottom:20px;opacity:0;animation:fadeSlide .8s var(--ease) .5s forwards;transform:translateY(16px)}
.hero-title em{font-style:normal;font-weight:500}
.hero-en{font-family:var(--font-en);font-size:clamp(.875rem,1.5vw,1.125rem);font-weight:300;color:var(--mist);letter-spacing:.1em;font-style:italic;margin-bottom:48px;opacity:0;animation:fadeIn .8s var(--ease) .8s forwards}
.hero-line{width:60px;height:1px;background:var(--mist);margin-bottom:48px;opacity:0;animation:fadeIn .8s var(--ease) 1s forwards}
.hero-desc{font-size:.875rem;font-weight:300;line-height:2.2;color:var(--ink-light);max-width:440px;opacity:0;animation:fadeSlide .8s var(--ease) 1.2s forwards;transform:translateY(12px)}
@keyframes fadeIn{to{opacity:1}}
@keyframes fadeSlide{to{opacity:1;transform:translateY(0)}}

/* ========== 下層ページヒーロー ========== */
.page-hero{min-height:40vh;display:flex;align-items:flex-end;position:relative;overflow:hidden;background:var(--white);padding-bottom:60px;padding-top:120px}
.page-hero .hero-orb{width:500px;height:500px;right:-15%;opacity:.5}
.page-hero .hero-orb::before{width:350px;height:350px}
.page-hero .hero-orb::after{width:200px;height:200px}
.page-hero-content{position:relative;z-index:2}
.page-hero-en{font-family:var(--font-en);font-size:clamp(2.5rem,5vw,4rem);font-weight:300;color:var(--ink);letter-spacing:.06em;line-height:1.2;margin-bottom:8px;opacity:0;animation:fadeSlide .8s var(--ease) .2s forwards;transform:translateY(16px)}
.page-hero-ja{font-size:.9375rem;font-weight:300;color:var(--silver);letter-spacing:.08em;opacity:0;animation:fadeIn .8s var(--ease) .5s forwards}
.page-hero-line{width:40px;height:1px;background:var(--accent);margin-top:24px;opacity:0;animation:fadeIn .8s var(--ease) .7s forwards}

/* ========== パンくずリスト ========== */
.breadcrumb{padding:16px 0;border-bottom:1px solid var(--cloud)}
.breadcrumb-list{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--silver);font-weight:300}
.breadcrumb-list a{color:var(--silver);transition:color .3s}
.breadcrumb-list a:hover{color:var(--ink)}
.breadcrumb-sep{color:var(--mist)}
.breadcrumb-current{color:var(--ink)}

/* ========== セクション共通 ========== */
.section{padding:140px 0}
.section-head{margin-bottom:72px}
.section-en{font-family:var(--font-en);font-size:.6875rem;letter-spacing:.3em;color:var(--silver);text-transform:uppercase;margin-bottom:4px}
.section-title{font-family:var(--font-en);font-size:clamp(1.75rem,3vw,2.5rem);font-weight:300;color:var(--ink);letter-spacing:.04em}
.section-divider{width:40px;height:1px;background:var(--mist);margin-top:20px}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ========== About（トップページ） ========== */
.about{background:var(--white)}
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:start}
.about-left h3{font-size:1.375rem;font-weight:400;line-height:1.8;color:var(--ink);margin-bottom:32px}
.about-left p{font-size:.875rem;font-weight:300;line-height:2.2;color:var(--ink-light);margin-bottom:20px}
.about-link{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-en);font-size:.8125rem;font-weight:400;color:var(--accent);letter-spacing:.06em;margin-top:16px;transition:gap .3s}
.about-link:hover{gap:16px}
.about-right{position:relative}
.about-img-wrap{position:relative;overflow:hidden;border-radius:2px}
.about-img-wrap img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform .8s var(--ease)}
.about-img-wrap:hover img{transform:scale(1.03)}
.about-philosophy{margin-top:48px;padding:40px;border:1px solid var(--cloud);border-radius:2px;position:relative}
.about-philosophy::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent)}
.about-philosophy h4{font-family:var(--font-en);font-size:.6875rem;letter-spacing:.25em;color:var(--silver);text-transform:uppercase;margin-bottom:16px}
.about-philosophy p{font-size:.9375rem;font-weight:400;line-height:2;color:var(--ink)}

/* ========== About下層ページ ========== */
.about-page-text{max-width:800px}
.about-page-text h3{font-size:1.25rem;font-weight:400;line-height:1.8;color:var(--ink);margin-bottom:28px}
.about-page-text p{font-size:.875rem;font-weight:300;line-height:2.4;color:var(--ink-light);margin-bottom:20px}
.about-page-text p:last-child{margin-bottom:0}
.philosophy-box{padding:48px;border:1px solid var(--cloud);border-radius:2px;position:relative;margin-top:80px;background:var(--snow)}
.philosophy-box::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent)}
.philosophy-box .section-en{margin-bottom:4px}
.philosophy-box .section-title{margin-bottom:20px;font-size:clamp(1.5rem,2.5vw,2rem)}
.philosophy-box .section-divider{margin-bottom:32px}
.philosophy-box p{font-size:1rem;font-weight:400;line-height:2.2;color:var(--ink)}
.company-table{margin-top:80px}
.company-table table{width:100%;border-collapse:collapse}
.company-table th,.company-table td{padding:20px 24px;font-size:.875rem;font-weight:300;line-height:1.8;text-align:left;border-bottom:1px solid var(--cloud)}
.company-table th{color:var(--silver);width:180px;font-weight:400;letter-spacing:.04em;background:var(--snow)}
.company-table td{color:var(--ink)}

/* ========== Business（トップページ） ========== */
.business{background:var(--snow);position:relative}
.business::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--cloud)}
.biz-group{position:relative}
.biz-statement{font-size:clamp(1.125rem,2vw,1.5rem);font-weight:300;line-height:2;color:var(--ink);max-width:700px;margin-bottom:80px}
.biz-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--cloud);border:1px solid var(--cloud);border-radius:2px;overflow:hidden}
.biz-card{background:var(--white);padding:40px 32px;transition:all .5s var(--ease);position:relative}
.biz-card:hover{background:var(--snow)}
.biz-card-num{font-family:var(--font-en);font-size:2.5rem;font-weight:300;color:var(--cloud);margin-bottom:24px;transition:color .4s}
.biz-card:hover .biz-card-num{color:rgba(92,124,250,.15)}
.biz-card-icon{width:48px;height:48px;margin-bottom:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-pale)}
.biz-card-icon svg{width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:1.5}
.biz-card h3{font-size:1.125rem;font-weight:500;color:var(--ink);margin-bottom:16px}
.biz-card p{font-size:.8125rem;font-weight:300;line-height:2;color:var(--silver);margin-bottom:24px}
.biz-card-link{font-family:var(--font-en);font-size:.75rem;letter-spacing:.1em;color:var(--accent);display:inline-flex;align-items:center;gap:8px;transition:gap .3s}
.biz-card-link:hover{gap:12px}
.biz-images{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.biz-img-item{overflow:hidden;border-radius:2px;aspect-ratio:16/10}
.biz-img-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.biz-img-item:hover img{transform:scale(1.04)}

/* ========== Business下層ページ ========== */
.biz-section{padding:100px 0;border-bottom:1px solid var(--cloud)}
.biz-section:last-of-type{border-bottom:none}
.biz-section.alt-bg{background:var(--snow)}
.biz-section-head{display:flex;align-items:baseline;gap:24px;margin-bottom:20px}
.biz-section-num{font-family:var(--font-en);font-size:3.5rem;font-weight:300;color:var(--cloud);line-height:1}
.biz-section-title-group{flex:1}
.biz-lead{font-size:.875rem;font-weight:300;line-height:2.4;color:var(--ink-light);max-width:800px;margin-bottom:60px}
.biz-lead p{margin-bottom:16px}
.biz-lead p:last-child{margin-bottom:0}

/* 環境装置 カードグリッド */
.equip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--cloud);border:1px solid var(--cloud);border-radius:2px;overflow:hidden}
.equip-card{background:var(--white);padding:36px 28px;transition:background .4s var(--ease)}
.equip-card:hover{background:var(--snow)}
.equip-card-icon{width:44px;height:44px;margin-bottom:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-pale)}
.equip-card-icon svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.5}
.equip-card h4{font-size:1rem;font-weight:500;color:var(--ink);margin-bottom:12px}
.equip-card p{font-size:.8125rem;font-weight:300;line-height:2;color:var(--silver)}

/* 化粧品原料・食品原料 商品カード */
.product-list{display:flex;flex-direction:column;gap:80px}
.product-item{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.product-item:nth-child(even){direction:rtl}
.product-item:nth-child(even)>*{direction:ltr}
.product-img{position:relative;overflow:hidden;border-radius:2px;aspect-ratio:4/3}
.product-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.product-img:hover img{transform:scale(1.03)}
.product-content{}
.product-num{font-family:var(--font-en);font-size:3rem;font-weight:300;color:var(--cloud);margin-bottom:8px}
.product-name{font-size:1.375rem;font-weight:500;color:var(--ink);margin-bottom:8px}
.product-name-en{font-family:var(--font-en);font-size:.75rem;letter-spacing:.15em;color:var(--silver);text-transform:uppercase;margin-bottom:24px}
.product-desc{font-size:.875rem;font-weight:300;line-height:2.2;color:var(--ink-light);margin-bottom:28px}
.product-features{margin-bottom:28px}
.product-features h5{font-size:.8125rem;font-weight:500;color:var(--ink);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.product-features h5::before{content:'';width:16px;height:1px;background:var(--accent)}
.product-features ul{padding-left:0}
.product-features li{font-size:.8125rem;font-weight:300;line-height:2;color:var(--ink-light);padding-left:16px;position:relative}
.product-features li::before{content:'';position:absolute;left:0;top:11px;width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:.5}
.product-features li strong{font-weight:500;color:var(--ink)}
.product-cert{padding:16px 20px;background:var(--snow);border-radius:2px;font-size:.8125rem;font-weight:300;line-height:1.8;color:var(--ink-light);border-left:3px solid var(--accent)}
.product-blockquote{padding:16px 20px;background:var(--snow);border-radius:2px;font-size:.8125rem;font-weight:300;line-height:2;color:var(--ink-light);border-left:3px solid var(--mist);margin-bottom:28px;font-style:italic}
.product-usage{margin-bottom:28px}
.product-usage h5{font-size:.8125rem;font-weight:500;color:var(--ink);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.product-usage h5::before{content:'';width:16px;height:1px;background:var(--accent)}
.product-usage p{font-size:.8125rem;font-weight:300;line-height:2;color:var(--ink-light)}
.product-usage ul{padding-left:0}
.product-usage li{font-size:.8125rem;font-weight:300;line-height:2;color:var(--ink-light);padding-left:16px;position:relative}
.product-usage li::before{content:'';position:absolute;left:0;top:11px;width:4px;height:4px;border-radius:50%;background:var(--mist)}

/* ========== News（トップページ） ========== */
.news{background:var(--white)}
.news-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--cloud);border-top:1px solid var(--cloud);border-bottom:1px solid var(--cloud)}
.news-item{background:var(--white);padding:32px 24px;transition:background .3s;display:block}
.news-item:hover{background:var(--snow)}
.news-item-date{font-family:var(--font-en);font-size:.75rem;color:var(--silver);letter-spacing:.05em;margin-bottom:4px}
.news-item-cat{font-size:.6875rem;color:var(--accent);margin-bottom:16px;display:block}
.news-item-title{font-size:.875rem;font-weight:400;line-height:1.7;color:var(--ink)}
.news-more{display:flex;justify-content:flex-end;margin-top:32px}
.news-more a{font-family:var(--font-en);font-size:.75rem;letter-spacing:.15em;color:var(--silver);display:inline-flex;align-items:center;gap:8px;transition:color .3s,gap .3s}
.news-more a:hover{color:var(--ink);gap:12px}

/* ========== Media下層ページ ========== */
.media-filter{display:flex;gap:8px;margin-bottom:48px;flex-wrap:wrap}
.media-filter-btn{padding:8px 20px;font-size:.8125rem;font-weight:300;color:var(--silver);background:var(--white);border:1px solid var(--cloud);border-radius:2px;cursor:pointer;transition:all .3s var(--ease)}
.media-filter-btn:hover,.media-filter-btn.active{color:var(--ink);border-color:var(--ink);background:var(--white)}
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-bottom:60px}
.media-card{border:1px solid var(--cloud);border-radius:2px;overflow:hidden;transition:all .4s var(--ease);display:block}
.media-card:hover{border-color:var(--mist);box-shadow:0 8px 32px rgba(0,0,0,.04)}
.media-card-img{aspect-ratio:16/9;overflow:hidden;background:var(--snow)}
.media-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.media-card:hover .media-card-img img{transform:scale(1.04)}
.media-card-img.no-thumb{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--ink) 0%,#2a2a2a 100%)}
.media-card-img.no-thumb .no-thumb-label{font-family:var(--font-en);font-size:1.125rem;font-weight:300;letter-spacing:.18em;color:rgba(255,255,255,.45)}
.media-card-body{padding:24px}
.media-card-meta{display:flex;gap:12px;align-items:center;margin-bottom:12px}
.media-card-date{font-family:var(--font-en);font-size:.75rem;color:var(--silver);letter-spacing:.04em}
.media-card-cat{font-size:.6875rem;color:var(--accent);padding:2px 8px;background:var(--accent-pale);border-radius:2px}
.media-card-title{font-size:.9375rem;font-weight:400;line-height:1.7;color:var(--ink)}
.media-card-excerpt{font-size:.8125rem;font-weight:300;line-height:1.8;color:var(--silver);margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.media-skeleton{background:var(--snow);border-radius:2px;animation:skeleton 1.5s ease infinite}
@keyframes skeleton{0%,100%{opacity:1}50%{opacity:.5}}
.media-empty{text-align:center;padding:80px 40px;color:var(--silver);font-size:.875rem;font-weight:300}

/* ページネーション */
.pagination{display:flex;justify-content:center;gap:4px}
.pagination-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-family:var(--font-en);font-size:.8125rem;color:var(--silver);border:1px solid var(--cloud);background:var(--white);cursor:pointer;transition:all .3s;border-radius:2px}
.pagination-btn:hover{border-color:var(--ink);color:var(--ink)}
.pagination-btn.active{background:var(--ink);color:var(--white);border-color:var(--ink)}
.pagination-btn:disabled{opacity:.3;cursor:not-allowed}
.pagination-ellipsis{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-family:var(--font-en);font-size:.8125rem;color:var(--mist)}

/* ========== Company Profile（トップページ） ========== */
.profile{background:var(--snow);border-top:1px solid var(--cloud)}
.profile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:60px;margin-top:60px}
.profile-item{text-align:center;text-decoration:none;display:block;transition:opacity .3s}
a.profile-item:hover{opacity:.65}
.profile-icon{width:64px;height:64px;margin:0 auto 20px;border-radius:50%;border:1px solid var(--cloud);display:flex;align-items:center;justify-content:center}
.profile-icon svg{width:24px;height:24px;stroke:var(--silver);fill:none;stroke-width:1.5}
.profile-label{font-family:var(--font-en);font-size:.6875rem;letter-spacing:.2em;color:var(--silver);text-transform:uppercase;margin-bottom:8px}
.profile-value{font-size:.875rem;font-weight:400;color:var(--ink);line-height:1.8}

/* ========== 化粧品原料ゲートウェイCTA ========== */
.cos-gateway{position:relative;border-radius:8px;overflow:hidden;background:linear-gradient(165deg,#1a3a2a 0%,#0f2a1c 100%)}
.cos-gateway-grain{position:absolute;inset:0;opacity:.12;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}
.cos-gateway-inner{position:relative;z-index:1;padding:64px 56px;display:flex;align-items:center;gap:56px}
.cos-gateway-thumbs{display:flex;gap:16px;flex-shrink:0}
.cos-gateway-thumb{width:100px;height:100px;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.08);transition:transform .5s cubic-bezier(.23,1,.32,1)}
.cos-gateway-thumb:hover{transform:translateY(-4px)}
.cos-gateway-thumb img{width:100%;height:100%;object-fit:cover}
.cos-gateway-body{flex:1}
.cos-gateway-desc{font-size:.9375rem;font-weight:300;line-height:2;color:rgba(255,255,255,.65);margin-bottom:32px}
.cos-gateway-btn{display:inline-flex;align-items:center;gap:12px;padding:18px 48px;border:1px solid #c9a96e;color:#c9a96e;font-size:.9375rem;font-weight:400;letter-spacing:.06em;transition:all .5s cubic-bezier(.23,1,.32,1);background:transparent;text-decoration:none}
.cos-gateway-btn:hover{background:#c9a96e;color:#1a3a2a}
.cos-gateway-btn svg{transition:transform .3s}
.cos-gateway-btn:hover svg{transform:translateX(4px)}
@media(max-width:1023px){
  .cos-gateway-inner{flex-direction:column;padding:48px 40px;gap:32px;text-align:center}
  .cos-gateway-thumbs{justify-content:center}
  .cos-gateway-thumb{width:80px;height:80px}
}
@media(max-width:767px){
  .cos-gateway-inner{padding:36px 24px;gap:24px}
  .cos-gateway-thumbs{gap:10px}
  .cos-gateway-thumb{width:64px;height:64px;border-radius:6px}
  .cos-gateway-desc{font-size:.8125rem;margin-bottom:24px}
  .cos-gateway-btn{padding:14px 32px;font-size:.8125rem;width:100%;justify-content:center}
}

/* ========== Contact CTA ========== */
.contact-cta{background:var(--white);text-align:center;padding:120px 0}
.contact-cta h2{font-family:var(--font-en);font-size:clamp(1.5rem,2.5vw,2rem);font-weight:300;color:var(--ink);margin-bottom:12px}
.contact-cta p{font-size:.875rem;font-weight:300;color:var(--silver);margin-bottom:40px;line-height:1.8}
.contact-btn{display:inline-flex;align-items:center;gap:12px;padding:16px 48px;border:1px solid var(--ink);color:var(--ink);font-size:.875rem;font-weight:400;letter-spacing:.06em;border-radius:0;transition:all .4s var(--ease);background:transparent;cursor:pointer;font-family:var(--font-ja)}
.contact-btn:hover{background:var(--ink);color:var(--white)}

/* ========== Contact下層ページ ========== */
.contact-page{padding:100px 0}
.contact-intro{max-width:600px;margin:0 auto 60px;text-align:center}
.contact-intro p{font-size:.875rem;font-weight:300;line-height:2;color:var(--silver)}
.contact-form{max-width:700px;margin:0 auto}
.form-group{margin-bottom:32px}
.form-label{display:block;font-size:.8125rem;font-weight:400;color:var(--ink);margin-bottom:8px;letter-spacing:.04em}
.form-label .required{color:var(--accent);font-size:.6875rem;margin-left:6px;font-weight:300}
.form-input,.form-textarea,.form-select{width:100%;padding:12px 16px;font-size:.875rem;font-family:var(--font-ja);color:var(--ink);border:1px solid var(--cloud);border-radius:2px;background:var(--white);transition:border-color .3s;outline:none}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--accent)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--mist)}
.form-textarea{min-height:160px;resize:vertical;line-height:1.8}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.form-error{font-size:.75rem;color:#e74c3c;margin-top:4px;display:none}
.form-group.error .form-input,.form-group.error .form-textarea{border-color:#e74c3c}
.form-group.error .form-error{display:block}
.form-submit{text-align:center;margin-top:48px}
.form-submit-btn{display:inline-flex;align-items:center;gap:12px;padding:18px 60px;border:1px solid var(--ink);color:var(--ink);font-size:.9375rem;font-weight:400;letter-spacing:.08em;border-radius:0;transition:all .4s var(--ease);background:transparent;cursor:pointer;font-family:var(--font-ja)}
.form-submit-btn:hover{background:var(--ink);color:var(--white)}
.form-submit-btn:disabled{opacity:.4;cursor:not-allowed}
.form-message{text-align:center;margin-top:24px;font-size:.875rem;font-weight:300;display:none}
.form-message.success{color:var(--accent);display:block}
.form-message.error{color:#e74c3c;display:block}

/* CF7 スタイル上書き */
.contact-form .wpcf7-form .form-group{margin-bottom:32px}
.contact-form .wpcf7-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.contact-form .wpcf7-form .form-label{display:block;font-size:.8125rem;font-weight:400;color:var(--ink);margin-bottom:8px;letter-spacing:.04em}
.contact-form .wpcf7-form .form-label .required{color:var(--accent);font-size:.6875rem;margin-left:6px;font-weight:300}
.contact-form .wpcf7-form input.wpcf7-form-control:not([type="submit"]),
.contact-form .wpcf7-form textarea.wpcf7-form-control{width:100%;padding:12px 16px;font-size:.875rem;font-family:var(--font-ja);color:var(--ink);border:1px solid var(--cloud);border-radius:2px;background:var(--white);transition:border-color .3s;outline:none;-webkit-appearance:none;appearance:none;box-sizing:border-box}
.contact-form .wpcf7-form input.wpcf7-form-control:focus,
.contact-form .wpcf7-form textarea.wpcf7-form-control:focus{border-color:var(--accent)}
.contact-form .wpcf7-form input.wpcf7-form-control::placeholder,
.contact-form .wpcf7-form textarea.wpcf7-form-control::placeholder{color:var(--mist)}
.contact-form .wpcf7-form textarea.wpcf7-form-control{min-height:160px;resize:vertical;line-height:1.8}
.contact-form .wpcf7-form .form-submit{text-align:center;margin-top:48px}
.contact-form .wpcf7-form input[type="submit"].wpcf7-submit{display:inline-flex;align-items:center;gap:12px;padding:18px 60px;border:1px solid var(--ink);color:var(--ink);font-size:.9375rem;font-weight:400;letter-spacing:.08em;border-radius:0;transition:all .4s var(--ease);background:transparent;cursor:pointer;font-family:var(--font-ja);-webkit-appearance:none;appearance:none}
.contact-form .wpcf7-form input[type="submit"].wpcf7-submit:hover{background:var(--ink);color:var(--white)}
.contact-form .wpcf7-form .wpcf7-spinner{display:none}
/* CF7 バリデーションエラー */
.contact-form .wpcf7-form .wpcf7-not-valid{border-color:#e74c3c !important}
.contact-form .wpcf7-form .wpcf7-not-valid-tip{display:block;font-size:.75rem;color:#e74c3c;margin-top:6px;font-weight:300}
.contact-form .wpcf7-form .wpcf7-response-output{text-align:center;font-size:.875rem;font-weight:300;margin:32px 0 0;padding:16px 24px;border-radius:2px}
.contact-form .wpcf7-form.invalid .wpcf7-response-output,
.contact-form .wpcf7-form.unaccepted .wpcf7-response-output{border-color:#e74c3c;color:#e74c3c;background:rgba(231,76,60,.04)}
.contact-form .wpcf7-form.sent .wpcf7-response-output{border-color:var(--accent);color:var(--accent);background:rgba(var(--accent-rgb,107,142,35),.04)}
.contact-form .wpcf7-form.failed .wpcf7-response-output,
.contact-form .wpcf7-form.aborted .wpcf7-response-output{border-color:#e74c3c;color:#e74c3c;background:rgba(231,76,60,.04)}
@media(max-width:600px){.contact-form .wpcf7-form .form-row{grid-template-columns:1fr}}

/* 完了ページ */
.contact-thanks{padding:120px 0 100px;text-align:center}
.contact-thanks-icon{width:64px;height:64px;margin:0 auto 32px;border-radius:50%;background:var(--accent-pale);display:flex;align-items:center;justify-content:center}
.contact-thanks-icon svg{width:28px;height:28px;stroke:var(--accent);fill:none;stroke-width:1.5}
.contact-thanks h2{font-family:var(--font-en);font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:300;color:var(--ink);margin-bottom:24px;letter-spacing:.06em}
.contact-thanks p{font-size:.875rem;font-weight:300;line-height:2.2;color:var(--silver);max-width:520px;margin:0 auto}
.contact-thanks-link{display:inline-flex;align-items:center;gap:8px;margin-top:48px;font-family:var(--font-en);font-size:.8125rem;color:var(--accent);letter-spacing:.06em;border-bottom:1px solid transparent;transition:border-color .3s}
.contact-thanks-link:hover{border-color:var(--accent)}

/* ========== フッター ========== */
.footer{background:var(--white);border-top:1px solid var(--cloud);padding:60px 0 40px}
.footer-inner{display:flex;justify-content:space-between;align-items:flex-start}
.footer-logo{font-family:var(--font-en);font-size:1.25rem;font-weight:400;color:var(--ink);letter-spacing:.1em}
.footer-logo span{display:block;font-size:.625rem;letter-spacing:.2em;color:var(--silver);margin-top:4px;font-weight:300}
.footer-nav{display:flex;gap:32px}
.footer-nav a{font-size:.75rem;color:var(--silver);font-weight:300;transition:color .3s}
.footer-nav a:hover{color:var(--ink)}
.footer-copy{text-align:center;margin-top:48px;padding-top:24px;border-top:1px solid var(--cloud);font-size:.6875rem;color:var(--mist);font-family:var(--font-en);letter-spacing:.05em}

/* ========== レスポンシブ ========== */
@media(max-width:1023px){
  .hero-orb{width:500px;height:500px;right:-20%}
  .hero-words{display:none}
  .about-layout{grid-template-columns:1fr;gap:48px}
  .biz-cards{grid-template-columns:1fr 1fr}
  .biz-cards .biz-card:last-child{grid-column:span 2}
  .news-list{grid-template-columns:1fr 1fr}
  .profile-grid{grid-template-columns:repeat(3,1fr);gap:32px}
  .biz-images{grid-template-columns:1fr 1fr}
  .equip-grid{grid-template-columns:1fr 1fr}
  .product-item{grid-template-columns:1fr;gap:40px}
  .product-item:nth-child(even){direction:ltr}
  .media-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .page-hero .hero-orb{width:400px;height:400px}
}
@media(max-width:767px){
  .container{padding:0 24px}
  .section{padding:80px 0}
  .logo span{display:none}
  .nav-list{display:none}
  .header-right .lang-toggle,.header-right .lang-sep{display:none}
  .hamburger{display:flex}
  .hero{min-height:80vh}
  .hero-orb{display:none}
  .biz-cards{grid-template-columns:1fr}
  .biz-cards .biz-card:last-child{grid-column:span 1}
  .news-list{grid-template-columns:1fr}
  .profile-grid{grid-template-columns:1fr;gap:40px}
  .biz-images{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;gap:24px}
  .footer-nav{flex-wrap:wrap;gap:16px}
  .page-hero{min-height:30vh;padding-top:100px;padding-bottom:40px}
  .page-hero .hero-orb{display:none}
  .page-hero-en{font-size:clamp(2rem,8vw,3rem)}
  .equip-grid{grid-template-columns:1fr}
  .product-item{grid-template-columns:1fr;gap:32px}
  .media-grid{grid-template-columns:1fr}
  .biz-section{padding:60px 0}
  .company-table th{width:120px;padding:14px 16px}
  .company-table td{padding:14px 16px}
  .philosophy-box{padding:32px 24px}
}
