@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,700;1,700&family=Noto+Sans+JP:wght@300;400;500;700&family=DM+Sans:wght@300;400;500;700&display=swap');

:root {
  --bg:        #f5f2ec;
  --hero-dark: #1a2018;
  --text:      #1a1a1a;
  --text-mid:  #555550;
  --text-lt:   #888880;
  --accent:    #4a5c3f;
  --border:    #dedad3;
  --white:     #ffffff;
  --tag-bg:    #e8e4dc;
  --font-d:    'Montserrat','Noto Sans JP',sans-serif;
  --font-s:    'Noto Sans JP',sans-serif;
  --font-n:    'DM Sans','Noto Sans JP',sans-serif;
  --max:       1200px;
  --gutter:    clamp(20px,5vw,60px);
  --ease:      cubic-bezier(0.16,1,0.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-n);background:var(--bg);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}
.container{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}

/* ── HEADER ── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border);height:64px;display:flex;align-items:center}
.header-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gutter);width:100%;display:flex;align-items:center;justify-content:space-between}
.site-logo{font-family:var(--font-d);font-size:20px;font-weight:700;color:var(--text)}
.site-nav{display:flex;align-items:center;gap:8px}
.site-nav a{font-family:var(--font-n);font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mid);padding:6px 12px;transition:color .2s}
.site-nav a:hover{color:var(--text)}
.nav-div{color:var(--border);font-size:12px}
.btn-login{background:var(--text) !important;color:var(--white) !important;padding:10px 20px !important;border-radius:100px;transition:background .2s,transform .15s !important}
.btn-login:hover{background:var(--accent) !important;transform:translateY(-1px)}
.btn-login--outline{background:transparent !important;color:var(--text) !important;border:1px solid var(--border) !important}
.btn-login--outline:hover{background:var(--tag-bg) !important;transform:translateY(-1px)}

/* ── HERO ── */
.hero{margin-top:64px;display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 64px)}
.hero-left{background:var(--hero-dark);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:72px 56px 56px}
.hero-glow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.hero-glow-1{width:420px;height:420px;background:radial-gradient(circle,rgba(140,170,110,.28) 0%,transparent 70%);top:80px;left:-60px}
.hero-glow-2{width:320px;height:320px;background:radial-gradient(circle,rgba(180,200,150,.18) 0%,transparent 70%);top:200px;left:120px}
.hero-glow-3{width:260px;height:260px;background:radial-gradient(circle,rgba(100,130,80,.22) 0%,transparent 70%);bottom:120px;right:40px}
.hero-left-inner{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;justify-content:center}
.hero-title-ja{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Yu Gothic',sans-serif;font-size:clamp(52px,6.5vw,84px);font-weight:700;line-height:1.2;color:var(--white);margin-bottom:32px;letter-spacing:.02em}
.hero-divider{width:32px;height:2px;background:rgba(255,255,255,.35);margin-bottom:28px}
.hero-desc-ja{font-family:'Noto Sans JP','Yu Gothic',sans-serif;font-size:14px;font-weight:400;color:rgba(255,255,255,.6);line-height:2;letter-spacing:.04em}
.hero-scroll-indicator{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:40px}
.hero-scroll-text{font-family:var(--font-n);font-size:9px;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.35);writing-mode:vertical-lr;letter-spacing:.2em}
.hero-scroll-line{width:1px;height:40px;background:rgba(255,255,255,.25);display:block;animation:scrollLine 1.6s ease-in-out infinite}
@keyframes scrollLine{0%,100%{transform:scaleY(1);opacity:.4}50%{transform:scaleY(.5);opacity:.9}}
.hero-left-footer{position:relative;z-index:1;display:flex;align-items:center;gap:12px;font-family:var(--font-n);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.28)}
.hero-footer-sep{color:rgba(255,255,255,.18)}
.hero-right{background:var(--bg);display:flex;flex-direction:column;border-left:1px solid var(--border)}

/* フィーチャー記事 */
.hero-feature{flex:0 0 58%;position:relative;overflow:hidden;border-bottom:1px solid var(--border)}
.hero-feature-link{display:block;width:100%;height:100%;position:relative;text-decoration:none}
.hero-feature-img{width:100%;height:100%;min-height:280px;position:relative;background:var(--tag-bg);display:flex;align-items:center;justify-content:center;font-size:64px}
.hero-feature-img img{width:100%;height:100%;object-fit:cover}
.hero-feature-img-placeholder{font-size:64px}
.hero-feature-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,20,12,.88) 0%,rgba(15,20,12,.3) 55%,transparent 100%)}
.hero-feature-body{position:absolute;bottom:0;left:0;right:0;padding:32px 32px 28px;z-index:1}
.hero-feature-label{font-family:var(--font-n);font-size:9px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:12px}
.hero-feature-title{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Yu Gothic',sans-serif;font-size:clamp(20px,2.2vw,26px);font-weight:700;line-height:1.5;color:var(--white);margin-bottom:10px;letter-spacing:.02em}
.hero-feature-excerpt{font-family:'Noto Sans JP',sans-serif;font-size:12px;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:16px}
.hero-feature-cta{font-family:var(--font-n);font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.75);display:inline-flex;align-items:center;gap:8px;transition:gap .2s}
.hero-feature-link:hover .hero-feature-cta{gap:14px}
.hero-feature-dummy .hero-feature-img{background:#2a3028}

/* 記事カード（下3列） */
.hero-cards{flex:1;display:grid;grid-template-columns:repeat(3,1fr)}
.hero-card-item{display:flex;flex-direction:column;border-right:1px solid var(--border);text-decoration:none;transition:background .2s;position:relative}
.hero-card-item:last-child{border-right:none}
.hero-card-item:hover{background:rgba(0,0,0,.025)}
.hero-card-img{width:100%;aspect-ratio:4/3;background:var(--tag-bg);display:flex;align-items:center;justify-content:center;font-size:32px;overflow:hidden;flex-shrink:0}
.hero-card-img img{width:100%;height:100%;object-fit:cover}
.hero-card-body{padding:14px 16px 36px}
.hero-card-meta{font-family:var(--font-n);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-lt);margin-bottom:7px}
.hero-card-title{font-family:'Noto Sans JP','Yu Gothic',sans-serif;font-size:13px;font-weight:500;line-height:1.65;color:var(--text)}
.hero-card-num{position:absolute;bottom:14px;right:16px;font-family:var(--font-d);font-size:11px;color:var(--border);font-weight:700}

