:root{
  --bg:#f6f9ff; --panel:#fff; --text:#0c1b4d; --muted:#63708f; --line:#dce5f5;
  --primary:#102a83; --primary-2:#eaf0ff; --accent:#2f64ff; --shadow:0 14px 34px rgba(30,56,120,.09);
  --radius:18px;
}
*{box-sizing:border-box}

body{
  margin:0;
  font-family:Noto Sans JP,-apple-system,"Segoe UI",sans-serif;background:var(--bg);
  color:var(--text)
}

a{
  color:var(--primary);
  text-decoration:none
}

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

.site-header{
  position:sticky;
  top:0;
  z-index:10;display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;padding:14px 28px;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--text)
}

.brand-icon{
  display:grid;
  place-items:center;
  width:36px;height:36px;
  border-radius:10px;
  background:var(--primary);
  color:#fff
}

.brand small{
  display:block;
  color:var(--muted);
  font-size:12px
}

.nav{
  display:flex;
  gap:22px;
  font-weight:700;
  font-size:14px;
  align-items: center;
}

.layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:24px;
  max-width:1360px;
  margin:0 auto;
  padding:24px;
  align-items:start
}

.main-column{
  display:grid;
  gap:20px
}

.side-column{
  display:flex;
  flex-direction:column;
  gap:20px;
  align-self:start
}

.hero{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;align-items:center;
  padding:32px;
  background-image: url("../image/cover.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow)
}

h1{
  font-size:clamp(28px,4vw,48px);
  line-height:1.35;
  margin:0 0 16px
}

h2{
  margin:0 0 14px;
  font-size:22px
}

h3{
  margin:18px 0 10px;
  font-size:15px
}

.muted,.breadcrumb{
  color:var(--muted);
  font-size:13px
}

.hero-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px
}

.hero-grid img{
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:12px;
  border:1px solid var(--line)
}

.panel{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow)
}

.compact{
  padding:18px
}

.side-column .panel{
  width:100%;
  align-self:stretch;
}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  margin-bottom:14px
}

.controls{
  display:flex;
  gap:8px;
  align-items:center
}

select,.search-box input{
  height:44px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  color:var(--text);
  padding:0 12px
}

.search-box{
  display:flex;
  gap:8px;
  max-width:680px;
  align-items:center;
}

.search-box .tag-select{
  flex:0 0 120px;
}

.search-box input{
  flex:1;
  min-width:0;
}

.search-box button,.button{
  display: inline-flex;
  align-items: center;
  height:44px;
  border:0;
  border-radius:12px;
  background:var(--primary);
  color:#fff;
  font-weight:700;
  padding:0 18px;
  cursor:pointer
}

.search-box.small{
  max-width:none
}

.request-banner{
  padding:24px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

.request-banner__label{
  margin:0 0 6px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.12em;
  color:var(--accent);
}

.request-banner h2{
  margin:8px 0;
  font-size:22px;
}

.request-banner p{
  margin:0;
  color:var(--muted);
}

.request-banner__button{
  flex-shrink:0;
  padding:12px 18px;
  border-radius:999px;
  background:var(--primary);
  color:#fff;
  font-weight:700;
  text-decoration:none;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
}

.request-banner__button:hover{
  transform:translateY(-1px);
  opacity:.9;
}

.icon-btn{
  height:38px;
  width:38px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  color:var(--text);
  cursor:pointer
}

.icon-btn.is-active{
  background:var(--primary);
  color:#fff
}

.kana-nav{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(54px,1fr));
  gap:10px
}

.kana-nav a{
  display:grid;
  place-items:center;
  min-height:42px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  font-weight:800;
  color:var(--text)
}

.kana-nav a.is-active{
  background:var(--primary);
  color:#fff
}

.kana-nav a.is-disabled{
  opacity:.35;
  pointer-events:none
}

.card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:18px
}

.character-card{
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  box-shadow:0 8px 20px rgba(25,50,100,.06)
}

.character-card img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  background:#eeeef4
}

.card-body{
  padding:12px
}

.character-name{
  margin:0;
  font-size:17px
}

.reading1{
  margin:3px 0 0px;
  color:var(--muted);
  font-size:12px
}

.reading2{
  margin:3px 0 10px;
  color:var(--muted);
  font-size:12px
}


