:root{
  --bg:#f6f7fb;          /* メイン背景：白寄り */
  --surface:#ffffff;     /* カード背景 */
  --text:#111827;        /* 文字：濃いグレー */
  --muted:#6b7280;       /* 補助文字 */
  --border:rgba(17,24,39,.12);

  --header:#0b1020;      /* ヘッダーは暗め */
  --headerText:#e9ecf5;

  --accent:#2563eb;      /* 青 */
  --accent2:#16a34a;     /* 緑 */

  /* 角丸は控えめ */
  --radius-card:6px;
  --radius-btn:6px;
  --radius-input:6px;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", sans-serif;
  color:var(--text);
  background: var(--bg);
  min-height:100vh;
}
a{color:inherit; text-decoration:none}

.wrap{max-width:1100px; margin:0 auto; padding:24px}

/* ---- header (full width, dark, no rounded) ---- */
.headerbar{
  width:100%;
  background:
    radial-gradient(900px 300px at 20% 0%, rgba(37,99,235,.35), transparent 60%),
    radial-gradient(700px 260px at 80% 0%, rgba(22,163,74,.25), transparent 55%),
    var(--header);
  color: var(--headerText);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}
.headerinner{
  max-width:1100px;
  margin:0 auto;
  padding:14px 24px;
}

header{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
  padding:0;
  border-radius:0;        /* 角丸なし */
  background: transparent;
  box-shadow:none;
  color: inherit;
}