/* ── TICKER ── */
.area-ticker{border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;padding:20px 0}
.ticker-track{display:flex;animation:ticker 40s linear infinite;white-space:nowrap}
.ticker-item{font-family:var(--font-n);font-size:13px;font-weight:500;letter-spacing:.1em;color:var(--text-mid);padding:0 20px;display:flex;align-items:center;gap:20px;transition:color .2s}
.ticker-item:hover{color:var(--text)}
.ticker-item::after{content:'/';color:var(--border)}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── SECTION COMMON ── */
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:40px}
.section-title{font-family:var(--font-d);font-size:32px;font-weight:700;display:flex;align-items:baseline;gap:12px}
.section-title-ja{font-family:var(--font-n);font-size:13px;font-weight:400;color:var(--text-lt)}
.section-link{font-family:var(--font-n);font-size:12px;font-weight:500;letter-spacing:.06em;color:var(--text-mid);display:flex;align-items:center;gap:6px;transition:color .2s}
.section-link:hover{color:var(--text)}
.section-link::after{content:'→'}

/* ── AREA SECTION ── */
.section-area{padding:80px 0 64px;border-bottom:1px solid var(--border)}
.area-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:10px}
.area-btn{font-family:var(--font-n);font-size:13px;font-weight:500;color:var(--text);border:1.5px solid var(--border);border-radius:100px;padding:10px 8px;background:transparent;cursor:pointer;transition:all .2s var(--ease);letter-spacing:.04em;text-align:center;width:100%}
.area-btn:hover{background:var(--text);color:var(--white);border-color:var(--text);transform:translateY(-2px)}

/* ── LATEST SECTION ── */
.section-latest{padding:80px 0 100px}
.latest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);border:1px solid var(--border)}

/* ── ARTICLE CARD ── */
.article-card{background:var(--bg);cursor:pointer;transition:background .2s;display:flex;flex-direction:column}
.article-card:hover{background:#ede9e1}
.article-card-img{width:100%;aspect-ratio:4/3;background:#e0dbd0;display:flex;align-items:center;justify-content:center;font-size:48px;overflow:hidden;position:relative}
.article-card-img img{width:100%;height:100%;object-fit:cover}
.article-card-tag{position:absolute;top:14px;left:14px;background:var(--text);color:var(--white);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:100px}
.article-card-body{padding:24px 28px 32px;flex:1}
.article-card-meta{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-lt);margin-bottom:10px;font-family:var(--font-n)}
.article-card-title{font-family:var(--font-s);font-size:17px;font-weight:500;line-height:1.6;color:var(--text);margin-bottom:10px}
.article-card-loc{font-size:12px;color:var(--text-lt);font-family:var(--font-n)}

/* ── FOOTER ── */
.site-footer{background:var(--bg);border-top:1px solid var(--border);padding:56px 0 40px}
.footer-inner{display:grid;grid-template-columns:1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-logo{font-family:var(--font-d);font-size:18px;font-weight:700;margin-bottom:12px}
.footer-tagline{font-size:12px;color:var(--text-lt);line-height:1.8;margin-bottom:20px}
.footer-social{display:flex;gap:12px}
.footer-social a{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mid);transition:color .2s}
.footer-social a:hover{color:var(--text)}
.footer-col-title{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text-lt);margin-bottom:16px}
.footer-area-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 16px}
.footer-area-grid a,.footer-nav a{font-size:13px;color:var(--text-mid);transition:color .2s;line-height:2}
.footer-area-grid a:hover,.footer-nav a:hover{color:var(--text)}
.footer-nav{display:flex;flex-direction:column}
.footer-member{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.footer-member a{font-size:12px;color:var(--text-mid);border:1px solid var(--border);padding:8px 16px;border-radius:4px;text-align:center;transition:all .2s}
.footer-member a:hover{background:var(--text);color:var(--white);border-color:var(--text)}
.footer-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a,.footer-copy{font-size:11px;color:var(--text-lt);letter-spacing:.04em;transition:color .2s}
.footer-bottom-links a:hover{color:var(--text)}

/* ── PAGE HERO (light) ── */
.page-hero{margin-top:64px;padding:80px 0 64px;border-bottom:1px solid var(--border)}
.page-hero-label{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--text-lt);margin-bottom:16px}
.page-hero-title{font-family:var(--font-d);font-size:clamp(36px,5vw,60px);font-weight:700;color:var(--text);margin-bottom:20px;line-height:1.15}
.page-hero-lead{font-family:var(--font-s);font-size:15px;color:var(--text-mid);line-height:2;max-width:520px}