.character-gender{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin:8px 0 10px;
  padding:4px 9px;
  border-radius:999px;
  background:#dee0fb;
  color:#5d3fb7;
  font-size:12px;
  font-weight:700;
}

.character-gender span{
  color:#5d3fb7;
  font-size:11px;
  letter-spacing:.05em;
}

.tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px
}

.tag{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:3px 8px;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--primary-2);
  font-size:12px;
  color:var(--primary);
  font-weight:700
}


.work-tags{
  margin-bottom:6px;
}

.work-tag{
  background:#ebebeb;
  color:#0c1b4d;
}

.detail-link{
  display:inline-block;
  margin-top:10px;
  font-size:13px;
  font-weight:800
}

.card-grid.is-list{
  grid-template-columns:1fr
}

.card-grid.is-list .character-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:stretch
}

.card-grid.is-list .character-card img{
  width:auto;
  height:100%;
  min-width:150px;
  max-width:200px;
  aspect-ratio:1/1;
  object-fit:cover;
  align-self:stretch;
  display:block
}

.card-grid.is-list .character-card .card-body{
  min-width:0
}

.tag-cloud{
  display:flex;
  flex-wrap:wrap;
  gap:8px
}

.tag-cloud a{
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  padding:7px 10px;
  font-size:13px;
  font-weight:700
}

.check-list{
  padding-left:20px;
  line-height:1.9
}

.empty{
  text-align:center;
  padding:40px;
  color:var(--muted)
}

.footer{
  padding:28px;
  text-align:center;
  color:var(--muted);
  border-top:1px solid var(--line)
}

@media (max-width: 980px){
  .layout{
    grid-template-columns:1fr
  }
  
  .hero{
    grid-template-columns:1fr
  }
  
  .side-column{
    display:flex;
    flex-direction:column;
  }
  
  .nav{display:none}
}

@media (max-width: 700px){
  .request-banner{
    flex-direction:column;
    align-items:flex-start;
    padding:22px;
  }

  .request-banner__button{
    width:100%;
    text-align:center;
  }
}

@media (max-width: 640px){
  .layout{
    padding:12px
  }
  
  .site-header{
    padding:12px
  }
  
  .hero,.panel{
    padding:16px
  }
  
  .side-column{
    display:flex;
    flex-direction:column;
  }
  
  .section-head{
    display:block
  }
  
  .controls{
    margin-top:10px
  }
  
  .card-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))
  }
  
  .search-box{
    flex-direction:column;
    min-height: 100px;
  }
  
  .search-box button{
    width:100%
  }
}

/* ===== Custom updates: header/search spacing, split banners, terms page ===== */
.hero-content{
  max-width:720px;
}

.hero-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:20px;
}

.terms-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  white-space:nowrap;
}

.hero-search{
  flex:1;
  max-width:550px;
  margin:0;
}

.banner-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}

.info-banner{
  position:relative;
  overflow:hidden;
  min-height:210px;
  padding:24px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  background:var(--panel);
  color:var(--text);
}

.info-banner::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(234,245,255,.78));
  z-index:0;
}

.terms-card::after,
.request-card::after,
.gacha-card::after,
.link-card::after{
  content:"";
  position:absolute;
  right:-36px;
  bottom:-42px;
  width:160px;
  height:160px;
  border-radius:999px;
  background:rgba(16,42,131,.08);
  z-index:0;
}


.terms-card::before{
  background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(237,230,255,.84));
}

.request-card::before{
  background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(255,232,238,.84));
}

.gacha-card::before{
  background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(229,241,255,.86));
}

.terms-card .info-banner__label,
.terms-card h2{
  color:#5d3fb7;
}

.request-card .info-banner__label,
.request-card h2{
  color:#e05273;
}

.gacha-card .info-banner__label,
.gacha-card h2{
  color:#225fc4;
}

.terms-card .info-banner__button{
  background:#5d3fb7;
}

.request-card .info-banner__button{
  background:#e05273;
}

.gacha-card .info-banner__button{
  background:#225fc4;
}

.collapsible-wrap{
  display:grid;
  gap:10px;
}

.tag-cloud.is-collapsed{
  overflow:hidden;
}

.tag-more-btn{
  justify-self:center;
  min-height:36px;
  padding:0 16px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  color:var(--primary);
  font-weight:800;
  cursor:pointer;
}

.tag-more-btn:hover{
  background:var(--primary-2);
}

.info-banner > *{
  position:relative;
  z-index:1;
}

