/* Himeji page-specific styles adapted from the Kobe/Osaka page family.
   Shared navbar/footer/dropdowns/reveal live in fernweh-global.css.
   Shared region hero/sidebar live in region-layout.css. */

:root{
  --hm-bg:#eef1f5;
  --hm-card:#ffffff;
  --hm-text:#1d2228;
  --hm-muted:#67717b;
  --hm-accent:#5f6f87;
  --hm-accent-strong:#4a5970;
  --hm-accent-soft:#f4f7fb;
  --hm-border:#d8dee7;
  --hm-border-soft:#e8edf3;
  --hm-gradient-start:#62728a;
  --hm-gradient-end:#93a0b5;
}

body{background:var(--hm-bg);color:var(--hm-text);}
main{display:block;}
.himeji-region-hero{--fj-region-hero-image:url('https://commons.wikimedia.org/wiki/Special:FilePath/Himeji_Castle_The_Keep_Towers.jpg');}

.chiba-section{padding:92px 24px 0;}
.chiba-wrap{max-width:1280px;margin:0 auto;}
.chiba-head{max-width:920px;margin-bottom:34px;}
.chiba-eyebrow{display:block;font-family:"Alegreya",serif;color:var(--hm-accent);font-size:20px;font-weight:700;margin-bottom:10px;}
.chiba-title{font-family:"Alegreya",serif;font-size:clamp(38px, 5vw, 58px);line-height:1.08;font-weight:800;color:var(--hm-accent);margin:0 0 16px;}
.chiba-line{width:320px;max-width:90%;height:2px;background:var(--hm-border);border-radius:999px;margin:0 0 20px;}
.chiba-lead{font-size:18px;line-height:1.65;color:var(--hm-muted);margin:0;}
.chiba-intro-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:24px;align-items:start;}
.chiba-panel,.chiba-fact-card,.chiba-sight,.chiba-area-card,.chiba-interest-card,.chiba-plan-card,.chiba-stay-card,.chiba-tip-card,.chiba-topic-link,.chiba-faq-item,.chiba-cta{background:var(--hm-card);border:1px solid var(--hm-border);border-radius:24px;box-shadow:0 14px 38px rgba(29,34,40,.06);}
.chiba-panel{padding:28px;}
.chiba-facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:22px;}
.chiba-fact-card{padding:18px;}
.chiba-fact-card strong{display:block;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--hm-accent);margin-bottom:6px;}
.chiba-fact-card span{display:block;color:var(--hm-muted);line-height:1.5;}
.chiba-toc{padding:28px;background:linear-gradient(180deg,#fff,var(--hm-accent-soft));}
.chiba-toc h3{font-family:"Alegreya",serif;font-size:30px;line-height:1.15;color:#1f2227;margin:0 0 12px;}
.chiba-toc ul{list-style:none;margin:0;padding:0;display:grid;gap:10px;}
.chiba-toc a{display:flex;justify-content:space-between;align-items:center;min-height:52px;padding:0 16px;border-radius:16px;background:#fff;border:1px solid var(--hm-border-soft);color:var(--hm-text);text-decoration:none;font-weight:700;transition:.2s ease;}
.chiba-toc a:hover{color:var(--hm-accent);border-color:#cfd7e2;transform:translateX(2px);}
.chiba-sights{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;}
.chiba-sight{overflow:hidden;display:flex;flex-direction:column;min-height:100%;}
.chiba-sight img{width:100%;height:240px;object-fit:cover;display:block;}
.chiba-sight-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1;}
.chiba-pill{display:inline-flex;align-items:center;min-height:28px;padding:0 12px;border-radius:999px;background:var(--hm-accent-soft);color:var(--hm-accent);font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;margin-bottom:12px;}
.chiba-sight h3,.chiba-area-card h3,.chiba-interest-card h3,.chiba-stay-card h3,.chiba-tip-card h3{font-family:"Alegreya",serif;font-size:28px;line-height:1.14;color:#1f2227;margin:0 0 10px;}
.chiba-sight p,.chiba-area-card p,.chiba-interest-card p,.chiba-stay-card p,.chiba-tip-card p,.chiba-plan-card p{color:var(--hm-muted);line-height:1.66;margin:0;}
.chiba-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:16px;}
.chiba-tag{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;border:1px solid var(--hm-border);background:#fbfcfe;color:#6b7280;font-size:14px;font-weight:600;}
.chiba-areas{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;}
.chiba-area-card,.chiba-interest-card,.chiba-stay-card,.chiba-tip-card{padding:24px;display:flex;flex-direction:column;min-height:100%;}
.chiba-interest-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));column-gap:18px;row-gap:56px;align-items:start;}
.chiba-tabbar{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 20px;}
.chiba-tab{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 18px;border-radius:999px;border:1px solid #d7dde6;background:#fff;color:#4f5a68;font-weight:700;cursor:pointer;transition:.2s ease;}
.chiba-tab:hover{border-color:#bdc7d4;color:var(--hm-accent);}
.chiba-tab.is-active{background:linear-gradient(135deg,var(--hm-gradient-start),var(--hm-gradient-end));border-color:transparent;color:#fff;box-shadow:0 10px 24px rgba(98,114,138,.24);}
.chiba-plan-intro{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;margin-bottom:18px;}
.chiba-plan-card{padding:24px;}
.chiba-plan-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;}
.chiba-plan-grid[data-days="5"]{grid-template-columns:repeat(5,minmax(0,1fr));}
.chiba-plan-grid[data-days="2"]{grid-template-columns:repeat(2,minmax(0,1fr));}
.chiba-plan-card ul{margin:12px 0 0;padding-left:18px;color:var(--hm-muted);line-height:1.7;}
.chiba-plan-card li+li{margin-top:6px;}
.chiba-plan-card h3{font-family:"Alegreya",serif;font-size:24px;line-height:1.16;color:var(--hm-accent);margin:0 0 10px;}
.chiba-plan-panel{display:none;}
.chiba-plan-panel.is-active{display:block;}
.chiba-stays{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));column-gap:18px;row-gap:28px;align-items:start;margin-bottom:60px;}
.chiba-stay-link{display:inline-flex;align-items:center;gap:8px;color:var(--hm-accent);font-weight:700;text-decoration:none;}
.chiba-stay-link:hover{text-decoration:underline;}
.chiba-stay-cta{display:block;width:100%;margin-top:60px;clear:both;position:relative;z-index:5;}
.chiba-tips{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;}
.chiba-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:18px;row-gap:56px;align-items:start;}
.chiba-faq{display:grid;gap:14px;}
.chiba-faq-item{padding:0;overflow:hidden;}
.chiba-faq-item summary{list-style:none;cursor:pointer;padding:22px 24px;font-family:"Source Sans 3",sans-serif;font-size:16px;line-height:1.5;color:var(--hm-text);font-weight:700;display:flex;align-items:center;gap:10px;}
.chiba-faq-item summary::-webkit-details-marker{display:none;}
.chiba-faq-item summary::before{content:"▸";font-size:15px;line-height:1;color:var(--hm-text);flex:none;transition:transform .2s ease;}
.chiba-faq-item[open] summary::before{transform:rotate(90deg);}
.chiba-faq-item p{padding:0 24px 22px;color:var(--hm-muted);line-height:1.7;margin:0;}
.chiba-topic-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}
.chiba-topic-link{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:84px;padding:22px 20px;color:var(--hm-text);text-decoration:none;font-weight:700;font-size:18px;line-height:1.35;transition:transform .2s ease,color .2s ease,box-shadow .2s ease;}
.chiba-topic-link span:last-child{color:var(--hm-accent);font-size:22px;flex:none;}
.chiba-topic-link:hover{color:var(--hm-accent);transform:translateY(-1px);}
.chiba-cta{padding:38px 34px;background:linear-gradient(135deg,var(--hm-gradient-start),var(--hm-gradient-end));color:#fff;}
.chiba-cta h2{font-family:"Alegreya",serif;font-size:48px;line-height:1.06;margin:0 0 12px;}
.chiba-cta p{max-width:780px;color:#f2f6fb;font-size:18px;line-height:1.65;margin:0 0 18px;}
.chiba-cta a{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 20px;border-radius:999px;background:#fff;color:var(--hm-accent);font-weight:700;text-decoration:none;}
.chiba-cta a:hover{transform:translateY(-1px);}
.chiba-cta-section{padding-bottom:72px;}
@media (max-width:780px){.chiba-cta-section{padding-bottom:48px;}}
@media (max-width:1400px){.chiba-hero-inner{width:min(1580px, calc(100vw - 18px));padding:140px 24px 80px 4px;}}
@media (max-width:1180px){
  .chiba-hero-inner{grid-template-columns:1fr;width:min(1280px, calc(100vw - 28px));padding:138px 20px 72px 20px;gap:28px;}
  .region-kanto-rail,.region-chubu-rail,.region-kansai-rail{max-width:100%;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));}
  .chiba-intro-grid,.chiba-plan-intro{grid-template-columns:1fr;}
  .chiba-sights,.chiba-areas,.chiba-interest-grid,.chiba-stays,.chiba-topic-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .chiba-plan-grid,.chiba-plan-grid[data-days="5"]{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:780px){
  .chiba-hero-inner{width:100%;padding:152px 16px 56px;gap:24px;}
  .region-kanto-rail,.region-chubu-rail,.region-kansai-rail{grid-template-columns:repeat(2,minmax(0,1fr));}
  .chiba-hero h1{font-size:clamp(42px,14vw,72px);}
  .chiba-hero p{font-size:18px;}
  .chiba-section{padding:68px 16px 0;}
  .chiba-sights,.chiba-areas,.chiba-interest-grid,.chiba-plan-grid,.chiba-plan-grid[data-days="5"],.chiba-stays,.chiba-tips,.chiba-topic-grid,.chiba-grid-2{grid-template-columns:1fr;}
  .chiba-facts{grid-template-columns:1fr;}
  .chiba-sight img{height:220px;}
  .chiba-topic-link{min-height:72px;}
  .chiba-title{font-size:40px;}
  .chiba-cta h2{font-size:36px;}
  .chiba-interest-grid,.chiba-grid-2{row-gap:24px;}
  .chiba-stays{row-gap:20px;margin-bottom:30px;}
  .chiba-stay-cta{margin-top:30px;}
}

/* Himeji-specific refinements */
@media (min-width:1181px){
  .himeji-region-hero .fj-region-hero-inner{
    width:min(1440px, calc(100vw - 48px));
    padding:150px 24px 88px;
    gap:28px;
    align-items:start;
  }

  .himeji-region-hero .fj-region-rail{
    margin-top:0;
    max-width:200px;
    align-self:start;
    padding-top:10px;
  }

  .himeji-region-hero .fj-region-copy{
    max-width:780px;
  }
}

.himeji-region-hero .fj-region-title{
  font-size:clamp(48px, 5.4vw, 82px);
  max-width:840px;
}

.himeji-region-hero .fj-region-description{max-width:920px;}

.chiba-interest-card,.chiba-stay-card,.chiba-tip-card,.chiba-sight,.chiba-area-card{
  min-height:100%;
  position:relative;
  z-index:1;
}

#uebernachten{padding-bottom:48px;}

@media (max-width:780px){
  .himeji-region-hero .fj-region-title{
    font-size:clamp(38px, 11.5vw, 58px);
    max-width:100%;
  }
}

/* Himeji additional content sections */
.himeji-extra-section{padding-top:72px;}
.himeji-food-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  align-items:start;
}
.himeji-food-card,.himeji-access-card{
  background:#fff;
  border:1px solid var(--hm-border);
  border-radius:18px;
  box-shadow:0 10px 24px rgba(29,34,40,.04);
}
.himeji-food-card{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:16px 18px;
  min-height:96px;
}
.himeji-food-card--compact{min-height:auto;}
.himeji-food-icon,.himeji-access-icon{
  flex:none;
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--hm-accent-soft);
  font-size:18px;
  line-height:1;
}
.himeji-food-content h3,.himeji-access-content h3{
  margin:0 0 6px;
  font-family:"Source Sans 3",sans-serif;
  font-size:24px;
  line-height:1.15;
  font-weight:700;
  color:#1f2227;
}
.himeji-food-content p,.himeji-access-content p{
  margin:0;
  color:var(--hm-muted);
  line-height:1.55;
}
.himeji-access-list{display:grid;gap:14px;}
.himeji-access-card{
  display:flex;
  align-items:flex-start;
  gap:16px;
  padding:18px 20px;
}
.himeji-access-content h3{font-size:22px;}

@media (max-width:1180px){
  .himeji-food-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width:780px){
  .himeji-extra-section{padding-top:56px;}
  .himeji-food-grid{grid-template-columns:1fr;}
  .himeji-food-card,.himeji-access-card{padding:16px;}
  .himeji-food-content h3,.himeji-access-content h3{font-size:20px;}
}