/* ── AREA PAGE ── */
.area-nav{border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:64px;z-index:50}
.area-nav-grid{display:flex;overflow-x:auto;scrollbar-width:none}
.area-nav-grid::-webkit-scrollbar{display:none}
.area-nav-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:16px 0;border-right:1px solid var(--border);border-left:1px solid transparent;white-space:nowrap;transition:background .2s;flex:1;min-width:0;}
.area-nav-btn:first-child{border-left:1px solid var(--border)}
.area-nav-btn:hover{background:rgba(0,0,0,.03)}
.area-nav-btn.active{background:var(--text)}
.area-nav-icon{font-size:18px;line-height:1}
.area-nav-label{font-family:var(--font-s);font-size:13px;font-weight:500;color:var(--text)}
.area-nav-btn.active .area-nav-label,.area-nav-btn.active .area-nav-en{color:var(--white)}
.area-nav-en{font-family:var(--font-n);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-lt)}
@media(max-width:768px){
  .area-nav-grid{flex-wrap:nowrap}
  .area-nav-btn{flex:0 0 auto;min-width:80px;padding:14px 10px;border-right:1px solid var(--border)}
  .area-nav-label{font-size:12px}
  .area-nav-en{display:none}
}
.area-detail{padding:72px 0 100px}
.area-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:40px;margin-bottom:56px;flex-wrap:wrap}
.area-detail-en{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text-lt);display:block;margin-bottom:8px}
.area-detail-title{font-family:var(--font-d);font-size:clamp(36px,5vw,56px);font-weight:700;color:var(--text);line-height:1.1}
.area-detail-prefs{display:flex;flex-wrap:wrap;gap:8px;align-items:center;max-width:480px}
.area-pref-tag{font-family:var(--font-n);font-size:12px;color:var(--text-mid);background:var(--tag-bg);padding:6px 14px;border-radius:100px}
.area-posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);border:1px solid var(--border)}
.area-empty{text-align:center;padding:80px 0}
.area-empty-icon{font-size:64px;margin-bottom:24px;line-height:1}
.area-empty-text{font-family:var(--font-s);font-size:15px;color:var(--text-lt);line-height:2}
.area-map-section{padding:72px 0 100px}
.area-all-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);border:1px solid var(--border)}
.area-card{background:var(--bg);padding:36px 32px;display:flex;align-items:center;gap:20px;transition:background .2s}
.area-card:hover{background:#ede9e1}
.area-card-img{width:160px;height:120px;flex-shrink:0;border-radius:6px;overflow:hidden}.area-card-img img{width:100%;height:100%;object-fit:cover;display:block}.area-card-img-placeholder{width:100%;height:100%;background:var(--border)}
.area-card-body{flex:1}
.area-card-en{font-family:var(--font-n);font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-lt);margin-bottom:4px}
.area-card-label{font-family:var(--font-d);font-size:22px;font-weight:700;color:var(--text);margin-bottom:8px}
.area-card-prefs{font-family:var(--font-n);font-size:11px;color:var(--text-lt);line-height:1.6}
.area-card-arrow{font-size:18px;color:var(--border);transition:color .2s,transform .2s}
.area-card:hover .area-card-arrow{color:var(--text);transform:translateX(4px)}

/* ── ABOUT PAGE ── */
.about-hero{background:var(--hero-dark);min-height:80vh;display:flex;flex-direction:column;justify-content:flex-end;padding:120px var(--gutter) 80px;position:relative;overflow:hidden;margin-top:64px}
.about-hero-glow{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none}
.about-hero-glow-1{width:500px;height:500px;background:radial-gradient(circle,rgba(140,170,110,.22) 0%,transparent 70%);top:-80px;right:10%}
.about-hero-glow-2{width:300px;height:300px;background:radial-gradient(circle,rgba(180,200,150,.14) 0%,transparent 70%);bottom:60px;left:30%}
.about-hero-inner{position:relative;z-index:1;max-width:760px}
.about-hero-label{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:28px}
.about-hero-title{font-family:var(--font-d);font-size:clamp(52px,8vw,96px);font-weight:700;line-height:1.05;color:var(--white);margin-bottom:32px}
.about-hero-title em{font-style:italic;color:rgba(255,255,255,.7)}
.about-hero-lead{font-family:var(--font-s);font-size:clamp(14px,1.6vw,17px);color:rgba(255,255,255,.6);line-height:2;max-width:560px}
.about-mission{padding:100px 0;border-bottom:1px solid var(--border)}
.about-mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.about-section-title{font-family:var(--font-d);font-size:clamp(28px,3.5vw,44px);font-weight:700;line-height:1.3;color:var(--text);margin-top:16px}
.about-body-text{font-family:var(--font-s);font-size:15px;line-height:2;color:var(--text-mid);margin-bottom:24px}
.about-values{padding:100px 0;border-bottom:1px solid var(--border)}
.about-values-header{margin-bottom:56px}
.about-values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);border:1px solid var(--border)}
.about-value-card{background:var(--bg);padding:48px 36px}
.about-value-num{font-family:var(--font-d);font-size:40px;font-weight:700;color:var(--border);display:block;margin-bottom:20px;line-height:1}
.about-value-title{font-family:var(--font-s);font-size:20px;font-weight:700;color:var(--text);margin-bottom:16px}
.about-value-text{font-family:var(--font-n);font-size:13px;line-height:1.9;color:var(--text-mid)}
.about-concept{background:var(--hero-dark);overflow:hidden}
.about-concept-inner{max-width:var(--max);margin:0 auto;padding:100px var(--gutter);display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative}
.about-concept-title{font-family:var(--font-d);font-size:clamp(32px,4vw,52px);font-weight:700;font-style:italic;color:var(--white);margin:16px 0 28px;line-height:1.15}
.about-concept-body{font-family:var(--font-s);font-size:14px;line-height:2.1;color:rgba(255,255,255,.55)}
.about-concept-deco{text-align:right;position:relative;z-index:1}
.concept-deco-text{font-family:var(--font-d);font-size:clamp(60px,9vw,120px);font-weight:700;line-height:.95;color:rgba(255,255,255,.04);display:block;user-select:none}
.concept-deco-text em{font-style:italic}
.about-concept-glow{position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(140,170,110,.15) 0%,transparent 70%);border-radius:50%;filter:blur(80px);right:-100px;top:50%;transform:translateY(-50%);pointer-events:none}
.about-company{padding:100px 0;border-bottom:1px solid var(--border)}
.about-company-header{margin-bottom:48px}
.about-company-table{max-width:800px}
.about-company-row{display:grid;grid-template-columns:160px 1fr;gap:24px;padding:20px 0;border-bottom:1px solid var(--border)}
.about-company-row:first-child{border-top:1px solid var(--border)}
.about-company-row dt{font-family:var(--font-n);font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--text-lt);padding-top:2px}
.about-company-row dd{font-family:var(--font-s);font-size:15px;color:var(--text);line-height:1.7}
.about-cta{padding:100px 0 120px}
.about-cta-inner{text-align:center}
.about-cta-label{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--text-lt);margin-bottom:20px}
.about-cta-title{font-family:var(--font-d);font-size:clamp(28px,4vw,48px);font-weight:700;line-height:1.4;color:var(--text);margin-bottom:48px}
.about-cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.about-cta-btn{font-family:var(--font-n);font-size:14px;font-weight:500;letter-spacing:.06em;padding:16px 40px;border-radius:100px;transition:all .25s var(--ease);display:inline-block}
.about-cta-btn--primary{background:var(--text);color:var(--white);border:1.5px solid var(--text)}
.about-cta-btn--primary:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}
.about-cta-btn--secondary{background:transparent;color:var(--text);border:1.5px solid var(--border)}
.about-cta-btn--secondary:hover{border-color:var(--text);transform:translateY(-2px)}

