*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Zen Kaku Gothic New','Hiragino Kaku Gothic ProN',sans-serif;color:#111;background:#fff;line-height:1.7;font-weight:400}
.serif{font-family:'Shippori Mincho B1','Hiragino Mincho ProN',serif}
a{color:inherit;text-decoration:none;transition:opacity .2s}
a:hover{opacity:.6}
img{max-width:100%;display:block}

.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 32px}

/* Header */
#hdr{position:sticky;top:0;background:rgba(0,0,0,.92);backdrop-filter:blur(10px);color:#fff;z-index:100;border-bottom:1px solid #222}
#hdr .nav{display:flex;justify-content:space-between;align-items:center;padding:20px 32px}
#hdr .logo{font-family:'Shippori Mincho B1',serif;font-size:20px;font-weight:700;letter-spacing:.05em}
#hdr .logo span{color:#c9a961}
#hdr .nav-links{display:flex;gap:32px;align-items:center;font-size:13px;letter-spacing:.1em;text-transform:uppercase}

/* Language switcher */
.lang-switch{position:relative;font-size:11px;letter-spacing:.15em}
.lang-switch>button{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 12px;cursor:pointer;font:inherit;letter-spacing:inherit;text-transform:uppercase}
.lang-switch>button:hover{border-color:#c9a961;color:#c9a961}
.lang-switch>button::after{content:'▾';margin-left:6px}
.lang-menu{display:none;position:absolute;top:100%;right:0;margin-top:6px;background:#111;border:1px solid #333;min-width:140px;z-index:200}
.lang-switch:hover .lang-menu,.lang-switch:focus-within .lang-menu{display:block}
.lang-menu a{display:block;padding:10px 16px;color:#fff;font-size:12px;letter-spacing:.1em;border-bottom:1px solid #222}
.lang-menu a:last-child{border-bottom:0}
.lang-menu a:hover{background:#c9a961;color:#000;opacity:1}
footer .lang-switch{display:none}

/* Hero (with background image) */
.hero{
  background:linear-gradient(rgba(0,0,0,.72),rgba(0,0,0,.88)),url('/images/top50/ranked/01.jpg') center/cover no-repeat;
  background-color:#000;color:#fff;padding:160px 32px 180px;text-align:center;position:relative;overflow:hidden;transition:background-image 1.2s ease-in-out
}
.hero>*{position:relative;z-index:3}
.hero::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(201,169,97,.15) 0%,transparent 70%);pointer-events:none}
.hero-eyebrow{font-size:12px;letter-spacing:.4em;color:#c9a961;margin-bottom:24px;position:relative}
.hero h1{font-family:'Shippori Mincho B1',serif;font-size:clamp(40px,6vw,80px);font-weight:700;line-height:1.2;margin-bottom:32px;letter-spacing:.02em;position:relative}
.hero h1 .gold{color:#c9a961}
.hero p{font-size:16px;max-width:680px;margin:0 auto 40px;opacity:.9;position:relative}
.hero-year{font-family:'Shippori Mincho B1',serif;font-size:13px;letter-spacing:.4em;color:#c9a961;position:relative}

/* Detail Hero with image */
.detail-hero{
  background:linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.88)),url('https://images.unsplash.com/photo-1618400109127-b9c068eabe1b?w=2000&q=80') center/cover no-repeat;
  color:#fff;padding:120px 0;text-align:center
}
.detail-hero .rank-badge{display:inline-block;font-family:'Shippori Mincho B1',serif;font-size:14px;letter-spacing:.3em;color:#c9a961;border:1px solid #c9a961;padding:8px 20px;margin-bottom:24px}
.detail-hero h1{font-family:'Shippori Mincho B1',serif;font-size:clamp(32px,5vw,56px);margin-bottom:16px}
.detail-hero .meta{font-size:13px;letter-spacing:.2em;opacity:.85}

/* Hero variants per page */
.hero-ranking{background-image:linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.88)),url('https://images.unsplash.com/photo-1574095443374-6748e7dd6c84?w=2000&q=80')}
.hero-criteria{background-image:linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.88)),url('https://images.unsplash.com/photo-1566904326734-e17fb7905d35?w=2000&q=80')}
.hero-committee{background-image:linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.88)),url('https://images.unsplash.com/photo-1692899667309-f99fc00ed0df?w=2000&q=80')}
.hero-about{background-image:linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.88)),url('https://images.unsplash.com/photo-1708388464912-d4ad82dca990?w=2000&q=80')}

