:root{
  --bg: #fffaf7;
  --bg-soft: #fff4ef;
  --bg-mist: #fffdfc;
  --surface: rgba(255,255,255,0.86);
  --surface-strong: rgba(255,255,255,0.94);

  --ink: #433532;
  --ink-soft: #6d5a56;
  --ink-faint: #907d78;

  --line: rgba(110, 83, 76, 0.12);
  --line-strong: rgba(110, 83, 76, 0.22);

  --accent: #d97c8e;
  --accent-deep: #b75e70;
  --accent-soft: #f5cdd6;
  --accent-blush: #fdecef;

  --matcha: #89a881;
  --sky: #a7c7df;
  --gold: #d9b178;

  --shadow-sm: 0 8px 24px rgba(72, 48, 42, 0.06);
  --shadow-md: 0 18px 40px rgba(72, 48, 42, 0.10);
  --shadow-lg: 0 28px 70px rgba(72, 48, 42, 0.16);

  --radius-xs: 12px;
  --radius-sm: 18px;
  --radius-md: 26px;
  --radius-lg: 36px;
  --radius-pill: 999px;

  --maxw: 1240px;
  --gutter: clamp(18px, 3vw, 32px);
  --header-h: 74px;

  --serif-jp: "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --sans-jp: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  --serif-en: "Cormorant Garamond", "Georgia", serif;
  --sans-en: "Inter", "Helvetica Neue", Arial, sans-serif;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
}

body{
  margin:0;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(253,232,238,0.95), transparent 26%),
    radial-gradient(circle at top right, rgba(251,241,230,0.90), transparent 28%),
    linear-gradient(180deg, #fffdfc 0%, #fff8f4 42%, #fffaf7 100%);
  font-family:var(--sans-jp);
  font-size:16px;
  line-height:1.8;
  letter-spacing:0.01em;
  text-rendering:optimizeLegibility;
}

html[lang="en"] body{
  font-family:var(--sans-en);
  line-height:1.75;
}

img{
  display:block;
  max-width:100%;
  height:auto;
}

a{
  color:inherit;
  text-decoration:none;
}

button,
input,
textarea,
select{
  font:inherit;
}

button{
  cursor:pointer;
}

::selection{
  background:#f7dbe2;
  color:#3d2d2a;
}

.site-wrap{
  min-height:100vh;
  overflow:hidden;
}

.container{
  width:min(calc(100% - 2 * var(--gutter)), var(--maxw));
  margin-inline:auto;
}

.container-narrow{
  width:min(calc(100% - 2 * var(--gutter)), 860px);
  margin-inline:auto;
}

.section{
  position:relative;
  padding:clamp(52px, 8vw, 96px) 0;
}

.section-tight{
  padding:clamp(34px, 6vw, 60px) 0;
}

.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:18px;
  margin-bottom:26px;
}

.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,0.72);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  color:var(--accent-deep);
  font-size:0.82rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.section-title{
  margin:10px 0 0;
  font-family:var(--serif-jp);
  font-size:clamp(1.9rem, 4vw, 3.1rem);
  line-height:1.15;
  letter-spacing:0.01em;
}

html[lang="en"] .section-title{
  font-family:var(--serif-en);
}