.sidebar-info-row--block{align-items:flex-start;flex-direction:column;gap:4px;text-align:left}
.sidebar-info-row--block .sidebar-info-label{margin-bottom:2px;text-align:left}
.sidebar-info-row--block .sidebar-info-value{font-size:12px;line-height:1.6;text-align:left}
.sidebar-info-link{font-family:var(--font-n);font-size:13px;color:var(--accent);transition:opacity .2s}
.sidebar-info-link:hover{opacity:.7}
.sidebar-info-link--ext,.sidebar-info-link--ig{font-size:12px;font-weight:500;letter-spacing:.04em}

/* ── SINGLE PAGE ── */
.single-hero{margin-top:64px;position:relative;min-height:480px;display:flex;align-items:flex-end;background:var(--hero-dark);overflow:hidden}
.single-hero-img{position:absolute;inset:0}
.single-hero-img img{width:100%;height:100%;object-fit:cover;opacity:.5}
.single-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,26,18,.92) 0%,rgba(20,26,18,.2) 60%,transparent 100%)}
.single-hero-inner{position:relative;z-index:1;padding-bottom:60px;padding-top:120px}
.single-hero-meta{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.single-meta-region{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);background:rgba(255,255,255,.1);padding:4px 12px;border-radius:100px}
.single-meta-cat{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.8);background:var(--accent);padding:4px 12px;border-radius:100px}
.single-hero-title{font-family:var(--font-d);font-size:clamp(28px,4vw,52px);font-weight:700;color:var(--white);line-height:1.3;max-width:800px;margin-bottom:16px}
.single-hero-date{font-family:var(--font-n);font-size:12px;color:rgba(255,255,255,.4);letter-spacing:.1em}
.single-body{padding:72px 0 80px}
.single-body-inner{display:grid;grid-template-columns:1fr 300px;gap:64px;align-items:start}
.single-content{font-family:var(--font-s);font-size:16px;line-height:2;color:var(--text)}
.single-content p{margin-bottom:1.8em}
.single-content h2{font-family:var(--font-d);font-size:26px;font-weight:700;margin:2.4em 0 .8em;padding-bottom:12px;border-bottom:1px solid var(--border);line-height:1.4}
.single-content h3{font-family:var(--font-s);font-size:20px;font-weight:700;margin:2em 0 .6em}
.single-content img{width:100%;border-radius:4px;margin:2em 0}
.single-content ul,.single-content ol{padding-left:1.5em;margin-bottom:1.8em}
.single-content ul{list-style:disc}
.single-content ol{list-style:decimal}
.single-content li{margin-bottom:.4em}
.single-content a{color:var(--accent);text-decoration:underline}
.single-content blockquote{border-left:3px solid var(--accent);padding:16px 24px;margin:2em 0;background:var(--tag-bg);font-style:italic;color:var(--text-mid)}
.single-sidebar{position:sticky;top:84px}
.sidebar-block{margin-bottom:32px;padding:24px;border:1px solid var(--border);border-radius:4px}
.sidebar-block-title{font-family:var(--font-n);font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--text-lt);margin-bottom:16px}
.sidebar-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.sidebar-info-row:last-child{border-bottom:none}
.sidebar-info-label{color:var(--text-lt);font-family:var(--font-n)}
.sidebar-info-value{color:var(--text);font-family:var(--font-s)}
.sidebar-related{display:flex;flex-direction:column;gap:16px}
.sidebar-related-item{display:flex;gap:12px;align-items:flex-start;transition:opacity .2s}
.sidebar-related-item:hover{opacity:.7}
.sidebar-related-thumb{width:64px;height:48px;background:var(--tag-bg);border-radius:4px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px}
.sidebar-related-thumb img{width:100%;height:100%;object-fit:cover}
.sidebar-related-loc{font-size:10px;color:var(--text-lt);margin-bottom:4px;font-family:var(--font-n)}
.sidebar-related-title{font-size:12px;color:var(--text);line-height:1.5;font-family:var(--font-s)}
.single-nav{padding:48px 0 80px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px}
.single-nav-back{font-family:var(--font-n);font-size:13px;font-weight:500;color:var(--text-mid);letter-spacing:.04em;transition:color .2s}
.single-nav-back:hover{color:var(--text)}
.single-nav-posts{display:flex;gap:24px}
.single-nav-link{display:flex;flex-direction:column;gap:4px;max-width:200px;transition:opacity .2s}
.single-nav-link:hover{opacity:.7}
.single-nav-next{text-align:right}
.single-nav-link span{font-family:var(--font-n);font-size:9px;font-weight:700;letter-spacing:.2em;color:var(--text-lt)}
.single-nav-link p{font-family:var(--font-s);font-size:13px;color:var(--text);line-height:1.5}

/* ── PREF NAV ── */
.pref-nav{border-bottom:1px solid var(--border);background:var(--bg);padding:0}
.pref-nav-list{display:flex;flex-wrap:wrap;gap:8px;padding:16px 0}
.pref-nav-btn{font-family:var(--font-n);font-size:12px;font-weight:500;color:var(--text-mid);background:transparent;border:1px solid var(--border);border-radius:100px;padding:6px 16px;transition:all .2s;cursor:pointer}
.pref-nav-btn:hover{border-color:var(--text);color:var(--text)}
.pref-nav-btn.active{background:var(--text);color:var(--white);border-color:var(--text)}
.pref-nav--cat{background:var(--tag-bg)}
.pref-nav-btn--cat{font-size:11px;padding:5px 14px;color:var(--text-lt);border-color:transparent}
.pref-nav-btn--cat:hover{border-color:var(--border);color:var(--text);background:var(--white)}
.pref-nav-btn--cat.active{background:var(--accent);color:var(--white);border-color:var(--accent)}

/* ── NEWS TABS ── */
.news-tabs{border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:64px;z-index:50}
.news-tab-list{display:flex;gap:0}
.news-tab{font-family:var(--font-n);font-size:13px;font-weight:500;letter-spacing:.04em;color:var(--text-mid);padding:20px 32px;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}
.news-tab:hover{color:var(--text)}
.news-tab.active{color:var(--text);border-bottom-color:var(--text)}
.news-list-left{flex:1}
.news-list-kind{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.12em;padding:3px 10px;border-radius:100px}
.news-list-kind--hq{background:var(--hero-dark);color:var(--white)}
.news-list-kind--news{background:var(--accent);color:var(--white)}
.news-list-kind--blog{background:var(--tag-bg);color:var(--text-mid)}

