/* saoari.com — 共通スタイル（ダーク・プレミアム / モバイルファースト） */
:root{
  --bg:#0d0b14; --bg2:#100d1a; --surface:#181421; --surface2:#211b30;
  --line:#2c2540; --text:#f5f3fa; --muted:#a49fb8; --muted2:#776f90;
  --accent:#ff2d78; --accent2:#8b5cf6; --gold:#ffcf5c;
  --r:14px; --maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--bg);color:var(--text);
  font-family:"Noto Sans JP",system-ui,-apple-system,"Segoe UI",sans-serif;
  line-height:1.6;overflow-x:hidden;padding-bottom:env(safe-area-inset-bottom);
  -webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;
}
/* 入力欄は選択・編集できるよう除外 */
input,textarea,select,[contenteditable="true"]{-webkit-user-select:text;-moz-user-select:text;user-select:text}
/* 名前・読み・別名はコピーできるよう選択を許可（コピペ用） */
.a-name,.a-sub,.a-alias,.card-name,.card-kana{-webkit-user-select:text;-moz-user-select:text;user-select:text;cursor:text}
/* 画像のドラッグ・長押し保存を抑止（クリック/タップは維持） */
img{-webkit-user-drag:none;-khtml-user-drag:none;user-drag:none;-webkit-touch-callout:none}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ===== 年齢ゲート ===== */
.agegate{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 100% at 50% 0%,#1a1228 0%,#070510 70%);padding:24px}
.agegate.is-hidden{display:none}
.ag-card{max-width:380px;width:100%;text-align:center;background:var(--surface);
  border:1px solid var(--line);border-radius:20px;padding:34px 26px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.ag-logo{font-weight:900;font-size:1.5rem;letter-spacing:.02em;margin-bottom:6px}
.ag-logo .m{display:inline-grid;place-items:center;width:1.5em;height:1.5em;background:var(--accent);
  color:#fff;border-radius:8px;margin-right:.35em;font-size:.85em;vertical-align:-.2em}
.ag-sub{color:var(--muted);font-size:.82rem;margin-bottom:20px}
.ag-q{font-size:1.15rem;font-weight:700;margin:18px 0 6px}
.ag-note{color:var(--muted2);font-size:.74rem;margin-bottom:22px}
.ag-btns{display:flex;flex-direction:column;gap:10px}
.ag-yes{background:linear-gradient(135deg,var(--accent),#ff5e9c);color:#fff;font-weight:700;
  border:none;border-radius:12px;padding:15px;font-size:1rem;cursor:pointer}
.ag-no{background:transparent;color:var(--muted);border:1px solid var(--line);border-radius:12px;padding:13px;cursor:pointer;font-size:.9rem}

/* ===== ヘッダー ===== */
.site-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:12px 16px;background:rgba(13,11,20,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.brand{font-weight:900;font-size:1.22rem;letter-spacing:.01em;display:flex;align-items:center;gap:.1em}
.brand-mark{display:grid;place-items:center;width:1.5em;height:1.5em;background:var(--accent);color:#fff;
  border-radius:8px;font-size:.7em;margin-right:.35em}
.brand-tld{color:var(--accent)}
.back{color:var(--muted);font-size:.82rem;white-space:nowrap}
.back:hover{color:var(--text)}
#count-badge{font-size:.72rem;white-space:nowrap;flex:0 0 auto}
.site-nav{display:flex;gap:4px;margin-left:auto;margin-right:4px}
.site-nav a{color:var(--muted);text-decoration:none;font-weight:700;font-size:.82rem;padding:6px 11px;border-radius:999px;white-space:nowrap}
.site-nav a.on,.site-nav a:hover{color:#fff;background:rgba(255,45,120,.16)}

/* ===== 共通 ===== */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px}
.chip{display:inline-flex;align-items:center;gap:.25em;font-size:.72rem;font-weight:600;line-height:1;
  padding:.42em .7em;border-radius:999px;background:var(--surface2);color:var(--muted);border:1px solid var(--line)}
.chip-sao.on{background:rgba(255,45,120,.16);color:#ff8ab6;border-color:rgba(255,45,120,.4)}
.chip-sao.off{background:rgba(139,92,246,.16);color:#c4b5fd;border-color:rgba(139,92,246,.4)}
.chip-shop{background:rgba(255,207,92,.15);color:var(--gold);border-color:rgba(255,207,92,.4)}
.chip-count{background:transparent}

/* ===== フッター ===== */
.site-footer{margin-top:40px;padding:28px 16px;border-top:1px solid var(--line);text-align:center;color:var(--muted2);font-size:.76rem}
.site-footer p+p{margin-top:6px}
.age-disclaimer{color:var(--muted2)}
.footer-links{margin-top:8px}
.footer-links a{color:var(--muted)}
.ws-credit{margin-top:10px}
.ws-credit img{margin:0 auto}
.fz-disclaimer{font-size:.68rem;color:var(--muted2);line-height:1.7;max-width:560px;margin:6px auto 0}

/* ===== 上部に戻る ===== */
.to-top{position:fixed;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));z-index:80;width:46px;height:46px;
  border-radius:50%;border:1px solid var(--line);background:var(--surface);color:var(--text);font-size:1.1rem;
  cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s;display:grid;place-items:center}
.to-top.show{opacity:1;pointer-events:auto}

/* ===== トップ: ヒーロー ===== */
.hero{padding:20px 4px 12px}
.hero-title{font-size:1.4rem;font-weight:900;letter-spacing:.01em;line-height:1.3}
.hero-accent{color:var(--accent)}
.hero-sub{color:var(--muted);font-size:.78rem;margin-top:7px;line-height:1.6}
.hero-sub b{color:var(--text);font-weight:700}

/* ===== フィルタバー ===== */
.filterbar{position:sticky;top:57px;z-index:60;background:rgba(13,11,20,.9);backdrop-filter:blur(10px);
  padding:10px 0 12px;margin:0 -16px;padding-left:16px;padding-right:16px;border-bottom:1px solid var(--line)}
.search{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:12px;color:var(--text);
  padding:12px 14px;font-size:.95rem;font-family:inherit;outline:none}
.search:focus{border-color:var(--accent)}
.search::placeholder{color:var(--muted2)}
.fchips{display:flex;gap:8px;overflow-x:auto;margin-top:10px;padding-bottom:2px;-webkit-overflow-scrolling:touch}
.fchip{flex:0 0 auto;background:var(--surface);border:1px solid var(--line);color:var(--muted);font-family:inherit;
  font-size:.82rem;font-weight:600;padding:8px 14px;border-radius:999px;cursor:pointer;white-space:nowrap}
.fchip.is-on{background:var(--accent);border-color:var(--accent);color:#fff}

/* スマホはトップの文字をさらに小さく＋右上カウントの縦折れ防止 */
@media(max-width:600px){
  .site-header{padding:10px 13px;gap:8px}
  .brand{font-size:1.05rem}
  .site-nav a{font-size:.78rem;padding:5px 9px}
  #count-badge{display:none}
  .hero{padding:16px 2px 10px}
  .hero-title{font-size:1.22rem}
  .hero-sub{font-size:.74rem}
  .fchip{font-size:.76rem;padding:7px 12px}
  .card-name{font-size:.8rem}
}

/* ===== カードグリッド ===== */
.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:16px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  transition:transform .12s,border-color .12s}
.card:active{transform:scale(.98)}
.card-thumb{position:relative;aspect-ratio:3/4;background:var(--surface2);overflow:hidden}
.card-thumb img{width:100%;height:100%;object-fit:cover}
.card-noimg{width:100%;height:100%;display:grid;place-items:center;font-size:2rem;color:var(--muted2);
  background:linear-gradient(135deg,var(--surface2),var(--surface))}
.card-count{position:absolute;left:8px;bottom:8px;background:rgba(0,0,0,.66);color:#fff;font-size:.7rem;
  font-weight:600;padding:.25em .55em;border-radius:6px;backdrop-filter:blur(4px)}

/* お気に入り★ボタン（カード/顔写真 右上） */
.fav-star{position:absolute;top:8px;right:8px;z-index:4;width:34px;height:34px;border-radius:50%;border:none;
  background:rgba(0,0,0,.42);color:rgba(255,255,255,.72);font-size:1.05rem;line-height:1;cursor:pointer;
  display:grid;place-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);transition:transform .12s,color .12s}
.fav-star:hover{transform:scale(1.14);color:#fff}
.fav-star:active{transform:scale(.9)}
.fav-star.on{color:var(--gold);text-shadow:0 0 9px rgba(255,207,92,.85)}
.fchip-fav.is-on{background:var(--gold);border-color:var(--gold);color:#3a2c00}
.card-body{padding:9px 10px 11px}
.card-name{font-weight:700;font-size:.84rem;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card-kana{color:var(--muted2);font-size:.68rem;margin-top:1px}
.card-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.mini-chip{font-size:.66rem;font-weight:700;padding:.28em .55em;border-radius:6px;line-height:1}
.mini-chip.sao{background:rgba(255,45,120,.16);color:#ff8ab6}
.mini-chip.nosao{background:rgba(139,92,246,.16);color:#c4b5fd}
.mini-chip.shop{background:rgba(255,207,92,.16);color:var(--gold)}

.more-wrap{text-align:center;margin:24px 0}
.more-btn{background:var(--surface2);border:1px solid var(--line);color:var(--text);font-family:inherit;
  font-weight:700;padding:13px 40px;border-radius:12px;cursor:pointer;font-size:.92rem}
.more-btn:hover{border-color:var(--accent)}
.empty{text-align:center;color:var(--muted);padding:40px 0}
#count-badge{font-variant-numeric:tabular-nums}

@media(min-width:560px){.card-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:820px){.card-grid{grid-template-columns:repeat(4,1fr);gap:16px}.hero-title{font-size:2.2rem}.filterbar{top:57px}}
@media(min-width:1100px){.card-grid{grid-template-columns:repeat(5,1fr)}}

/* ===== お気に入り動画 連続再生 (play.html) ===== */
.play-wrap{padding-top:18px;padding-bottom:40px}
.play-h1{font-size:1.3rem;font-weight:900;margin-bottom:16px}
.play-h1-sub{color:var(--accent)}
.play-empty{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:34px 20px;text-align:center;color:var(--muted)}
.play-empty-note{font-size:.82rem;margin-top:10px;line-height:1.6}
.play-empty-note b{color:#ff8ab6}
.play-empty-link{display:inline-block;margin-top:18px;background:var(--accent);color:#fff;font-weight:700;padding:10px 24px;border-radius:10px;text-decoration:none}
.player{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px;margin-bottom:24px}
.pv-wrap{background:#000;border-radius:10px;overflow:hidden;line-height:0}
.pv{width:100%;height:auto;max-height:70vh;display:block}
.pv-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:11px}
.pv-btn{background:var(--surface2);border:1px solid var(--line);color:var(--text);font-weight:700;padding:9px 16px;border-radius:9px;cursor:pointer;font-family:inherit;white-space:nowrap}
.pv-btn:hover{border-color:var(--accent)}
.pv-now{text-align:center;min-width:0;flex:1}
.pv-idx{display:block;color:var(--accent);font-weight:800;font-size:.78rem}
.pv-name{color:var(--muted);font-size:.82rem}
.pv-title{font-size:.86rem;font-weight:700;margin-top:11px;line-height:1.5}
.pv-cta{display:block;text-align:center;background:linear-gradient(135deg,var(--accent),#ff5e9c);color:#fff;font-weight:800;padding:12px;border-radius:11px;text-decoration:none;margin-top:12px}
.pv-loop{display:flex;align-items:center;gap:7px;justify-content:center;color:var(--muted);font-size:.78rem;margin-top:11px;cursor:pointer}
.pl-head{font-size:1rem;font-weight:800;margin-bottom:12px}
.pl-count{color:var(--muted);font-size:.8rem;font-weight:600}
.playlist{display:flex;flex-direction:column;gap:8px}
.pl-item{display:flex;align-items:center;gap:11px;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:8px;cursor:pointer}
.pl-item.on{border-color:var(--accent);background:rgba(255,45,120,.08)}
.pl-item:hover{border-color:var(--accent)}
.pl-thumb{position:relative;flex:0 0 96px;width:96px;aspect-ratio:16/10;border-radius:7px;overflow:hidden;background:#000}
.pl-thumb img{width:100%;height:100%;object-fit:cover}
.pl-playing{position:absolute;left:4px;bottom:4px;background:var(--accent);color:#fff;font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:5px}
.pl-meta{flex:1;min-width:0}
.pl-t{font-size:.82rem;font-weight:700;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pl-a{font-size:.72rem;color:var(--muted);margin-top:2px}
.pl-x{flex:0 0 auto;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;font-size:.8rem}
.pl-x:hover{color:#ff5d5d;border-color:#ff5d5d}
.nav-heart{color:var(--accent)!important}