.info-banner__label{
  margin:0;
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  color:var(--accent);
}

.info-banner h2{
  margin:0;
  font-size:22px;
  line-height:1.35;
}

.info-banner p{
  margin:0;
  color:var(--muted);
  line-height:1.7;
}

.info-banner__button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 16px;
  border-radius:999px;
  background:var(--primary);
  color:#fff;
  font-weight:800;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
}

.info-banner:hover{
  transform:translateY(-2px);
}

.terms-layout{
  max-width:960px;
  margin:0 auto;
  padding:24px;
}

.terms-panel{
  padding:32px;
}

.terms-panel h1{
  margin-bottom:18px;
}

.terms-section{
  padding-top:22px;
  margin-top:22px;
  border-top:1px solid var(--line);
}

.credit-box{
  display:inline-block;
  padding:12px 16px;
  border-radius:12px;
  background:var(--primary-2);
  color:var(--primary);
  font-weight:800;
}

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

@media (max-width: 760px){
  .banner-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 640px){
  .hero-actions{
    display:grid;
    grid-template-columns:1fr;
  }

  .hero-search{
    min-width:0;
    width:100%;
  }

  .terms-button{
    width:100%;
  }

  .info-banner{
    min-height:auto;
    padding:20px;
  }

  .terms-layout{
    padding:12px;
  }

  .terms-panel{
    padding:18px;
  }
}


/* ===== Random page and fixed 6-row side column ===== */
.random-layout{
  max-width:880px;
  margin:0 auto;
  padding:24px;
}

.random-panel{
  padding:32px;
}

.random-result{
  margin-top:24px;
}

.random-card{
  display:grid;
  grid-template-columns:220px 1fr;
  align-items:stretch;
  max-width:720px;
}

.random-card img{
  width:220px;
  height:220px;
  aspect-ratio:1/1;
  object-fit:cover;
}

.random-card .card-body{
  padding:24px;
}

.random-label{
  margin:0 0 8px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.14em;
  color:var(--accent);
}

.random-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:22px;
}

.secondary-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  color:var(--primary);
  border:1px solid var(--line);
}

@media (max-width: 640px){
  .random-layout{
    padding:12px;
  }

  .random-panel{
    padding:18px;
  }

  .random-card{
    grid-template-columns:1fr;
  }

  .random-card img{
    width:100%;
    height:auto;
  }

  .random-actions .button{
    width:100%;
  }
}

/* ===== Character list: show 10 items first ===== */
.character-more-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  margin:22px auto 0;
  padding:0 22px;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--primary);
  color:#fff;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,.10);
}

.character-more-btn:hover{
  opacity:.9;
  transform:translateY(-1px);
}

.character-more-btn[hidden]{
  display:none;
}


.social-link{
  padding:.45rem .8rem;
  background: var(--primary);
  color: #fff;
  border-radius:999px;
  text-decoration:none;
  font-size:.9rem;
}
.social-link:hover{opacity:.8;}

/* タグ一覧は中身の高さに合わせる。6行を超えた時だけJSのmax-heightで折りたたむ */
.tag-cloud{
  align-content:flex-start;
  align-items:flex-start;
  height:auto;
  min-height:0;
}

.collapsible-wrap{
  align-items:start;
}


/* ===== Fixed: tag panels show up to 6 rows, then expand with more button ===== */
.tag-cloud{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-content:flex-start;
  align-items:flex-start;
  height:auto;
  min-height:0;
}

.tag-cloud.is-collapsed{
  overflow:hidden;
}

.collapsible-wrap{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
}

.collapsible-wrap .tag-more-btn{
  align-self:center;
}


/* ===== Update: side search has no tag selector; keep main tag selector and search field horizontal on mobile ===== */
.side-search-box .tag-select{
  display:none;
}

@media (max-width: 640px){
  .hero-search{
    display:flex;
    flex-direction:row;
    flex-wrap:wrap;
    align-items:center;
    gap:8px;
    min-height:0;
  }

  .hero-search .tag-select{
    flex:0 0 calc(40% - 4px);
    min-width:104px;
    height:42px;
    padding:0 8px;
    font-size:13px;
  }

  .hero-search input{
    flex:1 1 calc(60% - 4px);
    min-width:0;
    height:42px;
    padding:0 8px;
    font-size:13px;
  }

  .hero-search button{
    flex:0 0 100%;
    width:100%;
    height:42px;
    padding:0 12px;
    font-size:13px;
    white-space:nowrap;
  }

  .side-search-box{
    flex-direction:row;
    min-height:0;
  }

  .side-search-box button{
    width:auto;
    flex:0 0 auto;
  }
}