.section-lead{
  max-width:760px;
  margin:14px 0 0;
  color:var(--ink-soft);
  font-size:1.03rem;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
  color:var(--accent-deep);
  font-size:0.9rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.eyebrow::before{
  content:"";
  width:24px;
  height:1px;
  background:linear-gradient(90deg, var(--accent), transparent);
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  height:var(--header-h);
  transition:background .25s ease, border-color .25s ease, box-shadow .25s ease;
}

.site-header.is-scrolled{
  background:rgba(255,250,247,0.88);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border-bottom:1px solid var(--line);
  box-shadow:0 10px 30px rgba(56,36,30,0.06);
}

.site-header-inner{
  height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}

.brand-mark{
  width:46px;
  height:46px;
  border-radius:16px;
  overflow:hidden;
  background:linear-gradient(135deg, #ffe8ef 0%, #fff8f3 60%, #faebd7 100%);
  border:1px solid rgba(173,120,128,0.18);
  box-shadow:var(--shadow-sm);
  flex:0 0 auto;
}

.brand-mark img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.brand-text{
  min-width:0;
}

.brand-title{
  display:block;
  font-size:1.08rem;
  font-weight:800;
  line-height:1.1;
}

.brand-sub{
  display:block;
  margin-top:2px;
  color:var(--ink-faint);
  font-size:0.78rem;
  line-height:1.3;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.nav-wrap{
  display:flex;
  align-items:center;
  gap:12px;
}

.site-nav{
  display:flex;
  align-items:center;
  gap:4px;
}

.site-nav a{
  padding:10px 12px;
  border-radius:var(--radius-pill);
  color:var(--ink-soft);
  font-size:0.92rem;
  font-weight:700;
  transition:background .2s ease, color .2s ease, transform .2s ease;
}

.site-nav a:hover,
.site-nav a:focus-visible,
.site-nav a.is-current{
  background:rgba(255,255,255,0.84);
  color:var(--accent-deep);
  transform:translateY(-1px);
  outline:none;
}

.header-tools{
  display:flex;
  align-items:center;
  gap:10px;
}

.lang-switch{
  display:flex;
  align-items:center;
  padding:4px;
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,0.82);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}

.lang-switch a{
  padding:8px 12px;
  border-radius:var(--radius-pill);
  color:var(--ink-soft);
  font-size:0.84rem;
  font-weight:800;
}

.lang-switch a.is-current{
  background:linear-gradient(135deg, #fbe2e9, #fff1f5);
  color:var(--accent-deep);
}

.menu-toggle{
  display:none;
  width:44px;
  height:44px;
  border:none;
  border-radius:16px;
  background:rgba(255,255,255,0.84);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  color:var(--ink);
  align-items:center;
  justify-content:center;
}

.menu-toggle svg{
  width:22px;
  height:22px;
}

/* Mobile menu */
.mobile-nav{
  display:none;
  position:fixed;
  inset:var(--header-h) 0 0 0;
  z-index:999;
  background:rgba(255,250,247,0.92);
  backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%);
  padding:14px var(--gutter) 28px;
  overflow:auto;
}

.mobile-nav.is-open{
  display:block;
}

.mobile-nav-panel{
  background:rgba(255,255,255,0.82);
  border:1px solid var(--line);
  border-radius:28px;
  box-shadow:var(--shadow-md);
  padding:18px;
}

.mobile-nav-grid{
  display:grid;
  gap:8px;
}

.mobile-nav-grid a{
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,0.70);
  border:1px solid rgba(115,84,76,0.08);
  color:var(--ink);
  font-weight:700;
}

.mobile-nav-grid a:hover,
.mobile-nav-grid a.is-current{
  color:var(--accent-deep);
  background:#fff;
}

.mobile-lang{
  display:flex;
  gap:10px;
  margin-top:14px;
}

/* Hero */
.hero{
  position:relative;
  padding:clamp(28px, 6vw, 50px) 0 clamp(52px, 8vw, 88px);
}

.hero-grid{
  display:grid;
  grid-template-columns:1.08fr 0.92fr;
  gap:clamp(24px, 4vw, 40px);
  align-items:center;
}

.hero-title{
  margin:0;
  font-family:var(--serif-jp);
  font-size:clamp(2.5rem, 7vw, 5.2rem);
  line-height:0.98;
  letter-spacing:-0.01em;
}

html[lang="en"] .hero-title{
  font-family:var(--serif-en);
}

.hero-intro{
  max-width:700px;
  margin:18px 0 0;
  color:var(--ink-soft);
  font-size:1.07rem;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:26px;
}

.hero-card{
  position:relative;
  overflow:hidden;
  border-radius:36px;
  box-shadow:var(--shadow-lg);
  background:#fff;
  border:1px solid rgba(173,120,128,0.14);
  aspect-ratio:4 / 5;
}

.hero-card img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.hero-overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:18px;
  background:linear-gradient(180deg, transparent, rgba(52,31,29,0.66));
  color:#fff;
}

