@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}
}

/* ============================================================
   CREATOR SINGLE — 2カラムレイアウト改修
   ============================================================ */

/* ── レイアウト ── */
.creator-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 64px;
  padding-top: 80px;
  padding-bottom: 100px;
  align-items: start;
}
.creator-main { min-width: 0; }

/* ── セクション共通 ── */
.creator-section {
  padding-bottom: 72px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 72px;
}
.creator-section:last-child { border-bottom: none; }
.creator-section .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 .creator-section-title {
  font-family: var(--font-d);
  font-size: 24px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 32px;
}

/* ── スキルタグ ── */
.creator-skills-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.creator-skill-tag {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-n);
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 100px;
  padding: 8px 16px;
  transition: border-color .2s, background .2s;
}
.creator-skill-tag:hover { border-color: var(--accent); background: var(--tag-bg); }
.creator-skill-icon { font-size: 15px; line-height: 1; }

/* ── 実績カード ── */
.creator-works-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.creator-work-card {
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  transition: box-shadow .2s, transform .2s;
  text-decoration: none;
  color: inherit;
}
.creator-work-card:hover {
  box-shadow: 0 6px 24px rgba(0,0,0,.09);
  transform: translateY(-2px);
}
.creator-work-img {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--tag-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.creator-work-img img { width: 100%; height: 100%; object-fit: cover; }
.creator-work-img-placeholder { font-size: 40px; }
.creator-work-body { padding: 16px 20px 20px; }
.creator-work-cat {
  font-family: var(--font-n);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 6px;
}
.creator-work-title {
  font-family: var(--font-s);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.6;
  color: var(--text);
  margin-bottom: 4px;
}
.creator-work-client {
  font-family: var(--font-n);
  font-size: 11px;
  color: var(--text-lt);
}

/* ── 執筆記事リスト ── */
.creator-articles-list { display: flex; flex-direction: column; gap: 16px; }
.creator-article-card {
  display: flex;
  gap: 16px;
  padding: 16px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  transition: background .2s;
  text-decoration: none;
  color: inherit;
}
.creator-article-card:hover { background: var(--tag-bg); }
.creator-article-img {
  width: 80px;
  height: 60px;
  flex-shrink: 0;
  border-radius: 4px;
  overflow: hidden;
  background: var(--tag-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.creator-article-img img { width: 100%; height: 100%; object-fit: cover; }
.creator-article-img-placeholder { font-size: 24px; }
.creator-article-body { flex: 1; min-width: 0; }
.creator-article-cat {
  display: inline-block;
  font-family: var(--font-n);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 100px;
  background: var(--tag-bg);
  color: var(--text-mid);
  margin-bottom: 6px;
}
.creator-article-cat--news            { background: #1a2018; color: #fff; }
.creator-article-cat--blog            { background: #4a5c3f; color: #fff; }
.creator-article-cat--interview       { background: #7a6040; color: #fff; }
.creator-article-cat--area-report     { background: #3d5a70; color: #fff; }
.creator-article-cat--creator-column  { background: #6b4c6e; color: #fff; }
.creator-article-title {
  font-family: var(--font-s);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  color: var(--text);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.creator-article-date {
  font-family: var(--font-n);
  font-size: 10px;
  color: var(--text-lt);
}

/* ── 活動地域タグ ── */
.creator-area-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.creator-area-tag {
  font-family: var(--font-n);
  font-size: 13px;
  color: var(--text-mid);
  background: var(--tag-bg);
  border: 1px solid var(--border);
  padding: 6px 16px;
  border-radius: 100px;
}

/* ── CTA ── */
.creator-cta-section {
  background: var(--hero-dark);
  border-radius: 12px;
  padding: 48px 40px;
  text-align: center;
  margin-bottom: 32px;
}
.creator-cta-lead {
  font-family: var(--font-s);
  font-size: 15px;
  color: rgba(255,255,255,.75);
  line-height: 2;
  margin-bottom: 32px;
}
.creator-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-n);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .06em;
  background: var(--white);
  color: var(--text);
  padding: 16px 32px;
  border-radius: 100px;
  margin: 6px;
  transition: background .2s, color .2s, transform .15s;
}
.creator-cta-btn:hover { background: var(--accent); color: var(--white); transform: translateY(-1px); }
.creator-cta-btn--outline {
  background: transparent;
  color: rgba(255,255,255,.8);
  border: 1.5px solid rgba(255,255,255,.35);
}
.creator-cta-btn--outline:hover { background: rgba(255,255,255,.1); color: var(--white); }

/* ── サイドバー共通 ── */
.creator-sidebar {
  position: sticky;
  top: 88px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.creator-sb-widget {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 24px;
}
.creator-sb-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;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}

/* サイドバー記事 */
.creator-sb-articles { display: flex; flex-direction: column; gap: 12px; }
.creator-sb-article {
  display: flex;
  gap: 10px;
  text-decoration: none;
  color: inherit;
  align-items: flex-start;
}
.creator-sb-article:hover .creator-sb-article-title { color: var(--accent); }
.creator-sb-article-img {
  width: 60px;
  height: 45px;
  flex-shrink: 0;
  border-radius: 4px;
  overflow: hidden;
  background: var(--tag-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.creator-sb-article-img img { width: 100%; height: 100%; object-fit: cover; }
.creator-sb-article-placeholder { font-size: 18px; }
.creator-sb-article-title {
  font-family: var(--font-s);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.5;
  color: var(--text);
  transition: color .2s;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.creator-sb-article-date {
  font-family: var(--font-n);
  font-size: 10px;
  color: var(--text-lt);
  margin-top: 4px;
}

/* サイドバータグ */
.creator-sb-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.creator-sb-tag {
  font-family: var(--font-n);
  font-size: 11px;
  color: var(--text-mid);
  background: var(--tag-bg);
  border: 1px solid var(--border);
  padding: 4px 12px;
  border-radius: 100px;
}

/* サイドバーSNS */
.creator-sb-sns { display: flex; flex-direction: column; gap: 8px; }
.creator-sb-sns-link {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-n);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-mid);
  text-decoration: none;
  padding: 8px 12px;
  border-radius: 6px;
  transition: background .2s, color .2s;
}
.creator-sb-sns-link:hover { background: var(--tag-bg); color: var(--text); }

/* サイドバーお問い合わせ */
.creator-sb-contact { background: var(--hero-dark); border-color: transparent; text-align: center; }
.creator-sb-contact-lead {
  font-family: var(--font-s);
  font-size: 13px;
  color: rgba(255,255,255,.7);
  line-height: 1.8;
  margin-bottom: 16px;
}
.creator-sb-contact-btn {
  display: block;
  font-family: var(--font-n);
  font-size: 13px;
  font-weight: 600;
  text-align: center;
  background: var(--white);
  color: var(--text);
  padding: 12px 20px;
  border-radius: 100px;
  margin-bottom: 8px;
  text-decoration: none;
  transition: background .2s, color .2s;
}
.creator-sb-contact-btn:hover { background: var(--accent); color: var(--white); }
.creator-sb-contact-btn--outline {
  background: transparent;
  color: rgba(255,255,255,.75);
  border: 1.5px solid rgba(255,255,255,.3);
}
.creator-sb-contact-btn--outline:hover { background: rgba(255,255,255,.1); color: var(--white); }

/* サイドバー関連クリエイター */
.creator-sb-related { display: flex; flex-direction: column; gap: 12px; }
.creator-sb-related-card {
  display: flex;
  gap: 10px;
  align-items: center;
  text-decoration: none;
  color: inherit;
}
.creator-sb-related-card:hover .creator-sb-related-name { color: var(--accent); }
.creator-sb-related-img {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--tag-bg);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}
.creator-sb-related-img img { width: 100%; height: 100%; object-fit: cover; }
.creator-sb-related-placeholder { font-size: 20px; }
.creator-sb-related-name {
  font-family: var(--font-n);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  transition: color .2s;
}
.creator-sb-related-area {
  font-family: var(--font-n);
  font-size: 10px;
  color: var(--text-lt);
  margin-top: 2px;
}

/* ============================================================
   PRESS ARCHIVE（ブログ一覧）
   ============================================================ */
.press-cat-nav {
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  position: sticky;
  top: 64px;
  z-index: 50;
}
.press-cat-nav-inner {
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.press-cat-nav-inner::-webkit-scrollbar { display: none; }
.press-cat-btn {
  flex-shrink: 0;
  font-family: var(--font-n);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-lt);
  padding: 16px 24px;
  border-bottom: 2px solid transparent;
  text-decoration: none;
  transition: color .15s, border-color .15s;
  white-space: nowrap;
}
.press-cat-btn:hover, .press-cat-btn.active { color: var(--text); }
.press-cat-btn.active { border-bottom-color: var(--text); }

.press-grid-section { padding: 64px 0 100px; }
.press-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}

/* ── PRESS カード（共通） ── */
.press-card {
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: box-shadow .2s, transform .2s;
}
.press-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,.09); transform: translateY(-2px); }
.press-card-img {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--tag-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.press-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--ease); }
.press-card:hover .press-card-img img { transform: scale(1.04); }
.press-card-img-placeholder { font-size: 48px; }
.press-card-cat {
  position: absolute;
  top: 12px;
  left: 12px;
  font-family: var(--font-n);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 100px;
  background: var(--tag-bg);
  color: var(--text);
}
.press-card-cat--news            { background: #1a2018; color: #fff; }
.press-card-cat--blog            { background: #4a5c3f; color: #fff; }
.press-card-cat--interview       { background: #7a6040; color: #fff; }
.press-card-cat--area-report     { background: #3d5a70; color: #fff; }
.press-card-cat--creator-column  { background: #6b4c6e; color: #fff; }
.press-card-body { padding: 20px 24px 24px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.press-card-date { font-family: var(--font-n); font-size: 10px; color: var(--text-lt); }
.press-card-title { font-family: var(--font-s); font-size: 16px; font-weight: 500; line-height: 1.6; color: var(--text); flex: 1; }
.press-card-excerpt { font-family: var(--font-n); font-size: 12px; color: var(--text-mid); line-height: 1.7; }
.press-card-creator {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  border-top: 1px solid var(--border);
  padding-top: 12px;
}
.press-card-creator-img { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; }
.press-card-creator-name { font-family: var(--font-n); font-size: 11px; color: var(--text-lt); }

/* ページネーション */
.press-pagination, .press-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
.press-empty { flex-direction: column; padding: 80px 0; }
.press-empty-icon { font-size: 48px; }
.press-empty-text { font-family: var(--font-s); font-size: 15px; color: var(--text-lt); }
.press-pager-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;
}
.press-pager-btn:hover { background: var(--tag-bg); }
.press-pager-info { font-family: var(--font-n); font-size: 13px; color: var(--text-lt); }

/* ============================================================
   PRESS SINGLE（ブログ詳細）
   ============================================================ */
.press-eyecatch { width: 100%; max-height: 520px; overflow: hidden; background: var(--tag-bg); }
.press-eyecatch-img { width: 100%; height: 100%; object-fit: cover; display: block; max-height: 520px; }

.press-single-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 56px;
  padding-top: 56px;
  padding-bottom: 80px;
  align-items: start;
}

.press-single-header { margin-bottom: 32px; }
.press-single-cat {
  display: inline-block;
  font-family: var(--font-n);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 100px;
  margin-bottom: 16px;
  background: var(--tag-bg);
  color: var(--text);
}
.press-single-cat--news            { background: #1a2018; color: #fff; }
.press-single-cat--blog            { background: #4a5c3f; color: #fff; }
.press-single-cat--interview       { background: #7a6040; color: #fff; }
.press-single-cat--area-report     { background: #3d5a70; color: #fff; }
.press-single-cat--creator-column  { background: #6b4c6e; color: #fff; }

.press-single-title {
  font-family: var(--font-s);
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 700;
  line-height: 1.5;
  color: var(--text);
  margin-bottom: 16px;
}
.press-single-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.press-single-date, .press-single-area {
  font-family: var(--font-n);
  font-size: 12px;
  color: var(--text-lt);
  display: flex;
  align-items: center;
  gap: 4px;
}

/* 執筆者バイライン */
.press-single-byline {
  margin: 24px 0 32px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 16px 0;
}
.press-byline-link {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  color: inherit;
}
.press-byline-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--tag-bg);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
}
.press-byline-img { width: 100%; height: 100%; object-fit: cover; }
.press-byline-label { font-family: var(--font-n); font-size: 10px; color: var(--text-lt); margin-bottom: 2px; }
.press-byline-name { font-family: var(--font-n); font-size: 14px; font-weight: 600; color: var(--text); }
.press-byline-area { font-family: var(--font-n); font-size: 11px; color: var(--text-lt); margin-top: 2px; }

/* 本文 */
.press-single-content {
  font-family: var(--font-s);
  font-size: 16px;
  line-height: 2;
  color: var(--text-mid);
  margin-bottom: 48px;
}
.press-single-content p { margin-bottom: 1.6em; }
.press-single-content h2 { font-family: var(--font-s); font-size: 22px; font-weight: 700; color: var(--text); margin: 2em 0 .8em; padding-bottom: 8px; border-bottom: 2px solid var(--border); }
.press-single-content h3 { font-family: var(--font-s); font-size: 18px; font-weight: 700; color: var(--text); margin: 1.6em 0 .6em; }
.press-single-content img { max-width: 100%; border-radius: 6px; margin: 1.6em 0; }
.press-single-content ul, .press-single-content ol { padding-left: 1.4em; margin-bottom: 1.4em; }
.press-single-content li { margin-bottom: .5em; }
.press-single-content blockquote { border-left: 3px solid var(--accent); padding: 16px 20px; background: var(--tag-bg); border-radius: 0 8px 8px 0; margin: 1.6em 0; color: var(--text-mid); font-style: italic; }

.press-single-footer { padding-top: 24px; border-top: 1px solid var(--border); }
.press-back-link {
  font-family: var(--font-n);
  font-size: 13px;
  color: var(--text-mid);
  text-decoration: none;
  transition: color .2s;
}
.press-back-link:hover { color: var(--text); }

/* 詳細サイドバー */
.press-single-sidebar {
  position: sticky;
  top: 88px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.press-sb-widget {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px;
}
.press-sb-title {
  font-family: var(--font-n);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--text-lt);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.press-sb-creator { padding: 0; overflow: hidden; }
.press-sb-creator-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  text-decoration: none;
  color: inherit;
  padding: 24px 20px;
  transition: background .2s;
}
.press-sb-creator-inner:hover { background: var(--tag-bg); }
.press-sb-creator-img {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--tag-bg);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
}
.press-sb-creator-photo { width: 100%; height: 100%; object-fit: cover; }
.press-sb-creator-placeholder { font-size: 36px; }
.press-sb-creator-name { font-family: var(--font-n); font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.press-sb-creator-type { font-family: var(--font-n); font-size: 10px; color: var(--text-lt); margin-bottom: 8px; }
.press-sb-creator-catch { font-family: var(--font-s); font-size: 12px; color: var(--text-mid); line-height: 1.6; margin-bottom: 12px; }
.press-sb-creator-btn { font-family: var(--font-n); font-size: 12px; font-weight: 600; color: var(--accent); }

.press-sb-article-list { display: flex; flex-direction: column; gap: 10px; }
.press-sb-article-item {
  display: flex;
  gap: 10px;
  text-decoration: none;
  color: inherit;
  align-items: flex-start;
}
.press-sb-article-item:hover .press-sb-article-title { color: var(--accent); }
.press-sb-article-img {
  width: 56px;
  height: 42px;
  border-radius: 4px;
  overflow: hidden;
  background: var(--tag-bg);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
}
.press-sb-article-img img { width: 100%; height: 100%; object-fit: cover; }
.press-sb-article-title {
  font-family: var(--font-s);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.5;
  color: var(--text);
  transition: color .2s;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.press-sb-article-date { font-family: var(--font-n); font-size: 10px; color: var(--text-lt); margin-top: 3px; }

/* 関連記事 */
.press-related { border-top: 1px solid var(--border); padding: 72px 0 100px; }
.press-related-header { margin-bottom: 40px; }
.press-related-label {
  font-family: var(--font-n);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text-lt);
  display: block;
  margin-bottom: 10px;
}
.press-related-title { font-family: var(--font-d); font-size: 24px; font-weight: 700; color: var(--text); }
.press-related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }

/* ============================================================
   トップページ PRESS 最新記事セクション
   ============================================================ */
.section-press { padding: 80px 0 100px; border-top: 1px solid var(--border); }
.press-top-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.press-top-card {
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: box-shadow .2s, transform .2s;
}
.press-top-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,.09); transform: translateY(-2px); }
.press-top-img {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--tag-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.press-top-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--ease); }
.press-top-card:hover .press-top-img img { transform: scale(1.04); }
.press-top-img-placeholder { font-size: 40px; }
.press-top-body { padding: 16px 20px 20px; flex: 1; }
.press-top-date { font-family: var(--font-n); font-size: 10px; color: var(--text-lt); margin-bottom: 6px; }
.press-top-title { font-family: var(--font-s); font-size: 15px; font-weight: 500; line-height: 1.6; color: var(--text); margin-bottom: 8px; }
.press-top-creator { font-family: var(--font-n); font-size: 11px; color: var(--text-lt); }

/* ============================================================
   レスポンシブ
   ============================================================ */
@media(max-width:1024px) {
  .creator-layout { grid-template-columns: 1fr 260px; gap: 40px; }
  .press-single-layout { grid-template-columns: 1fr 240px; gap: 40px; }
}

@media(max-width:768px) {
  /* クリエイターページ 1カラム */
  .creator-layout {
    grid-template-columns: 1fr;
    gap: 0;
    padding-top: 40px;
    padding-bottom: 60px;
  }
  .creator-sidebar {
    position: static;
    margin-top: 64px;
  }
  .creator-works-grid { grid-template-columns: 1fr; }
  .creator-cta-section { padding: 32px 24px; }

  /* PRESSアーカイブ */
  .press-grid { grid-template-columns: 1fr; gap: 16px; }
  .press-top-grid { grid-template-columns: 1fr; gap: 16px; }

  /* PRESS詳細 */
  .press-single-layout {
    grid-template-columns: 1fr;
    padding-top: 32px;
    padding-bottom: 60px;
  }
  .press-single-sidebar {
    position: static;
    margin-top: 48px;
  }
  .press-related-grid { grid-template-columns: 1fr; gap: 16px; }
}

@media(max-width:600px) {
  .press-grid { grid-template-columns: 1fr; }
  .press-related-grid { grid-template-columns: 1fr; }
  .press-top-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   ACHIEVEMENT SINGLE（制作実績 詳細ページ）
   ============================================================ */
.achievement-eyecatch { width:100%; max-height:520px; overflow:hidden; background:var(--tag-bg); }
.achievement-eyecatch-img { width:100%; height:100%; object-fit:cover; display:block; max-height:520px; }

.achievement-layout {
  display:grid;
  grid-template-columns:1fr 280px;
  gap:56px;
  padding-top:56px;
  padding-bottom:100px;
  align-items:start;
}

/* ── ヘッダー ── */
.achievement-header { margin-bottom:32px; }
.achievement-cat {
  display:inline-block;
  font-family:var(--font-n);
  font-size:10px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  background:var(--tag-bg);
  color:var(--text-mid);
  padding:4px 12px;
  border-radius:100px;
  margin-bottom:16px;
}
.achievement-title {
  font-family:var(--font-s);
  font-size:clamp(22px,3vw,34px);
  font-weight:700;
  line-height:1.5;
  color:var(--text);
  margin-bottom:16px;
}
.achievement-client {
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-n);
  font-size:13px;
  color:var(--text-mid);
}
.achievement-client-label {
  font-size:9px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--text-lt);
  background:var(--tag-bg);
  padding:3px 8px;
  border-radius:4px;
}

/* ── 本文 ── */
.achievement-content {
  font-family:var(--font-s);
  font-size:16px;
  line-height:2;
  color:var(--text-mid);
  margin-bottom:40px;
  border-top:1px solid var(--border);
  padding-top:32px;
}
.achievement-content p  { margin-bottom:1.6em; }
.achievement-content h2 { font-family:var(--font-s);font-size:20px;font-weight:700;color:var(--text);margin:2em 0 .8em;padding-bottom:8px;border-bottom:2px solid var(--border); }
.achievement-content h3 { font-family:var(--font-s);font-size:17px;font-weight:700;color:var(--text);margin:1.6em 0 .6em; }
.achievement-content img { max-width:100%;border-radius:6px;margin:1.6em 0; }
.achievement-content ul,
.achievement-content ol { padding-left:1.4em;margin-bottom:1.4em; }
.achievement-content li { margin-bottom:.5em; }
.achievement-content blockquote { border-left:3px solid var(--accent);padding:16px 20px;background:var(--tag-bg);border-radius:0 8px 8px 0;margin:1.6em 0;font-style:italic; }

/* ── 参照URLボタン ── */
.achievement-ref { margin-bottom:40px; }
.achievement-ref-btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-n);
  font-size:13px;
  font-weight:600;
  color:var(--white);
  background:var(--accent);
  padding:14px 28px;
  border-radius:100px;
  text-decoration:none;
  transition:opacity .2s, transform .15s;
}
.achievement-ref-btn:hover { opacity:.85; transform:translateY(-1px); }

/* ── 戻るリンク ── */
.achievement-back { padding-top:24px; border-top:1px solid var(--border); }
.achievement-back-link {
  font-family:var(--font-n);
  font-size:13px;
  color:var(--text-mid);
  text-decoration:none;
  transition:color .2s;
}
.achievement-back-link:hover { color:var(--text); }

/* ── サイドバー共通 ── */
.achievement-sidebar {
  position:sticky;
  top:88px;
  display:flex;
  flex-direction:column;
  gap:20px;
}
.achievement-sb-widget {
  background:var(--white);
  border:1px solid var(--border);
  border-radius:10px;
  padding:20px;
}
.achievement-sb-title {
  font-family:var(--font-n);
  font-size:10px;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--text-lt);
  margin-bottom:14px;
  padding-bottom:10px;
  border-bottom:1px solid var(--border);
}

/* ── 担当クリエイター ── */
.achievement-sb-creator {
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:inherit;
  margin-bottom:14px;
}
.achievement-sb-creator-img {
  width:56px;
  height:56px;
  border-radius:50%;
  overflow:hidden;
  background:var(--tag-bg);
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
}
.achievement-sb-creator-photo { width:100%;height:100%;object-fit:cover; }
.achievement-sb-creator-placeholder { font-size:24px; }
.achievement-sb-creator-name { font-family:var(--font-n);font-size:14px;font-weight:700;color:var(--text);margin-bottom:2px; }
.achievement-sb-creator-type { font-family:var(--font-n);font-size:10px;color:var(--text-lt); }
.achievement-sb-profile-btn {
  display:block;
  text-align:center;
  font-family:var(--font-n);
  font-size:12px;
  font-weight:600;
  color:var(--text);
  background:var(--tag-bg);
  border:1px solid var(--border);
  padding:10px;
  border-radius:6px;
  text-decoration:none;
  transition:background .2s;
}
.achievement-sb-profile-btn:hover { background:var(--border); }

/* ── 実績情報 dl ── */
.achievement-sb-info { margin-bottom:14px; }
.achievement-sb-info dt {
  font-family:var(--font-n);
  font-size:9px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text-lt);
  margin-top:10px;
}
.achievement-sb-info dd {
  font-family:var(--font-n);
  font-size:13px;
  color:var(--text);
  margin-top:2px;
}
.achievement-sb-url-btn {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  font-family:var(--font-n);
  font-size:12px;
  font-weight:600;
  color:var(--white);
  background:var(--accent);
  padding:10px;
  border-radius:6px;
  text-decoration:none;
  transition:opacity .2s;
}
.achievement-sb-url-btn:hover { opacity:.85; }

/* ── 他の実績 ── */
.achievement-sb-works { display:flex;flex-direction:column;gap:10px; }
.achievement-sb-work-item {
  display:flex;
  gap:10px;
  text-decoration:none;
  color:inherit;
  align-items:center;
}
.achievement-sb-work-item:hover .achievement-sb-work-title { color:var(--accent); }
.achievement-sb-work-img {
  width:56px;
  height:42px;
  border-radius:4px;
  overflow:hidden;
  background:var(--tag-bg);
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
}
.achievement-sb-work-img img { width:100%;height:100%;object-fit:cover; }
.achievement-sb-work-cat { font-family:var(--font-n);font-size:9px;color:var(--text-lt);margin-bottom:2px; }
.achievement-sb-work-title { font-family:var(--font-s);font-size:12px;font-weight:500;color:var(--text);transition:color .2s;line-height:1.4; }

/* ── レスポンシブ ── */
@media(max-width:768px) {
  .achievement-layout { grid-template-columns:1fr; padding-top:32px; padding-bottom:60px; }
  .achievement-sidebar { position:static; margin-top:48px; }
}