/* ===== Gender tag display ===== */
.gender-tags{
  margin:8px 0 6px;
}
.gender-tag{
  border-color:#cfc8ff;
  background:#f0edff;
  color:#5d3fb7;
  font-weight:700;
}

@media (max-width: 640px){
  .card-grid.is-list .character-card{
    grid-template-columns:112px minmax(0,1fr)
  }

  .card-grid.is-list .character-card img{
    width:100%;
    height:100%;
    min-width:0;
    max-width:none
  }
}

/* ===== Category tag search sidebar ===== */
.search-panel{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.search-panel h2{
  margin-bottom:0;
}

.side-search-box{
  width:100%;
}

.side-search-box input{
  width:100%;
}

.tag-filter-groups{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.tag-filter-group{
  padding-top:14px;
  border-top:1px solid var(--line);
}

.tag-filter-group h3{
  margin:0 0 10px;
  font-size:14px;
  color:var(--text);
}

.tag-check-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  overflow:hidden;
}

.tag-check{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:30px;
  padding:6px 8px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
}

.tag-check input{
  flex:0 0 auto;
  accent-color:var(--primary);
}

.tag-check span{
  flex:1;
  min-width:0;
}

.tag-check small{
  color:var(--muted);
  font-size:11px;
}

.tag-check:hover{
  background:var(--primary-2);
}

.tag-filter-more-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  margin:10px auto 0;
  padding:0 14px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  color:var(--primary);
  font-weight:800;
  cursor:pointer;
}

.tag-filter-more-btn[hidden]{
  display:none;
}

.tag-filter-more-btn:hover{
  background:var(--primary-2);
}

.hero-search button,
.side-search-box button{
  display:none;
}

/* ===== Update: search UI is consolidated into the right column ===== */
.hero-actions,
.hero-search{
  display:none !important;
}

.side-kana-block{
  padding-top:14px;
  border-top:1px solid var(--line);
}

.side-subhead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}

.side-subhead h3{
  margin:0;
  font-size:14px;
}

.side-subhead a{
  font-size:12px;
  font-weight:800;
  color:var(--primary);
  text-decoration:none;
  white-space:nowrap;
}

.side-kana-nav{
  margin-top:0;
}

.side-kana-nav a{
  min-width:38px;
}

.search-panel{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.search-panel h2{
  margin-bottom:0;
}

.side-search-box{
  margin:0;
}

/* 性別タグは検索ボックス直下に来るため、最初のグループだけ余白を少し抑える */
.tag-filter-group:first-child{
  padding-top:0;
  border-top:0;
}

/* Fix: category tag filters collapse by item count, not by height. */
.tag-check[hidden]{
  display:none !important;
}
.tag-check-list.is-collapsed{
  max-height:none !important;
  overflow:visible;
}

/* ===== Layout update: hero/banners full width, search column aligned with character list ===== */
.page-layout{
  max-width:1360px;
  margin:0 auto;
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:20px;
}

.content-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:24px;
  align-items:start;
}

.content-layout .main-column{
  display:block;
}

.content-layout .main-column > .panel{
  margin:0;
}

.content-layout .side-column{
  align-self:start;
}

/* 4 banners: terms / request / random / guide */
.banner-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
  align-items:stretch;
}

.info-banner{
  min-height:200px;
}

.guide-card::before{
  background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(231,252,244,.86));
}

.guide-card .info-banner__label,
.guide-card h2{
  color:#158464;
}

.guide-card .info-banner__button{
  background:#158464;
}

/* keep search panel head aligned with character list head */
.search-panel{
  margin-top:0;
}

.guide-layout code{
  display:inline-block;
  padding:.1em .45em;
  border-radius:6px;
  background:var(--primary-2);
  color:var(--primary);
  font-weight:700;
}

.guide-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

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

@media (max-width: 980px){
  .content-layout{
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  .page-layout{
    padding:12px;
  }

  .banner-grid{
    grid-template-columns:1fr;
  }

  .info-banner{
    min-height:auto;
  }
}

@media (max-width: 640px){
  .guide-actions .button{
    width:100%;
  }
}

/* ===== Character card tag folding and full-width management button ===== */
.character-card{
  display:flex;
  flex-direction:column;
}

.character-card .card-body{
  display:flex;
  flex-direction:column;
  flex:1;
}

.card-tags-wrap{
  margin-top:6px;
}

.card-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  overflow:visible;
}