.menu-vertical{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.menu-vertical a{
  display:block;
  width:100%;
  text-align:left; /* 中央寄せが良ければ center に */
}

.brand{display:flex; align-items:center; gap:12px; font-weight:800; letter-spacing:.5px}
.logo{
  width:40px; height:40px; border-radius:10px;
  background: linear-gradient(135deg, rgba(37,99,235,1), rgba(22,163,74,1));
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
nav{display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end}

/* ---- buttons (header) ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px;
  border-radius: var(--radius-btn);
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: var(--headerText);
  transition:.15s ease;
  font-weight:700;
}
.btn:hover{transform: translateY(-1px); background: rgba(255,255,255,.12)}
.btn.primary{
  border-color: rgba(37,99,235,.55);
  background: rgba(37,99,235,.22);
}
.btn.green{
  border-color: rgba(22,163,74,.55);
  background: rgba(22,163,74,.18);
}

/* ---- buttons (light area) ---- */
.btn-light{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px;
  border-radius: var(--radius-btn);
  border:1px solid var(--border);
  background:#fff;
  color: var(--text);
  font-weight:700;
  transition:.15s ease;
}
.btn-light:hover{transform: translateY(-1px); background: rgba(17,24,39,.02)}
.btn-light.primary{
  border-color: rgba(37,99,235,.35);
  color:#1d4ed8;
}
.btn-light.green{
  border-color: rgba(22,163,74,.35);
  color:#166534;
}

/* ---- layout ---- */
.hero{
  grid-template-columns: 1.2fr .8fr;
  gap:18px;
  align-items:stretch;
  margin-top:18px;
}
@media (max-width: 860px){
  .hero{grid-template-columns:1fr}
  nav{justify-content:flex-start}
}

/* ---- cards (light) ---- */
.card{
  background: var(--surface);
  border:1px solid var(--border);
  border-radius: var(--radius-card);
  padding:18px;
  box-shadow: 0 10px 30px rgba(17,24,39,.06);
}

.pillrow{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px}
.pill{
  padding:8px 10px; border-radius:999px;
  border:1px solid var(--border);
  color:var(--muted);
  background: rgba(17,24,39,.02);
  font-size:13px;
}

.title{font-size:40px; line-height:1.1; margin:6px 0 10px; letter-spacing:.2px}
.lead{color:var(--muted); font-size:16px; line-height:1.7; margin:0 0 16px}

.searchbox{display:flex; gap:10px; margin-top:14px}
.searchbox input{
  flex:1;
  padding:12px 14px;
  border-radius: var(--radius-input);
  border:1px solid var(--border);
  background: #fff;
  color:var(--text);
  outline:none;
}
.searchbox input::placeholder{color: rgba(17,24,39,.45)}

.grid2{display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:12px}
@media (max-width: 520px){ .grid2{grid-template-columns:1fr} }

.mini{color:var(--muted); font-size:13px; line-height:1.6; margin:0}

footer{color:rgba(17,24,39,.45); font-size:12px; padding:18px 0 6px}

/* ---- forms ---- */
.form{display:grid; gap:12px; margin-top:10px}
.field label{display:block; font-size:13px; color:var(--muted); margin:0 0 6px}
.field input, .field select, .field textarea{
  width:100%;
  padding:12px 14px;
  border-radius: var(--radius-input);
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  outline:none;
  font-size: 16px;
}
.field textarea{min-height:110px; resize:vertical}

.alert{
  padding:10px 12px;
  border-radius: var(--radius-card);
  border:1px solid rgba(220,38,38,.25);
  background: rgba(220,38,38,.06);
  color: var(--text);
}
.subnav{margin-top:12px; color: var(--muted); font-size: 13px}
.subnav a{ text-decoration: underline; text-underline-offset: 3px; }

/* ---- small badges for status ---- */
.badge{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  border:1px solid var(--border);
  background: rgba(17,24,39,.02);
  color: var(--muted);
}
.badge.watched{border-color: rgba(22,163,74,.25); background: rgba(22,163,74,.08); color:#166534;}
.badge.watching{border-color: rgba(37,99,235,.25); background: rgba(37,99,235,.08); color:#1d4ed8;}
.badge.watchlist{border-color: rgba(245,158,11,.25); background: rgba(245,158,11,.10); color:#92400e;}

.brand img{
  width: 50px;
}

/* --- Mobile bottom nav --- */
.mobile-nav {
  display: none;
}

@media (max-width: 768px) {
  .mobile-nav {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;

    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;

    background: #fff;
    border-top: 1px solid rgba(0,0,0,.08);
    padding: 8px 6px calc(8px + env(safe-area-inset-bottom));
  }

  .mobile-nav__item {
    text-decoration: none;
    color: rgba(17,24,39,.75);
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 4px;
    padding: 6px 0;
  }

  .mobile-nav__icon {
    font-size: 20px;
    line-height: 1;
  }

  .mobile-nav__label {
    font-size: 11px;
    line-height: 1;
  }

  .mobile-nav__item.is-active {
    color: rgba(17,24,39,1);
    font-weight: 600;
  }

  /* 下ナビに本文が隠れないように余白を足す */
  body {
    padding-bottom: 72px;
  }
}

@media (max-width: 768px) {
  .header-nav {
    display: none !important;
  }
}

/* =========================================================
   show.php（作品詳細）用：show側にCSSを書かない前提の追加分
   ========================================================= */

/* 画像上の「検索へ戻る」 */
.film-backlink{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 10px;
  border-radius:999px;
  background: rgba(17,24,39,.55);
  color: rgba(255,255,255,.95);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  font-size:12px;
}
.film-backlink:hover{ background: rgba(17,24,39,.68); }

/* タイトル下の評価（表示専用）：必ず5個、未評価はグレー塗り、評価分は黄色塗り＋枠黄色
   ※透明化される競合を潰すため !important を付ける */
.film-stars{
  display:inline-flex;
  gap:4px;
  align-items:center;
}
.film-stars .star{
  font-size:18px;
  line-height:1;
  color:#9ca3af !important;          /* 未評価：グレー塗りつぶし */
  opacity:1 !important;
  -webkit-text-stroke:0 !important;
}
.film-stars .star.on{
  color:#f5c542 !important;          /* 評価あり：黄色塗りつぶし */
  -webkit-text-stroke:1px #f5c542 !important; /* 枠線も黄色 */
}

/* 登録状態（評価の右に置く想定） */
.film-save-state{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background: rgba(17,24,39,.02);
  color: var(--muted);
  font-size:12px;
  white-space:nowrap;
}

/* エピソード見出し */
.episode-title{
  font-weight:800;
}

/* エピソード1件 */
.episode-item{
  padding:14px 6px;
  border-top:1px solid var(--border);
}
.episode-item:first-child{ border-top:1px solid var(--border); }

/* エピソードと評価の間の区域分け（グレー横線） */
.episode-divider{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(17,24,39,.18);
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  align-items:flex-start;
}

/* 評価入力の星（ボタン） */
.stars-input{
  display:inline-flex;
  gap:6px;
  align-items:center;
}
.stars-input .starbtn{
  appearance:none;
  border:0;
  background:transparent;
  cursor:pointer;
  font-size:22px;
  line-height:1;
  padding:2px 2px;

  /* 未評価：グレー塗り */
  color:#9ca3af;
}
.stars-input .starbtn.on{
  color:#f5c542;
}

/* 「評価を消す」 */
.rating-clear{
  font-size:12px;
  color: var(--muted);
  text-decoration: underline;
  text-underline-offset: 3px;
  background:transparent;
  border:0;
  cursor:pointer;
  padding:0;
  margin-left:10px;
}
.rating-clear:hover{ color: var(--text); }

/* 視聴日 input（黒文字） */
.watch-date{
  height:36px;
  padding:0 10px;
  border-radius: var(--radius-input);
  border:1px solid var(--border);
  background:#fff;
  color: var(--text);
  min-width: 180px;
  outline:none;
}

/* 保存ボタン（小さめ） */
.watch-save{
  height:36px;
  padding:0 14px;
  border-radius: var(--radius-btn);
  border:1px solid rgba(37,99,235,.25);
  background: rgba(37,99,235,.08);
  color:#1d4ed8;
  font-weight:700;
  cursor:pointer;
}
.watch-save:hover{ background: rgba(37,99,235,.12); }
.watch-save:disabled{ opacity:.6; cursor:default; }

/* 視聴履歴テーブル（枠線なし、ヘッダなし） */
.watch-table{
  margin-top:10px;
  border-collapse: collapse;
  width: 100%;
  max-width: 360px;
}
.watch-table td{
  padding:4px 0;
  font-size:12px;
  color: var(--muted);
  vertical-align: top;
}
.watch-table td:last-child{
  text-align:right;
  color: rgba(17,24,39,.75);
  white-space: nowrap;
}

/* ===== Layout normalize (PC/スマホ両方で幅を揃える) ===== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

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

/* 全ページ共通のコンテンツ幅 */
.wrap {
  width: 100%;
  max-width: 1100px;          /* ここが基準幅（好みで 1000〜1200） */
  margin: 0 auto;
  padding-left: 16px;
  padding-right: 16px;
}

/* PCでは少し余白を増やす */
@media (min-width: 900px) {
  .wrap {
    padding-left: 24px;
    padding-right: 24px;
  }
}

/* セクションが勝手に広がったり縮んだりしないように */
.hero,
section {
  width: 100%;
}

/* カードが横に伸びすぎたり、内容で幅が変わるのを抑える */
.card {
  width: 100%;
  min-width: 0;
  margin-top: 15px;
}

/* よくある「長い英数字」でレイアウトが押し広げられる問題を防ぐ */
.card,
.hero,
.wrap {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* TOPでカード一覧がある場合の“安定する”グリッド */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

@media (max-width: 480px) {
  .grid {
    grid-template-columns: 1fr; /* スマホは1列で安定 */
  }
}

/* iOS Safariの入力時ズーム防止（16px未満だと拡大される） */
input, textarea, select {
  font-size: 16px;
  line-height: 1.4;
}

/* ついでにタップしやすく */
input, textarea, select, button {
  min-height: 44px;
}
textarea {
  min-height: 140px;
}