/* ── NEWS ── */
.spot-news-section{padding:64px 0;border-top:1px solid var(--border)}
.spot-news-list{display:flex;flex-direction:column}
.spot-news-item{display:grid;grid-template-columns:100px 1fr 24px;align-items:center;gap:20px;padding:20px 0;border-bottom:1px solid var(--border);transition:background .2s}
.spot-news-item:first-child{border-top:1px solid var(--border)}
.spot-news-item:hover{padding-left:8px}
.spot-news-date{font-family:var(--font-n);font-size:12px;color:var(--text-lt);letter-spacing:.06em;white-space:nowrap}
.spot-news-title{font-family:var(--font-s);font-size:15px;color:var(--text);line-height:1.5}
.spot-news-arrow{font-size:14px;color:var(--border);transition:color .2s,transform .2s}
.spot-news-item:hover .spot-news-arrow{color:var(--text);transform:translateX(4px)}

.news-archive{padding:72px 0 100px}
.news-list{display:flex;flex-direction:column}
.news-list-item{display:grid;grid-template-columns:1fr 24px;gap:16px;padding:32px 0;border-bottom:1px solid var(--border);transition:padding .2s var(--ease)}
.news-list-item:first-child{border-top:1px solid var(--border)}
.news-list-item:hover{padding-left:12px}
.news-list-meta{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.news-list-date{font-family:var(--font-n);font-size:12px;color:var(--text-lt);letter-spacing:.06em}
.news-list-spot{font-family:var(--font-n);font-size:11px;font-weight:600;color:var(--white);background:var(--accent);padding:3px 10px;border-radius:100px}
.news-list-region{font-family:var(--font-n);font-size:11px;color:var(--text-lt);background:var(--tag-bg);padding:3px 10px;border-radius:100px}
.news-list-title{font-family:var(--font-s);font-size:18px;font-weight:500;color:var(--text);line-height:1.5;margin-bottom:8px}
.news-list-excerpt{font-family:var(--font-n);font-size:13px;color:var(--text-mid);line-height:1.7}
.news-list-arrow{font-size:18px;color:var(--border);transition:color .2s,transform .2s;align-self:center}
.news-list-item:hover .news-list-arrow{color:var(--text);transform:translateX(4px)}
.news-empty{text-align:center;padding:80px 0}
.news-empty-icon{font-size:56px;margin-bottom:20px}
.news-empty-text{font-family:var(--font-s);font-size:15px;color:var(--text-lt)}

/* ── CREATORS TOP ── */
.section-creators{padding:80px 0 120px;border-top:1px solid var(--border)}
.creators-top-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--border);border:1px solid var(--border)}
.creator-top-card{background:var(--bg);display:flex;flex-direction:column;transition:background .2s}
.creator-top-card:hover{background:#ede9e1}
.creator-top-img{width:100%;aspect-ratio:3/4;background:var(--tag-bg);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}
.creator-top-img img{width:100%;height:100%;object-fit:cover;object-position:top}
.creator-top-placeholder{font-size:48px}
.creator-top-body{padding:16px 20px 24px}
.creator-top-name{font-family:var(--font-d);font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}
.creator-top-catch{font-family:var(--font-s);font-size:11px;color:var(--text-mid);line-height:1.6;margin-bottom:6px}
.creator-top-area{font-family:var(--font-n);font-size:10px;color:var(--text-lt)}
@media(max-width:960px){.creators-top-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.creators-top-grid{grid-template-columns:1fr 1fr}}

/* ── CREATORS LIST ── */
.creators-filter{border-bottom:1px solid var(--border);background:var(--bg);padding:0}
.creators-filter-list{display:flex;flex-wrap:wrap;gap:8px;padding:20px 0}
.creators-filter-btn{font-family:var(--font-n);font-size:12px;font-weight:500;color:var(--text-mid);background:transparent;border:1px solid var(--border);border-radius:100px;padding:6px 18px;transition:all .2s;cursor:pointer}
.creators-filter-btn:hover{border-color:var(--text);color:var(--text)}
.creators-filter-btn.active{background:var(--text);color:var(--white);border-color:var(--text)}
.creators-archive{padding:72px 0 100px}
.creators-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--border);border:1px solid var(--border)}
.creator-card{background:var(--bg);display:flex;flex-direction:column;transition:background .2s;cursor:pointer}
.creator-card:hover{background:#ede9e1}
.creator-card-img{width:100%;aspect-ratio:1/1;background:var(--tag-bg);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}
.creator-card-img img{width:100%;height:100%;object-fit:cover}
.creator-card-placeholder{font-size:48px}
.creator-card-type{position:absolute;top:12px;left:12px;background:var(--text);color:var(--white);font-size:9px;font-weight:700;letter-spacing:.1em;padding:4px 10px;border-radius:100px;font-family:var(--font-n)}
.creator-card-body{padding:20px 24px 28px}
.creator-card-name{font-family:var(--font-d);font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px}
.creator-card-catch{font-family:var(--font-s);font-size:12px;color:var(--text-mid);line-height:1.6;margin-bottom:8px}
.creator-card-area{font-family:var(--font-n);font-size:11px;color:var(--text-lt);margin-bottom:10px}
.creator-card-sns{display:flex;gap:6px;flex-wrap:wrap}
.creator-sns-icon{font-family:var(--font-n);font-size:9px;font-weight:700;letter-spacing:.08em;color:var(--text-mid);background:var(--tag-bg);padding:3px 8px;border-radius:100px}

/* ── CREATOR SINGLE ── */
.creator-hero{padding:100px 0 80px;border-bottom:1px solid var(--border);margin-top:64px}
.creator-hero-inner{display:grid;grid-template-columns:320px 1fr;gap:72px;align-items:start}
.creator-hero-img{border-radius:8px;overflow:hidden;aspect-ratio:1/1;background:var(--tag-bg)}
.creator-hero-img img{width:100%;height:100%;object-fit:cover}
.creator-hero-placeholder{width:100%;aspect-ratio:1/1;background:var(--tag-bg);display:flex;align-items:center;justify-content:center;font-size:80px;border-radius:8px}
.creator-hero-type{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text-lt);margin-bottom:16px}
.creator-hero-name{font-family:var(--font-d);font-size:clamp(36px,5vw,60px);font-weight:700;color:var(--text);line-height:1.15;margin-bottom:16px}
.creator-hero-catch{font-family:var(--font-s);font-size:18px;color:var(--text-mid);line-height:1.6;margin-bottom:16px;font-style:italic}
.creator-hero-area{font-family:var(--font-n);font-size:13px;color:var(--text-lt);margin-bottom:32px}
.creator-hero-sns{display:flex;gap:10px;flex-wrap:wrap}
.creator-sns-btn{font-family:var(--font-n);font-size:12px;font-weight:600;letter-spacing:.06em;padding:10px 20px;border-radius:100px;border:1.5px solid var(--border);color:var(--text-mid);transition:all .2s}
.creator-sns-btn:hover{border-color:var(--text);color:var(--text)}
.creator-sns-btn--ig{border-color:#e1306c;color:#e1306c}
.creator-sns-btn--ig:hover{background:#e1306c;color:var(--white)}
.creator-sns-btn--x{border-color:var(--text);color:var(--text)}
.creator-sns-btn--x:hover{background:var(--text);color:var(--white)}
.creator-sns-btn--web{border-color:var(--accent);color:var(--accent)}
.creator-sns-btn--web:hover{background:var(--accent);color:var(--white)}
.creator-about{padding:80px 0;border-bottom:1px solid var(--border)}
.creator-about-inner{max-width:760px}
.creator-section-label{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--text-lt);margin-bottom:12px}
.creator-section-title{font-family:var(--font-d);font-size:28px;font-weight:700;color:var(--text);margin-bottom:32px}
.creator-content{font-family:var(--font-s);font-size:16px;line-height:2;color:var(--text-mid)}
.creator-content p{margin-bottom:1.6em}
.creator-portfolio{padding:80px 0}
.creator-portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);border:1px solid var(--border);margin-top:32px}
.creator-portfolio-item{aspect-ratio:4/3;overflow:hidden;background:var(--tag-bg)}
.creator-portfolio-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.creator-portfolio-item:hover img{transform:scale(1.04)}

