/* news.css
   Extracted from news.html embedded <style> (Phase B-2-c, 2026-05-15).
*/

body{font-family:"Noto Sans JP",sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden}

/* ── HEADER ── */
header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:64px;background:rgba(15,39,66,.97);border-bottom:1px solid rgba(255,255,255,.07)}
.header-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.header-logo img{height:40px;width:auto;display:block}
.logo-name{font-family:"Noto Serif JP",serif;color:rgba(255,255,255,.65);font-size:12px;letter-spacing:.1em;font-weight:300;line-height:1.5}
nav{display:flex;align-items:center;gap:20px}
nav a{color:rgba(255,255,255,.72);text-decoration:none;font-size:12px;letter-spacing:.06em;transition:color .2s;white-space:nowrap}
nav a:hover,nav a.active{color:var(--accent-light)}
.nav-cta{background:var(--accent)!important;color:#fff!important;padding:7px 16px;border-radius:2px;font-weight:500!important}

/* ── PAGE HERO ── */
.page-hero{height:320px;position:relative;display:flex;align-items:flex-end;padding-bottom:52px;margin-top:64px;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,rgba(15,39,66,.55) 0%,rgba(15,39,66,.30) 100%),url("../photos/office/hq-building.jpg") center 45%/cover no-repeat}
.page-hero-content{position:relative;z-index:1;padding:0 80px}
.page-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.page-breadcrumb a{font-size:12px;color:rgba(255,255,255,.45);text-decoration:none;letter-spacing:.06em;transition:color .2s}
.page-breadcrumb a:hover{color:rgba(255,255,255,.75)}
.page-breadcrumb span{font-size:12px;color:rgba(255,255,255,.3);}
.page-breadcrumb .current{color:rgba(255,255,255,.6)}
.page-en{font-size:12px;letter-spacing:.25em;color:var(--accent);text-transform:uppercase;font-weight:500;margin-bottom:10px;display:block}
.page-title{font-family:"Noto Serif JP",serif;font-size:clamp(26px,3.5vw,40px);color:#fff;letter-spacing:.06em;font-weight:400}

/* ── MAIN ── */
main{max-width:1200px;margin:0 auto;padding:72px 80px 120px}

/* ── FILTER ── */
.filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:48px;padding-bottom:24px;border-bottom:1px solid rgba(13,31,53,.1)}
.filter-label{font-size:12px;letter-spacing:.12em;color:var(--text-mid);margin-right:6px}
.filter-btn{background:none;border:1px solid rgba(13,31,53,.15);color:var(--text-mid);padding:6px 16px;font-size:12px;letter-spacing:.06em;cursor:pointer;transition:all .2s;font-family:"Noto Sans JP",sans-serif}
.filter-btn:hover{border-color:var(--accent);color:var(--accent)}
.filter-btn.active{background:var(--navy);border-color:var(--navy);color:#fff}

/* ── NEWS GRID ── */
.news-grid{display:grid;grid-template-columns:1fr;gap:12px}
.news-card{display:flex;gap:0;border:1px solid rgba(13,31,53,.08);border-radius:4px;text-decoration:none;color:inherit;transition:background .2s,box-shadow .2s;background:#fff;overflow:hidden;box-shadow:0 1px 4px rgba(13,31,53,.05)}

.news-card:hover{background:#f7f8fa;box-shadow:0 4px 16px rgba(13,31,53,.1)}
.nc-thumb{width:200px;min-width:200px;height:140px;overflow:hidden;flex-shrink:0}
.nc-thumb img{width:200px;height:140px;object-fit:cover;display:block;transition:transform .4s}
.nc-thumb-placeholder{width:200px;min-width:200px;height:140px;flex-shrink:0;background:var(--navy);display:flex;align-items:center;justify-content:center}
.nc-thumb-placeholder img{width:52px;height:auto;opacity:.45;display:block}
.news-card:hover .nc-thumb img{transform:scale(1.04)}
.nc-body{flex:1;padding:22px 28px;display:flex;flex-direction:column;justify-content:space-between;min-width:0}
.nc-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.nc-tag{font-size:11px;letter-spacing:.1em;padding:3px 10px;border:1px solid;white-space:nowrap;display:inline-block}
.nc-tag.press{border-color:var(--accent);color:var(--accent)}
.nc-tag.info{border-color:var(--gray-mid);color:var(--text-mid)}
.nc-date{font-size:12px;color:var(--text-mid);letter-spacing:.05em}
.nc-cat{font-size:11px;color:rgba(13,31,53,.4);letter-spacing:.06em;border-left:1px solid rgba(13,31,53,.15);padding-left:12px}
.nc-title{font-size:15px;color:var(--navy);font-weight:500;letter-spacing:.04em;line-height:1.65}
.nc-footer{display:flex;justify-content:flex-end;margin-top:10px}
.nc-arr{font-size:12px;color:var(--accent);letter-spacing:.08em;white-space:nowrap}
.news-card.hidden{display:none}

/* ── PAGINATION ── */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:52px}
.pg-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(13,31,53,.15);color:var(--text-mid);text-decoration:none;font-size:14px;transition:all .2s;cursor:pointer;background:none;font-family:"Noto Sans JP",sans-serif}
.pg-btn:hover,.pg-btn.active{background:var(--navy);border-color:var(--navy);color:#fff}
.pg-btn.prev,.pg-btn.next{width:auto;padding:0 16px;font-size:12px;letter-spacing:.08em}

/* ── FOOTER ── */
footer{background:var(--navy);padding:48px 80px 26px;border-top:1px solid rgba(255,255,255,.07)}
.ft-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07)}
/* フッターロゴ: 白背景PNG */
.ft-logo-wrap{display:inline-block;margin-bottom:14px}
.ft-logo-wrap .logo-symbol{height:48px;width:auto;display:block}
.ft-co{font-size:13px;color:rgba(255,255,255,.5);letter-spacing:.07em;font-family:"Noto Serif JP",serif;margin-bottom:10px}
.ft-addr{font-size:12px;color:rgba(255,255,255,.55);line-height:2.0;letter-spacing:.04em;font-weight:300}
.ft-hours{font-size:12px;color:rgba(255,255,255,.55);line-height:1.9;letter-spacing:.04em;font-weight:300;margin-top:8px;border-top:1px solid rgba(255,255,255,.1);padding-top:8px}
.ft-sns{display:flex;gap:8px;margin-top:18px}
.sns-btn{width:32px;height:32px;border:1px solid rgba(255,255,255,.36);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:border-color .2s,background .2s}
.sns-btn:hover{border-color:var(--accent);background:rgba(255,255,255,.04)}
.sns-btn svg{width:14px;height:14px;fill:rgba(255,255,255,.6)}
.sns-btn svg.si{fill:none;stroke:rgba(255,255,255,.6);stroke-width:1.5}
.ft-nav{display:grid;grid-template-columns:repeat(4,auto);gap:8px 36px;align-content:start}
.ft-nav a{font-size:12px;color:rgba(255,255,255,.7);text-decoration:none;letter-spacing:.06em;transition:color .2s;white-space:normal}
.ft-nav a:hover{color:var(--accent-light)}
.ft-bottom{display:flex;justify-content:space-between;align-items:center}
.ft-policies{display:flex;gap:18px;flex-wrap:wrap}
.ft-policies a{font-size:11px;color:rgba(255,255,255,.55);text-decoration:none;letter-spacing:.04em;transition:color .2s}
.ft-policies a:hover{color:rgba(255,255,255,.85)}
.ft-copy{font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.06em}