.card-tags.is-collapsed{
  max-height:30px;
  overflow:hidden;
}

.card-tags-toggle{
  appearance:none;
  border:0;
  background:transparent;
  color:var(--primary);
  font-size:12px;
  font-weight:800;
  padding:6px 0 0;
  cursor:pointer;
}

.card-tags-toggle:hover{
  text-decoration:underline;
}

.card-tags-toggle[hidden]{
  display:none;
}

.detail-link{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:42px;
  margin-top:auto;
  padding:10px 14px;
  border-radius:12px;
  background:#eeeef4;
  color:var(--primary);
  text-decoration:none;
  font-size:13px;
  font-weight:800;
}

.detail-link:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 22px rgba(94,113,228,.25);
}

.card-tags-wrap + .detail-link{
  margin-top:12px;
}

.card-grid.is-list .character-card{
  display:grid;
}

.card-grid.is-list .character-card .card-body{
  min-height:100%;
}

/* ===== Card tag groups: meta line + collapsible category line ===== */
.card-tags-wrap{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:8px;
  margin-bottom:12px;
}

.card-gender-tags,
.card-work-tags,
.card-main-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.card-main-tags{
  overflow:visible;
}

.card-main-tags.is-collapsed{
  max-height:30px;
  overflow:hidden;
}

.card-main-tags-wrap{
  min-width:0;
}

.character-card .card-body{
  display:flex;
  flex-direction:column;
  flex:1;
  min-height:0;
}

.character-card .detail-link,
.card-tags-wrap + .detail-link{
  margin-top:auto;
}

.card-tags-toggle{
  align-self:flex-start;
}


/* ===== Mobile search drawer ===== */
.mobile-search-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  color:var(--primary);
  font-size:18px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(30,56,120,.08);
}



.mobile-search-toggle img{
  display:block;
  width:22px;
  height:22px;
  object-fit:contain;
}

.mobile-search-backdrop{
  position:fixed;
  inset:0;
  z-index:40;
  background:rgba(12,27,77,.32);
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
}

.mobile-search-backdrop.is-open{
  opacity:1;
  pointer-events:auto;
}

.search-panel-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.search-panel-head h2{
  margin:0;
}

.mobile-search-close{
  display:none;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  color:var(--primary);
  font-size:22px;
  line-height:1;
  font-weight:900;
  cursor:pointer;
}

@media (max-width: 760px){
  .site-header{
    gap:10px;
  }

  .brand{
    min-width:0;
  }

  .brand span:last-child{
    min-width:0;
  }

  .brand strong{
    display:block;
    max-width:58vw;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }

  .mobile-search-toggle{
    display:flex;
    flex:0 0 auto;
  }

  .content-layout{
    display:block;
  }

  .content-layout .side-column{
    position:fixed;
    top:0;
    right:0;
    z-index:50;
    width:min(70vw, 360px);
    max-width:calc(100vw - 44px);
    height:100dvh;
    padding:14px;
    overflow-y:auto;
    background:var(--bg);
    transform:translateX(105%);
    transition:transform .24s ease;
    box-shadow:-16px 0 32px rgba(12,27,77,.18);
  }

  .content-layout .side-column.is-open{
    transform:translateX(0);
  }

  .content-layout .side-column .search-panel{
    min-height:100%;
    margin:0;
  }

  .mobile-search-close{
    display:flex;
    flex:0 0 auto;
  }

  body.mobile-search-open{
    overflow:hidden;
  }

  .detail-link{
    min-height:38px;
    padding:9px 10px;
    font-size:12px;
    white-space:nowrap;
    letter-spacing:-.02em;
  }
}

@media (max-width: 420px){
  .content-layout .side-column{
    width:74vw;
    max-width:calc(100vw - 32px);
    padding:12px;
  }

  .detail-link{
    font-size:11px;
  }
}