/* Section */
.section{padding:100px 0}
.section-dark{background:#000;color:#fff}
.section-head{text-align:center;margin-bottom:60px}
.section-head .eyebrow{font-size:11px;letter-spacing:.4em;color:#c9a961;margin-bottom:16px}
.section-head h2{font-family:'Shippori Mincho B1',serif;font-size:clamp(28px,4vw,44px);font-weight:700;letter-spacing:.02em}
.section-head p{margin-top:24px;font-size:15px;opacity:.7;max-width:680px;margin-left:auto;margin-right:auto}

/* Top 10 List with image */
.top10{max-width:980px;margin:0 auto}
.top10-item{display:grid;grid-template-columns:80px 120px 1fr auto;gap:32px;align-items:center;padding:24px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.section:not(.section-dark) .top10-item{border-bottom-color:rgba(0,0,0,.1)}
.top10-item:first-child{border-top:1px solid rgba(255,255,255,.1)}
.section:not(.section-dark) .top10-item:first-child{border-top-color:rgba(0,0,0,.1)}
.top10-rank{font-family:'Shippori Mincho B1',serif;font-size:48px;font-weight:700;color:#c9a961;line-height:1}
.top10-thumb{width:120px;height:80px;background-size:cover;background-position:center;background-color:#222}
.top10-info h3{font-family:'Shippori Mincho B1',serif;font-size:22px;margin-bottom:6px}
.top10-info p{font-size:13px;opacity:.7;letter-spacing:.05em}
.top10-link{font-size:11px;letter-spacing:.3em;color:#c9a961}

.cta-row{text-align:center;margin-top:60px}
.btn{display:inline-block;padding:18px 44px;font-size:12px;letter-spacing:.3em;text-transform:uppercase;border:1px solid #c9a961;color:#c9a961;background:transparent;transition:all .3s}
.btn:hover{background:#c9a961;color:#000;opacity:1}
.btn-solid{background:#c9a961;color:#000}
.btn-solid:hover{background:#b89651;border-color:#b89651}

/* Criteria Grid */
.criteria-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:48px 80px;margin:60px auto 0;max-width:880px}
.criteria-card{text-align:center}
.criteria-card .num{font-family:'Shippori Mincho B1',serif;font-size:48px;color:#c9a961;line-height:1;margin-bottom:24px}
.criteria-card h3{font-family:'Shippori Mincho B1',serif;font-size:20px;margin-bottom:12px}
.criteria-card p{font-size:14px;opacity:.7;line-height:1.8}

/* Committee */
.committee-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:48px;margin-top:60px}
.committee-card{text-align:center}
.committee-card .avatar{width:140px;height:140px;border-radius:50%;background:#222;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;font-family:'Shippori Mincho B1',serif;font-size:48px;color:#c9a961;background-size:cover;background-position:center}
.committee-card h3{font-family:'Shippori Mincho B1',serif;font-size:20px;margin-bottom:6px}
.committee-card .title{font-size:12px;letter-spacing:.2em;color:#c9a961;margin-bottom:12px}
.committee-card p{font-size:13px;opacity:.7;line-height:1.7}

/* Full Ranking List with thumb */
.rank-list{max-width:980px;margin:0 auto}
.rank-row{display:grid;grid-template-columns:60px 80px 1fr auto;gap:24px;align-items:center;padding:16px 0;border-bottom:1px solid rgba(0,0,0,.08);font-size:14px}
.rank-row:hover{background:rgba(201,169,97,.05)}
.rank-num{font-family:'Shippori Mincho B1',serif;font-size:18px;color:#c9a961;font-weight:700}
.rank-thumb{width:80px;height:60px;background-size:cover;background-position:center;background-color:#eee}
.rank-name{font-family:'Shippori Mincho B1',serif;font-size:16px}
.rank-location{font-size:12px;opacity:.6;letter-spacing:.05em}

/* Detail / Article body */
.detail-body{padding:80px 0}
.detail-body h2{font-family:'Shippori Mincho B1',serif;font-size:24px;margin:48px 0 16px}
.detail-body p{font-size:15px;line-height:1.9;margin-bottom:16px}
.detail-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;padding:40px;background:#fafafa;margin:48px 0;border-left:3px solid #c9a961}
.detail-info dt{font-size:11px;letter-spacing:.2em;color:#c9a961;margin-bottom:6px;text-transform:uppercase}
.detail-info dd{font-size:14px}

/* About Page */
.about-section{padding:80px 0}
.about-section h2{font-family:'Shippori Mincho B1',serif;font-size:32px;margin-bottom:24px;text-align:center}
.about-section p{font-size:15px;line-height:1.9;margin-bottom:20px;max-width:720px;margin-left:auto;margin-right:auto}

/* Columns */
.columns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:32px;max-width:1200px;margin:0 auto}
.column-card{background:#fff;color:#111;overflow:hidden;transition:transform .3s}
.column-card:hover{transform:translateY(-4px)}
.column-card .thumb{width:100%;aspect-ratio:16/10;background-size:cover;background-position:center}
.column-card .body{padding:24px 0}
.column-card .cat{font-size:11px;letter-spacing:.3em;color:#c9a961;margin-bottom:12px}
.column-card h3{font-family:'Shippori Mincho B1',serif;font-size:20px;line-height:1.4;margin-bottom:12px}
.column-card p{font-size:13px;opacity:.7;line-height:1.7}

/* Column article body */
.column-hero{
  background:linear-gradient(rgba(0,0,0,.7),rgba(0,0,0,.85)),url('https://images.unsplash.com/photo-1574095443374-6748e7dd6c84?w=2000&q=80') center/cover no-repeat;
  color:#fff;padding:120px 32px;text-align:center
}
.column-hero .eyebrow{font-size:11px;letter-spacing:.4em;color:#c9a961;margin-bottom:20px}
.column-hero h1{font-family:'Shippori Mincho B1',serif;font-size:clamp(28px,4vw,44px);line-height:1.3;max-width:880px;margin:0 auto}
.column-body{padding:80px 0;max-width:780px;margin:0 auto}
.column-body p{font-size:16px;line-height:1.95;margin-bottom:20px}
.column-body h2{font-family:'Shippori Mincho B1',serif;font-size:28px;margin:60px 0 20px;padding-bottom:12px;border-bottom:2px solid #c9a961}
.column-body h3{font-family:'Shippori Mincho B1',serif;font-size:20px;margin:32px 0 12px}
.column-body ul,.column-body ol{margin:0 0 20px 24px}
.column-body li{font-size:15px;line-height:1.9;margin-bottom:8px}

/* Footer */
footer{background:#000;color:#fff;padding:60px 32px 40px;text-align:center}
footer .logo{font-family:'Shippori Mincho B1',serif;font-size:18px;letter-spacing:.05em;margin-bottom:24px;display:inline-block}
footer .logo span{color:#c9a961}
footer .fnav{display:flex;justify-content:center;gap:32px;margin-bottom:32px;font-size:12px;letter-spacing:.15em;flex-wrap:wrap}
footer .fsns{display:flex;justify-content:center;gap:24px;margin-bottom:32px;font-size:11px;letter-spacing:.2em;opacity:.7;flex-wrap:wrap}
footer .copyright{font-size:11px;opacity:.4;letter-spacing:.15em}

/* Responsive */
@media (max-width:768px){
  .wrap,.wrap-narrow{padding:0 20px}
  #hdr .nav{position:relative;padding:16px 20px;flex-direction:column;gap:12px}
  #hdr .nav-links{gap:20px;font-size:11px;flex-wrap:wrap;justify-content:center}
  .lang-switch{position:absolute;top:14px;right:16px}
  .lang-switch>button{padding:4px 10px;font-size:10px}
  .lang-menu{right:0;left:auto}
  .hero{padding:100px 20px 120px}
  .hero h1{font-size:clamp(36px,11vw,60px);line-height:1.2;letter-spacing:0;word-break:keep-all;overflow-wrap:break-word}
  .hero p br{display:none}
  .section{padding:60px 0}
  .top10-item{grid-template-columns:50px 80px 1fr;gap:16px}
  .top10-rank{font-size:32px}
  .top10-thumb{width:80px;height:60px}
  .top10-link{display:none}
  .rank-row{grid-template-columns:40px 60px 1fr;gap:12px}
  .rank-thumb{width:60px;height:45px}
  .detail-info{padding:24px;grid-template-columns:1fr}
  .criteria-grid{grid-template-columns:1fr;gap:48px}
}