.hero-note{
  font-size:0.92rem;
  line-height:1.5;
  color:rgba(255,255,255,0.93);
}

.hero-floating{
  position:absolute;
  border-radius:24px;
  background:rgba(255,255,255,0.78);
  border:1px solid rgba(255,255,255,0.56);
  box-shadow:var(--shadow-md);
  padding:14px 16px;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}

.hero-floating.top{
  top:-14px;
  right:24px;
}

.hero-floating.bottom{
  left:-8px;
  bottom:18px;
}

.hero-floating strong{
  display:block;
  font-size:0.86rem;
  color:var(--accent-deep);
}

.hero-floating span{
  display:block;
  margin-top:4px;
  color:var(--ink-soft);
  font-size:0.84rem;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:50px;
  padding:0 18px;
  border:none;
  border-radius:var(--radius-pill);
  font-weight:800;
  letter-spacing:0.01em;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}

.btn:hover,
.btn:focus-visible{
  transform:translateY(-2px);
  outline:none;
}

.btn-primary{
  color:#fff;
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-deep) 100%);
  box-shadow:0 14px 30px rgba(195,102,121,0.22);
}

.btn-secondary{
  color:var(--ink);
  background:rgba(255,255,255,0.88);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}

.btn-soft{
  color:var(--accent-deep);
  background:var(--accent-blush);
  border:1px solid rgba(217,124,142,0.18);
}

.link-arrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--accent-deep);
  font-weight:800;
}

.link-arrow::after{
  content:"→";
  transition:transform .2s ease;
}

.link-arrow:hover::after{
  transform:translateX(3px);
}

/* Grid + cards */
.grid{
  display:grid;
  gap:20px;
}

.grid-2{
  grid-template-columns:repeat(2, minmax(0,1fr));
}

.grid-3{
  grid-template-columns:repeat(3, minmax(0,1fr));
}

.grid-4{
  grid-template-columns:repeat(4, minmax(0,1fr));
}

.card{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius-md);
  background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(255,255,255,0.84));
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}

.card-media{
  position:relative;
  aspect-ratio:4 / 3;
  overflow:hidden;
  background:#f8efea;
}

.card-media.tall{
  aspect-ratio:4 / 5;
}

.card-media.square{
  aspect-ratio:1 / 1;
}

.card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .45s ease;
}

.card:hover .card-media img{
  transform:scale(1.03);
}

.card-body{
  padding:18px 18px 20px;
}

.card-kicker{
  display:inline-flex;
  margin-bottom:8px;
  color:var(--accent-deep);
  font-size:0.8rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.card-title{
  margin:0;
  font-size:1.16rem;
  line-height:1.35;
  font-weight:800;
}

.card-text{
  margin:10px 0 0;
  color:var(--ink-soft);
  font-size:0.96rem;
  line-height:1.72;
}

.card-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}

.pill{
  display:inline-flex;
  align-items:center;
  padding:7px 11px;
  border-radius:var(--radius-pill);
  background:#fff;
  border:1px solid rgba(115,84,76,0.10);
  color:var(--ink-soft);
  font-size:0.8rem;
  font-weight:700;
}

/* Feature split */
.feature-split{
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:24px;
  align-items:stretch;
}

.feature-panel{
  overflow:hidden;
  border-radius:34px;
  background:linear-gradient(135deg, rgba(255,255,255,0.96), rgba(255,250,247,0.88));
  border:1px solid var(--line);
  box-shadow:var(--shadow-md);
}

