:root{
  --teal:#0d4f4a; --teal-d:#0a2628; --gold:#c8a04e; --gold-d:#a8842f;
  --cream:#faf6ee; --ink:#1c2b2a; --muted:#5f6f6d; --line:#e6ddc9; --white:#fff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Noto Sans JP",sans-serif;color:var(--ink);background:var(--cream);line-height:1.8;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Noto Serif JP",serif;line-height:1.4}

/* header */
.site-head{position:sticky;top:0;z-index:50;background:rgba(250,246,238,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.head-inner{max-width:1180px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:10px;font-family:"Noto Serif JP",serif;font-weight:700;font-size:1.05rem;color:var(--teal)}
.brand-mark{display:grid;place-items:center;width:34px;height:34px;background:var(--teal);color:var(--gold);border-radius:50%;font-size:1rem}
.brand-txt small{display:block;font-family:"Noto Sans JP",sans-serif;font-size:.6rem;letter-spacing:.18em;color:var(--muted);font-weight:500}
.head-nav{display:flex;gap:22px;font-size:.9rem;font-weight:500}
.head-nav a{color:var(--ink);padding:4px 0;border-bottom:2px solid transparent;transition:.2s}
.head-nav a:hover{color:var(--teal);border-color:var(--gold)}

/* hero */
.hero{background-size:cover;background-position:center;color:var(--white)}
.hero-inner{max-width:1180px;margin:0 auto;padding:120px 24px 110px}
.hero-kicker{letter-spacing:.28em;font-size:.72rem;font-weight:700;color:var(--gold);margin-bottom:18px}
.hero h1{font-size:clamp(2.3rem,5.5vw,4rem);font-weight:700;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.hero-lead{max-width:620px;margin:22px 0 26px;font-size:1.02rem;line-height:1.9;text-shadow:0 1px 12px rgba(0,0,0,.5)}
.hero-chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:34px}
.hero-chips span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.34);padding:7px 15px;border-radius:999px;font-size:.84rem;font-weight:500}
.hero-btn{display:inline-block;background:var(--gold);color:var(--teal-d);font-weight:700;padding:14px 30px;border-radius:999px;font-size:.95rem;transition:.2s}
.hero-btn:hover{background:#dcb869;transform:translateY(-2px)}

/* sections */
.sec-inner{max-width:1180px;margin:0 auto;padding:84px 24px}
.sec-kicker{letter-spacing:.24em;font-size:.72rem;font-weight:700;color:var(--gold-d);margin-bottom:10px}
.sec-title{font-size:clamp(1.6rem,3.4vw,2.3rem);color:var(--teal);font-weight:700}
.sec-title small{font-family:"Noto Sans JP",sans-serif;font-size:.82rem;color:var(--muted);font-weight:500;margin-left:10px}
.sec-desc{color:var(--muted);margin-top:12px;max-width:680px}

/* criteria */
.criteria{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.crit-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:34px}
.crit-item{background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:24px 18px;text-align:center}
.crit-ico{font-size:1.9rem;display:block;margin-bottom:8px}
.crit-item h4{color:var(--teal);font-size:1.05rem;margin-bottom:8px}
.crit-item p{font-size:.82rem;color:var(--muted);line-height:1.7}

/* ranking cards */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:38px}
.cc-card,.c-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.25s;box-shadow:0 6px 20px rgba(10,38,40,.05)}
.c-card:hover{transform:translateY(-6px);box-shadow:0 16px 38px rgba(10,38,40,.16);border-color:var(--gold)}
.cc-img{position:relative;height:188px;background-size:cover;background-position:center}
.cc-rank{position:absolute;top:12px;left:12px;width:40px;height:40px;display:grid;place-items:center;background:var(--teal);color:var(--gold);font-family:"Noto Serif JP",serif;font-weight:700;font-size:1.2rem;border-radius:50%;box-shadow:0 4px 12px rgba(0,0,0,.3)}
.cc-budget{position:absolute;top:14px;right:14px;font-size:.74rem;font-weight:700;padding:5px 11px;border-radius:999px;color:var(--white)}
.b-best{background:#1f8a5b}.b-ok{background:#3a82c4}.b-warn{background:#d99326}.b-ng{background:#b5503f}
.cc-body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1}
.cc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.cc-head h3{font-size:1.32rem;color:var(--teal)}
.cc-en{font-size:.74rem;color:var(--muted);letter-spacing:.04em;margin-top:2px}
.cc-total{text-align:center;line-height:1;flex-shrink:0}
.cc-total b{font-family:"Noto Serif JP",serif;font-size:1.7rem;color:var(--gold-d)}
.cc-total small{display:block;font-size:.66rem;color:var(--muted);margin-top:2px}
.cc-tag{font-size:.86rem;color:var(--ink);margin:12px 0 14px;flex:1}
.cc-axes{display:flex;flex-direction:column;gap:5px;padding-top:14px;border-top:1px dashed var(--line)}
.ax{display:flex;align-items:center;gap:9px}
.ax span{font-size:.72rem;color:var(--muted);width:30px;flex-shrink:0}
.axd{display:flex;gap:3px}
.axd i{width:13px;height:7px;border-radius:2px;background:var(--line)}
.axd i.on{background:var(--gold)}
.cc-more{margin-top:15px;font-size:.84rem;font-weight:700;color:var(--teal);align-self:flex-start}
.c-card:hover .cc-more{color:var(--gold-d)}