/* Creators Responsive */
@media(max-width:960px){
  .creators-grid{grid-template-columns:repeat(2,1fr)}
  .creator-hero-inner{grid-template-columns:200px 1fr;gap:40px}
  .creator-portfolio-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .creators-grid{grid-template-columns:1fr 1fr}
  .creator-hero-inner{grid-template-columns:1fr}
  .creator-portfolio-grid{grid-template-columns:1fr 1fr}
}

/* ── CONTACT SELECT ── */
.contact-select-section{padding:72px 0 100px}
.contact-select-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);border:1px solid var(--border);margin-bottom:48px}
.contact-select-card{background:var(--bg);padding:48px 36px;display:flex;flex-direction:column;gap:24px;transition:background .2s;position:relative}
.contact-select-card:hover{background:#ede9e1}
.contact-select-icon{font-size:40px;line-height:1}
.contact-select-en{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text-lt);margin-bottom:8px}
.contact-select-title{font-family:var(--font-d);font-size:22px;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:12px}
.contact-select-text{font-family:var(--font-n);font-size:13px;color:var(--text-mid);line-height:1.8;flex:1}
.contact-select-arrow{font-size:20px;color:var(--border);transition:color .2s,transform .2s;align-self:flex-end}
.contact-select-card:hover .contact-select-arrow{color:var(--text);transform:translateX(4px)}
.contact-select-note{text-align:center;padding:24px 0}
.contact-select-note p{font-family:var(--font-n);font-size:13px;color:var(--text-mid)}
.contact-direct-email{color:var(--accent);font-weight:500;transition:opacity .2s}
.contact-direct-email:hover{opacity:.7}