/* ===== Mobile search drawer layout fix ===== */
@media (max-width: 760px){
  .content-layout .side-column{
    background:#fff;
  }

  .content-layout .side-column .search-panel{
    min-height:auto;
    padding:0;
    background:transparent;
    border:0;
    border-radius:0;
    box-shadow:none;
  }

  .search-panel-head{
    position:sticky;
    top:0;
    z-index:2;
    padding:2px 0 12px;
    margin-bottom:12px;
    background:#fff;
    border-bottom:1px solid var(--line);
  }

  .search-panel-head h2{
    margin:0;
    padding-right:8px;
    font-size:18px;
    line-height:1.35;
  }

  .mobile-search-close{
    position:static;
    flex:0 0 36px;
  }

  .side-search-box{
    display:flex;
    width:100%;
    max-width:none;
    margin:0 0 16px;
  }

  .side-search-box input{
    width:100%;
    min-width:0;
  }

  .side-kana-block,
  .tag-filter-groups{
    padding:0;
    margin:0;
    background:transparent;
    border:0;
    box-shadow:none;
  }

  .tag-filter-group{
    padding-top:14px;
  }
}

/* ===== Fix: tag filter more button matches card tag toggle ===== */
.tag-filter-more-btn{
  appearance:none;
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  min-height:auto;
  margin:8px 0 0;
  padding:6px 0 0;
  border:0;
  border-radius:0;
  background:transparent;
  color:var(--primary);
  font-size:12px;
  font-weight:800;
  line-height:1.4;
  box-shadow:none;
  cursor:pointer;
}

.tag-filter-more-btn:hover{
  background:transparent;
  text-decoration:underline;
  transform:none;
}

/* ===== Fix: use search drawer whenever right column drops below main column ===== */
@media (max-width: 980px){
  .site-header{
    gap:10px;
  }

  .brand{
    min-width:0;
  }

  .brand span:last-child{
    min-width:0;
  }

  .brand strong{
    display:block;
    max-width:58vw;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }

  .mobile-search-toggle{
    display:flex;
    flex:0 0 auto;
  }

  .content-layout{
    display:block;
  }

  .content-layout .side-column{
    position:fixed;
    top:0;
    right:0;
    z-index:50;
    width:min(70vw, 360px);
    max-width:calc(100vw - 44px);
    height:100dvh;
    padding:14px;
    overflow-y:auto;
    background:#fff;
    transform:translateX(105%);
    transition:transform .24s ease;
    box-shadow:-16px 0 32px rgba(12,27,77,.18);
  }

  .content-layout .side-column.is-open{
    transform:translateX(0);
  }

  .content-layout .side-column .search-panel{
    min-height:auto;
    margin:0;
    padding:0;
    background:transparent;
    border:0;
    border-radius:0;
    box-shadow:none;
  }

  .search-panel-head{
    position:sticky;
    top:0;
    z-index:2;
    padding:2px 0 12px;
    margin-bottom:12px;
    background:#fff;
    border-bottom:1px solid var(--line);
  }

  .mobile-search-close{
    display:flex;
    flex:0 0 36px;
  }

  .side-search-box{
    display:flex;
    width:100%;
    max-width:none;
    margin:0 0 16px;
  }

  .side-search-box input{
    width:100%;
    min-width:0;
  }

  .side-kana-block,
  .tag-filter-groups{
    padding:0;
    margin:0;
    background:transparent;
    border:0;
    box-shadow:none;
  }

  body.mobile-search-open{
    overflow:hidden;
  }
}

@media (max-width: 420px){
  .content-layout .side-column{
    width:74vw;
    max-width:calc(100vw - 32px);
    padding:12px;
  }
}


/* ===== Fix random gacha card layout and single fallback icon ===== */
.random-result{
  display:flex;
  justify-content:center;
}

.random-card.character-card{
  display:grid;
  grid-template-columns:minmax(220px, 280px) minmax(0, 1fr);
  align-items:stretch;
  width:100%;
  max-width:860px;
  min-height:280px;
}

.random-card.character-card > img{
  width:100%;
  height:100%;
  min-height:280px;
  aspect-ratio:1 / 1;
  object-fit:cover;
  align-self:stretch;
}

.random-card.character-card .card-body{
  min-width:0;
  padding:24px;
}

.random-card.character-card .detail-link{
  margin-top:auto;
}

@media (max-width: 640px){
  .random-card.character-card{
    display:flex;
    flex-direction:column;
    max-width:100%;
    min-height:0;
  }

  .random-card.character-card > img{
    width:100%;
    height:auto;
    min-height:0;
    aspect-ratio:1 / 1;
  }

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