.feature-panel-image{
  aspect-ratio:16 / 10;
}

.feature-panel-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.feature-panel-copy{
  padding:clamp(22px, 3vw, 34px);
}

.feature-panel-title{
  margin:0;
  font-family:var(--serif-jp);
  font-size:clamp(1.6rem, 3vw, 2.4rem);
  line-height:1.15;
}

html[lang="en"] .feature-panel-title{
  font-family:var(--serif-en);
}

.feature-panel-text{
  margin:14px 0 0;
  color:var(--ink-soft);
}

.sidebar-stack{
  display:grid;
  gap:18px;
}

/* Haiku */
.haiku-wrap{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}

.haiku-card{
  padding:24px 22px;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,0.94), rgba(255,247,244,0.84));
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  min-height:220px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.haiku-card p{
  margin:0;
  font-family:var(--serif-jp);
  font-size:1.18rem;
  line-height:1.8;
  white-space:pre-line;
}

html[lang="en"] .haiku-card p{
  font-family:var(--serif-en);
}

.haiku-card .meta{
  margin-top:16px;
  color:var(--accent-deep);
  font-size:0.84rem;
  font-weight:800;
}

/* Character cards */
.character-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:18px;
}

.character-card{
  text-align:center;
  padding:20px;
  border-radius:30px;
  background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(255,250,247,0.86));
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}

.character-badge{
  width:min(180px, 72%);
  margin:0 auto 14px;
  aspect-ratio:1 / 1;
  border-radius:24px;
  overflow:hidden;
  background:#fff5f2;
  box-shadow:inset 0 0 0 1px rgba(115,84,76,0.08);
}

.character-badge img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.character-name{
  margin:0;
  font-size:1.08rem;
  font-weight:800;
}

.character-role{
  margin:8px 0 0;
  color:var(--ink-soft);
  font-size:0.94rem;
}

/* Scroller */
.scroller{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(260px, 300px);
  gap:18px;
  overflow:auto;
  padding-bottom:8px;
  scrollbar-width:thin;
}

.scroller::-webkit-scrollbar{
  height:10px;
}

.scroller::-webkit-scrollbar-thumb{
  background:#e8d0d6;
  border-radius:999px;
}

/* Article */
.article{
  display:grid;
  gap:28px;
}

.article-hero{
  overflow:hidden;
  border-radius:40px;
  box-shadow:var(--shadow-lg);
  border:1px solid rgba(173,120,128,0.14);
}

.article-hero img{
  width:100%;
  max-height:72vh;
  object-fit:cover;
}

.article-body{
  width:min(100%, 760px);
  margin:0 auto;
}

.article-body h1,
.article-body h2,
.article-body h3{
  color:var(--ink);
  line-height:1.2;
}

.article-body h1{
  font-family:var(--serif-jp);
  font-size:clamp(2.2rem, 5vw, 4rem);
  margin:0 0 18px;
}

.article-body h2{
  font-family:var(--serif-jp);
  font-size:clamp(1.55rem, 3vw, 2.2rem);
  margin:42px 0 12px;
}

.article-body h3{
  font-size:1.16rem;
  margin:24px 0 10px;
}

html[lang="en"] .article-body h1,
html[lang="en"] .article-body h2{
  font-family:var(--serif-en);
}

.article-body p,
.article-body li{
  color:var(--ink-soft);
}

.article-body p{
  margin:0 0 16px;
}

.article-body ul,
.article-body ol{
  padding-left:1.2em;
  margin:0 0 18px;
}

.article-body blockquote{
  margin:28px 0;
  padding:22px 24px;
  border-left:4px solid var(--accent-soft);
  background:#fff;
  border-radius:0 22px 22px 0;
  box-shadow:var(--shadow-sm);
}

.article-body table{
  width:100%;
  border-collapse:collapse;
  margin:24px 0;
  overflow:hidden;
  border-radius:18px;
  box-shadow:var(--shadow-sm);
}