/* ── CONTACT FORM ── */
.contact-body{padding:72px 0 120px}
.contact-inner{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:start}
.contact-info{position:sticky;top:84px}
.contact-info-block{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--border)}
.contact-info-label{font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text-lt);margin-bottom:10px}
.contact-info-text{font-family:var(--font-s);font-size:14px;color:var(--text-mid);line-height:1.9}
.contact-info-email{font-family:var(--font-n);font-size:15px;font-weight:500;color:var(--accent);transition:opacity .2s}
.contact-info-email:hover{opacity:.7}
.contact-form-wrap{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:48px}
.contact-form-group{margin-bottom:24px}
.contact-form-label{display:block;font-family:var(--font-n);font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--text);margin-bottom:8px}
.contact-required{font-size:10px;color:var(--white);background:#c0392b;padding:2px 8px;border-radius:100px;margin-left:8px;font-weight:700}
.contact-form-input,.contact-form-select,.contact-form-textarea{width:100%;font-family:var(--font-n);font-size:14px;color:var(--text);background:var(--bg);border:1.5px solid var(--border);border-radius:6px;padding:12px 16px;transition:border-color .2s;outline:none;appearance:none}
.contact-form-input:focus,.contact-form-select:focus,.contact-form-textarea:focus{border-color:var(--accent)}
.contact-form-textarea{resize:vertical;min-height:140px}
.contact-form-privacy{margin-bottom:28px}
.contact-privacy-check{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-family:var(--font-n);font-size:13px;color:var(--text-mid);line-height:1.6}
.contact-privacy-check input{margin-top:3px;flex-shrink:0;accent-color:var(--accent)}
.contact-privacy-check a{color:var(--accent);text-decoration:underline}
.contact-form-btn{width:100%;font-family:var(--font-n);font-size:15px;font-weight:600;letter-spacing:.06em;color:var(--white);background:var(--text);border:none;border-radius:100px;padding:18px 32px;cursor:pointer;transition:all .25s var(--ease)}
.contact-form-btn:hover{background:var(--accent);transform:translateY(-2px)}
.contact-thanks{text-align:center;padding:48px 24px}
.contact-thanks-icon{font-size:48px;margin-bottom:20px}
.contact-thanks-title{font-family:var(--font-d);font-size:28px;font-weight:700;color:var(--text);margin-bottom:16px}
.contact-thanks-text{font-family:var(--font-s);font-size:15px;color:var(--text-mid);line-height:2;margin-bottom:32px}
.contact-thanks-btn{display:inline-block;font-family:var(--font-n);font-size:14px;font-weight:500;color:var(--white);background:var(--text);padding:14px 32px;border-radius:100px;transition:all .2s}
.contact-thanks-btn:hover{background:var(--accent)}

/* ── PRIVACY ── */
.privacy-body{padding:72px 0 120px}
.privacy-inner{max-width:800px}
.privacy-updated{font-family:var(--font-n);font-size:12px;color:var(--text-lt);margin-bottom:56px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.privacy-section{margin-bottom:56px;padding-bottom:56px;border-bottom:1px solid var(--border)}
.privacy-section:last-child{border-bottom:none}
.privacy-section-title{font-family:var(--font-d);font-size:20px;font-weight:700;color:var(--text);margin-bottom:20px}
.privacy-section-body{font-family:var(--font-s);font-size:15px;color:var(--text-mid);line-height:2}

/* Contact / Privacy Responsive */
@media(max-width:960px){
  .contact-select-grid{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr;gap:40px}
  .contact-info{position:static}
  .contact-form-wrap{padding:32px 24px}
}

/* ── ANIMATIONS ── */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{padding:80px 32px 60px;min-height:70vh}
  .hero-right{border-left:none;border-top:1px solid var(--border)}
  .hero-feature{flex:none;min-height:300px}
  .hero-cards{grid-template-columns:repeat(3,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
  .latest-grid{grid-template-columns:1fr 1fr}
  .about-mission-grid{grid-template-columns:1fr;gap:40px}
  .about-values-grid{grid-template-columns:1fr}
  .about-concept-inner{grid-template-columns:1fr}
  .about-concept-deco{display:none}
  .about-company-row{grid-template-columns:120px 1fr}
  .area-all-grid{grid-template-columns:repeat(2,1fr)}
  .area-posts-grid{grid-template-columns:repeat(2,1fr)}
  .area-detail-header{flex-direction:column;gap:24px}
  .single-body-inner{grid-template-columns:1fr}
  .single-sidebar{position:static}
  .area-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:640px){
  .nav-div{display:none}
  .site-nav a:not(.btn-login){display:none}
  .hero-left{padding:60px 24px 40px;min-height:60vh}
  .hero-right{border-left:none;border-top:1px solid var(--border)}
  .hero-title-ja{font-size:clamp(40px,12vw,60px)}
  .hero-cards{grid-template-columns:1fr}
  .hero-card-item{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;align-items:stretch}
  .hero-card-img{width:120px;min-width:120px;aspect-ratio:auto;min-height:90px;flex-shrink:0}
  .hero-card-body{padding:14px 16px}
  .hero-card-num{position:static;align-self:flex-end;padding:0 12px 14px 0;margin-left:auto}
  .latest-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .about-hero{padding:100px 24px 60px}
  .about-company-row{grid-template-columns:1fr;gap:6px}
  .area-all-grid{grid-template-columns:1fr}
  .area-posts-grid{grid-template-columns:1fr}
  .area-nav-btn{padding:12px 6px}
  .single-nav{flex-direction:column;align-items:flex-start}
  .area-grid{grid-template-columns:repeat(3,1fr)}
  .creators-top-grid{grid-template-columns:repeat(2,1fr)}
  .contact-select-grid{grid-template-columns:1fr}
  .btn-login{padding:8px 14px !important;font-size:12px !important}
}

/* ── HAMBURGER ── */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:6px;z-index:200}
.hamburger-line{display:block;width:24px;height:1.5px;background:var(--text);transition:all .3s var(--ease);transform-origin:center}
.hamburger.is-open .hamburger-line:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.is-open .hamburger-line:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.is-open .hamburger-line:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── DRAWER ── */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s}
.drawer-overlay.is-open{opacity:1;pointer-events:auto}
.drawer-nav{position:fixed;top:0;right:0;width:min(320px,85vw);height:100%;background:var(--bg);z-index:400;transform:translateX(100%);transition:transform .35s var(--ease);display:flex;flex-direction:column;box-shadow:-4px 0 24px rgba(0,0,0,0.1)}
.drawer-nav.is-open{transform:translateX(0)}
.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px;border-bottom:1px solid var(--border)}
.drawer-logo{font-family:var(--font-d);font-size:14px;font-weight:700;color:var(--text)}
.drawer-close{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text-mid);padding:8px;line-height:1;transition:color .2s}
.drawer-close:hover{color:var(--text)}
.drawer-links{flex:1;padding:32px 0;overflow-y:auto}
.drawer-links li{border-bottom:1px solid var(--border)}
.drawer-links a{display:block;padding:18px 28px;font-family:var(--font-n);font-size:13px;font-weight:500;letter-spacing:.12em;color:var(--text-mid);transition:color .2s,background .2s}
.drawer-links a:hover{color:var(--text);background:#ede9e1}
.drawer-footer{padding:24px 28px;border-top:1px solid var(--border)}
.drawer-login{display:block;text-align:center;padding:14px;background:var(--text);color:var(--white);font-family:var(--font-n);font-size:13px;font-weight:600;letter-spacing:.06em;border-radius:100px;transition:background .2s}
.drawer-login:hover{background:var(--accent)}

@media(max-width:768px){
  .hamburger{display:flex}
  .site-nav{display:none}
}

/* ===== 検索ボックス ===== */
.hero-search-wrap{background:var(--bg);border-bottom:1px solid var(--border);padding:28px 0}
.search-bar{width:100%}
.search-bar-inner{display:flex;align-items:center;background:var(--white);border:1.5px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.07);transition:box-shadow .2s}
.search-bar-inner:focus-within{box-shadow:0 4px 32px rgba(0,0,0,.13);border-color:var(--text)}
.search-bar-field{display:flex;align-items:center;gap:10px;padding:0 20px;flex:1;min-width:0}
.search-bar-field svg{flex-shrink:0;color:var(--text-lt)}
.search-bar-field--keyword{flex:2}
.search-bar-field input[type=text]{border:none;outline:none;background:transparent;font-family:var(--font-n);font-size:14px;color:var(--text);width:100%;padding:20px 0}
.search-bar-field input[type=text]::placeholder{color:var(--text-lt)}
.search-bar-field select{border:none;outline:none;background:transparent;font-family:var(--font-n);font-size:14px;color:var(--text);cursor:pointer;padding:20px 0;width:100%;appearance:none;-webkit-appearance:none}
.search-bar-divider{width:1px;height:36px;background:var(--border);flex-shrink:0}
.search-bar-btn{flex-shrink:0;background:var(--text);color:var(--white);border:none;font-family:var(--font-n);font-size:14px;font-weight:600;padding:0 32px;height:64px;cursor:pointer;letter-spacing:.05em;transition:opacity .2s;white-space:nowrap}
.search-bar-btn:hover{opacity:.8}