.hamburger{display:none;flex-direction:column;justify-content:space-between;width:24px;height:18px;cursor:pointer;background:none;border:none;padding:0;flex-shrink:0}
.hamburger span{display:block;height:2px;background:rgba(255,255,255,.85);border-radius:1px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(max-width:360px){.logo-name{display:none}}
.drawer-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:98}
.drawer-overlay.open{display:block}
.drawer-menu{position:fixed;top:64px;right:0;width:260px;height:calc(100vh - 64px);background:#0d2540;z-index:99;overflow-y:auto;border-left:1px solid rgba(255,255,255,.1);box-shadow:-4px 0 24px rgba(0,0,0,.4);transform:translateX(100%);transition:transform .28s ease}
.drawer-menu.open{transform:translateX(0)}
.drawer-menu a{display:block;width:100%;padding:0 24px;height:48px;line-height:48px;color:rgba(255,255,255,.85);text-decoration:none;font-size:14px;letter-spacing:.06em;border-bottom:1px solid rgba(255,255,255,.07);box-sizing:border-box;transition:background .15s,color .15s}
.drawer-menu a:hover{background:rgba(255,255,255,.07);color:#fff}
.drawer-menu a.active{color:var(--accent-light);border-left:3px solid var(--accent);padding-left:21px}
.drawer-cta{display:block;padding:0 24px;height:48px;line-height:48px;background:var(--accent);color:#fff!important;text-decoration:none;font-size:14px;letter-spacing:.06em;border-bottom:1px solid rgba(255,255,255,.07);transition:background .15s,color .15s;margin-top:8px}
.drawer-cta:hover{background:var(--accent-light)!important;color:#fff!important}
@media(max-width:960px){
  header{padding:0 18px}
  nav{display:none}
  .hamburger{display:flex}
      .page-hero-content,main{padding-left:20px;padding-right:20px}
  .news-card{flex-direction:column}
  .nc-thumb,.nc-thumb-placeholder{width:100%!important;min-width:0!important;height:200px}
  .nc-thumb img{width:100%!important;height:200px;object-fit:cover}
  .nc-body{padding:16px 18px}
  .nc-arr{text-align:right}
  footer{padding:36px 20px 22px}
  .ft-top{flex-direction:column;gap:32px}
  .ft-nav{grid-template-columns:1fr 1fr}
  .ft-bottom{flex-direction:column;gap:12px}
}

header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:64px;background:rgba(15,39,66,.97);border-bottom:1px solid rgba(255,255,255,.07)}
.header-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.header-logo .logo-symbol{height:40px;width:auto;display:block}
.header-logo .logo-name{font-family:"Noto Serif JP",serif;color:rgba(255,255,255,.88);font-size:14px;letter-spacing:.12em;font-weight:300;white-space:nowrap}
nav{display:flex;align-items:center;gap:20px}
nav a{color:rgba(255,255,255,.72);text-decoration:none;font-size:12px;letter-spacing:.06em;transition:color .2s;white-space:normal}
nav a:hover{color:var(--accent-light)}
.nav-cta{background:var(--accent)!important;color:#fff!important;padding:7px 16px;border-radius:2px;font-weight:500!important}
.nav-cta:hover{background:var(--accent-light)!important}