.article-body th,
.article-body td{
  padding:12px 14px;
  border:1px solid var(--line);
  text-align:left;
  vertical-align:top;
  background:rgba(255,255,255,0.84);
}

.article-body th{
  background:#fff4f0;
}

/* Utilities */
.tag-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.kv{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
}

.kv .item{
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,0.82);
  border:1px solid var(--line);
}

.kv .label{
  display:block;
  color:var(--accent-deep);
  font-size:0.82rem;
  font-weight:800;
  letter-spacing:0.06em;
  text-transform:uppercase;
}

.kv .value{
  display:block;
  margin-top:6px;
  color:var(--ink);
  font-weight:700;
}

.notice{
  padding:16px 18px;
  border-radius:20px;
  background:linear-gradient(135deg, #fff4f7, #fff9f5);
  border:1px solid rgba(217,124,142,0.14);
  color:var(--ink-soft);
}

.divider{
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(115,84,76,0.20), transparent);
  margin:22px 0;
}

/* Footer */
.site-footer{
  margin-top:44px;
  padding:48px 0 28px;
  border-top:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,252,250,0.55), rgba(255,247,243,0.95));
}

.footer-grid{
  display:grid;
  grid-template-columns:1.15fr 0.85fr 0.85fr 0.85fr;
  gap:22px;
}

.footer-title{
  margin:0 0 12px;
  font-size:1rem;
  font-weight:800;
}

.footer-text{
  margin:0;
  color:var(--ink-soft);
  font-size:0.94rem;
}

.footer-links{
  display:grid;
  gap:8px;
}

.footer-links a{
  color:var(--ink-soft);
}

.footer-links a:hover{
  color:var(--accent-deep);
}

.footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-top:26px;
  padding-top:18px;
  border-top:1px solid var(--line);
  color:var(--ink-faint);
  font-size:0.88rem;
}

/* Critical fix: visible by default */
.reveal{
  opacity:1;
  transform:none;
}

.js-enhanced .reveal{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .7s ease, transform .7s ease;
}

.js-enhanced .reveal.is-visible{
  opacity:1;
  transform:none;
}

/* Responsive */
@media (max-width: 1120px){
  .site-nav{
    display:none;
  }

  .menu-toggle{
    display:inline-flex;
  }

  .hero-grid,
  .feature-split,
  .footer-grid{
    grid-template-columns:1fr;
  }

  .hero-card{
    aspect-ratio:16 / 13;
  }

  .character-grid{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }

  .grid-4{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 860px){
  :root{
    --header-h: 70px;
  }

  .section-head{
    align-items:start;
    flex-direction:column;
  }

  .grid-3,
  .grid-2,
  .haiku-wrap,
  .kv{
    grid-template-columns:1fr;
  }

  .hero-title{
    font-size:clamp(2.2rem, 11vw, 4rem);
  }

  .hero-floating{
    display:none;
  }

  .brand-sub{
    display:none;
  }

  .card-body{
    padding:16px;
  }
}

@media (max-width: 640px){
  body{
    font-size:15.5px;
  }

  .hero{
    padding-top:22px;
  }

  .hero-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .btn{
    width:100%;
  }

  .character-grid,
  .grid-4{
    grid-template-columns:1fr;
  }

  .mobile-nav{
    padding:14px 14px 28px;
  }

  .section{
    padding:46px 0;
  }

  .section-title{
    font-size:clamp(1.72rem, 8vw, 2.35rem);
  }

  .article-body h1{
    font-size:clamp(2rem, 9vw, 3rem);
  }
}

@media (prefers-reduced-motion: reduce){
  html{
    scroll-behavior:auto;
  }

  *,
  *::before,
  *::after{
    animation:none !important;
    transition:none !important;
  }

  .reveal,
  .js-enhanced .reveal,
  .js-enhanced .reveal.is-visible{
    opacity:1 !important;
    transform:none !important;
  }
}