/* 検索結果ページ */
.search-page-form-wrap{background:var(--bg);border-bottom:1px solid var(--border);padding:24px 0;margin-top:64px}
.search-bar--result .search-bar-inner{border-radius:10px}
.search-results{padding:56px 0 80px}
.search-result-count{font-family:var(--font-n);font-size:13px;color:var(--text-lt);margin-bottom:32px}
.search-result-count strong{color:var(--text);font-weight:600}
.search-result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.article-card-link{display:flex;flex-direction:column;text-decoration:none;color:inherit}
.article-card-img-placeholder{width:100%;height:100%;background:var(--tag-bg)}
.search-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:48px}
.search-page-btn{font-family:var(--font-n);font-size:13px;color:var(--text);border:1px solid var(--border);padding:10px 24px;border-radius:6px;text-decoration:none;transition:background .2s}
.search-page-btn:hover{background:var(--tag-bg)}
.search-page-info{font-family:var(--font-n);font-size:13px;color:var(--text-lt)}
.search-empty{text-align:center;padding:80px 0}
.search-empty-title{font-family:var(--font-s);font-size:18px;font-weight:500;color:var(--text);margin-bottom:12px}
.search-empty-desc{font-family:var(--font-n);font-size:14px;color:var(--text-lt)}

@media(max-width:768px){
  .search-bar-inner{flex-direction:column;border-radius:12px}
  .search-bar-field{width:100%;border-bottom:1px solid var(--border);padding:0 16px}
  .search-bar-field:last-of-type{border-bottom:none}
  .search-bar-divider{display:none}
  .search-bar-btn{width:100%;height:52px;border-radius:0 0 10px 10px}
  .search-result-grid{grid-template-columns:1fr}
}

/* ===== ショップ ===== */
.shop-hero{margin-top:64px;padding:72px 0 56px;border-bottom:1px solid var(--border);background:var(--hero-dark)}
.shop-hero-en{font-family:var(--font-n);font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px}
.shop-hero-title{font-family:impact;font-size:clamp(40px,6vw,72px);font-weight:700;color:var(--white);line-height:1;margin-bottom:20px}
.shop-hero-desc{font-family:var(--font-n);font-size:14px;color:rgba(255,255,255,.55);max-width:480px;line-height:1.8}

.shop-cats-wrap{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:64px;z-index:50}
.shop-cats{display:flex;gap:0;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}
.shop-cats::-webkit-scrollbar{display:none}
.shop-cat-btn{flex-shrink:0;font-family:var(--font-n);font-size:13px;font-weight:500;color:var(--text-lt);padding:16px 24px;border-bottom:2px solid transparent;text-decoration:none;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:6px;white-space:nowrap}
.shop-cat-btn:hover{color:var(--text)}
.shop-cat-btn.active{color:var(--text);border-bottom-color:var(--text)}
.shop-cat-count{background:var(--tag-bg);color:var(--text-lt);font-size:10px;padding:2px 7px;border-radius:100px}

.shop-products{padding:48px 0 80px}
.shop-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}
.shop-toolbar-count{font-family:var(--font-n);font-size:13px;color:var(--text-lt)}
.shop-toolbar-count strong{color:var(--text);font-weight:600}
.shop-sort-select{font-family:var(--font-n);font-size:13px;color:var(--text);border:1px solid var(--border);background:var(--white);padding:8px 14px;border-radius:6px;outline:none;cursor:pointer}

.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.shop-card{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s}
.shop-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.09);transform:translateY(-2px)}
.shop-card-link{text-decoration:none;color:inherit;flex:1;display:flex;flex-direction:column}
.shop-card-img{aspect-ratio:1/1;overflow:hidden;background:var(--tag-bg);position:relative}
.shop-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.shop-card:hover .shop-card-img img{transform:scale(1.04)}
.shop-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--tag-bg)}
.shop-card-badge{position:absolute;top:12px;left:12px;background:#e05c3a;color:#fff;font-family:var(--font-n);font-size:10px;font-weight:700;letter-spacing:.1em;padding:4px 10px;border-radius:100px}
.shop-card-body{padding:16px 20px 12px;flex:1;display:flex;flex-direction:column;gap:6px}
.shop-card-cat{font-family:var(--font-n);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-lt)}
.shop-card-title{font-family:var(--font-s);font-size:15px;font-weight:500;color:var(--text);line-height:1.5}
.shop-card-price{font-family:var(--font-n);font-size:14px;font-weight:600;color:var(--text);margin-top:4px}
.shop-card-price .woocommerce-Price-amount{color:var(--text)}
.shop-card-price del .woocommerce-Price-amount{color:var(--text-lt);font-weight:400;font-size:12px}
.shop-card-price ins{text-decoration:none;color:#e05c3a}
.shop-card-btn{width:100%;background:var(--text);color:var(--white);border:none;font-family:var(--font-n);font-size:13px;font-weight:600;padding:14px;cursor:pointer;transition:opacity .2s,background .2s;letter-spacing:.04em}
.shop-card-btn:hover{opacity:.85}
.shop-card-btn.added{background:var(--accent)}
.shop-card-btn:disabled{opacity:.6;cursor:not-allowed}
.shop-card-soldout{display:block;text-align:center;font-family:var(--font-n);font-size:12px;color:var(--text-lt);padding:14px;background:var(--tag-bg)}

@media(max-width:768px){
  .shop-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .shop-hero{padding:48px 0 40px}
}
@media(max-width:480px){
  .shop-grid{grid-template-columns:1fr}
}