/* country hero */
.c-hero{background-size:cover;background-position:center;color:var(--white)}
.c-hero-inner{max-width:1180px;margin:0 auto;padding:110px 24px 96px}
.c-hero-rank{letter-spacing:.2em;font-size:.76rem;font-weight:700;color:var(--gold);margin-bottom:12px}
.c-hero h1{font-size:clamp(2.6rem,6vw,4.4rem);font-weight:700;text-shadow:0 2px 24px rgba(0,0,0,.45)}
.c-hero-en{font-size:1rem;letter-spacing:.16em;color:rgba(255,255,255,.8);margin-top:4px}
.c-hero-tag{margin:18px 0 22px;font-size:1.05rem;max-width:640px;text-shadow:0 1px 12px rgba(0,0,0,.5)}
.c-hero-meta{display:flex;flex-wrap:wrap;gap:12px}
.ch-total{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.34);padding:9px 18px;border-radius:999px;font-size:.9rem}
.ch-total b{font-family:"Noto Serif JP",serif;font-size:1.3rem;color:var(--gold)}
.ch-budget{padding:9px 18px;border-radius:999px;font-size:.9rem;font-weight:700;color:var(--white)}

/* country main */
.c-main{max-width:1180px;margin:0 auto;padding:0 24px}
.c-slides{padding:78px 0 20px}
.c-slides .sec-kicker{color:var(--gold-d)}
.slide-wrap{display:flex;flex-direction:column;gap:34px;margin-top:34px}
.slide{position:relative;background:var(--white);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 12px 34px rgba(10,38,40,.12)}
.slide-no{position:absolute;top:0;left:0;background:var(--teal);color:var(--gold);font-family:"Noto Serif JP",serif;font-weight:700;font-size:.86rem;padding:7px 18px;border-bottom-right-radius:12px;z-index:2}
.slide img{width:100%}

/* score panel */
.c-score{padding:58px 0}
.score-panel{display:grid;grid-template-columns:1fr 220px;gap:30px;margin-top:26px;background:var(--white);border:1px solid var(--line);border-radius:16px;padding:32px}
.score-list{display:flex;flex-direction:column;gap:14px}
.score-row{display:flex;align-items:center;gap:14px}
.score-label{width:74px;font-size:.92rem;font-weight:500;color:var(--teal);flex-shrink:0}
.score-dots{display:flex;gap:6px;flex:1}
.dot{flex:1;height:14px;border-radius:4px;background:var(--line)}
.dot.on{background:linear-gradient(180deg,var(--gold),var(--gold-d))}
.score-num{font-family:"Noto Serif JP",serif;font-weight:700;color:var(--gold-d);width:20px;text-align:right}
.score-total{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--teal);color:var(--white);border-radius:12px;padding:24px}
.st-num{font-family:"Noto Serif JP",serif;font-size:3.4rem;font-weight:700;color:var(--gold);line-height:1}
.st-max{font-size:.84rem;color:rgba(255,255,255,.7);margin-bottom:12px}
.st-budget{padding:6px 16px;border-radius:999px;font-size:.84rem;font-weight:700}

/* gallery */
.c-gallery{padding:36px 0 70px}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:26px}
.g-item{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3;cursor:zoom-in;background:var(--line)}
.g-item img{width:100%;height:100%;object-fit:cover;transition:.35s}
.g-item:hover img{transform:scale(1.07)}
.g-cap{position:absolute;left:0;right:0;bottom:0;padding:16px 10px 8px;font-size:.72rem;color:#fff;background:linear-gradient(180deg,transparent,rgba(0,0,0,.78));opacity:0;transition:.25s}
.g-item:hover .g-cap{opacity:1}

/* country nav */
.c-nav{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;padding:30px 0 80px;align-items:center}
.cn-prev,.cn-next{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:16px 20px;transition:.2s}
.cn-prev:hover,.cn-next:hover{border-color:var(--gold);transform:translateY(-2px)}
.cn-next{text-align:right}
.cn-prev span,.cn-next span{display:block;font-size:.74rem;color:var(--muted)}
.cn-prev b,.cn-next b{font-family:"Noto Serif JP",serif;color:var(--teal);font-size:1.05rem}
.cn-top{background:var(--teal);color:var(--white);padding:16px 26px;border-radius:12px;font-weight:700;font-size:.9rem;white-space:nowrap}
.cn-top:hover{background:var(--teal-d)}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(8,20,21,.93);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:14px}
.lightbox[hidden]{display:none}
.lb-img{max-width:92vw;max-height:80vh;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.lb-cap{color:#fff;font-size:.9rem}
.lb-close{position:absolute;top:22px;right:30px;width:46px;height:46px;border:0;border-radius:50%;background:rgba(255,255,255,.16);color:#fff;font-size:1.6rem;cursor:pointer;line-height:1}
.lb-close:hover{background:var(--gold);color:var(--teal-d)}

/* footer */
.site-foot{background:var(--teal-d);color:rgba(255,255,255,.82)}
.foot-inner{max-width:1180px;margin:0 auto;padding:54px 24px}
.foot-title{font-family:"Noto Serif JP",serif;font-weight:700;color:var(--gold);font-size:1.15rem;margin-bottom:8px}
.foot-meta{font-size:.86rem;margin-bottom:14px}
.foot-note{font-size:.76rem;color:rgba(255,255,255,.55);line-height:1.8;max-width:760px}

/* responsive */
@media(max-width:900px){
  .crit-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .score-panel{grid-template-columns:1fr}
  .head-nav{gap:14px;font-size:.82rem}
}
@media(max-width:560px){
  .head-nav{display:none}
  .hero-inner,.c-hero-inner{padding-top:80px;padding-bottom:70px}
  .crit-grid{grid-template-columns:1fr}
  .card-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .sec-inner{padding:56px 18px}
  .c-main{padding:0 16px}
  .c-nav{grid-template-columns:1fr}
  .cn-next{text-align:left}
}
