/*
Theme Name: BBS WIFE FINAL STABLE
*/

/* =========================
   カラー
========================= */

:root{
--bg:#0f0f10;
--text:#e5e5e5;
--border:#333;
--meta:#aaa;
--accent:#ffffff;
--pink:#ff4fa3;
}

/* =========================
   リセット
========================= */

*,
*::before,
*::after{
box-sizing:border-box;
margin:0;
padding:0;
-webkit-tap-highlight-color:transparent;
}

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

body{
font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
background:var(--bg);
color:var(--text);
line-height:1.6;
}

/* =========================
   共通
========================= */

a{color:#fff;text-decoration:none;}

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

video{
display:block;
width:100%;
height:auto;
background:#000;
}

/* =========================
   レイアウト
========================= */

.container{
max-width:1200px;
margin:auto;
padding:20px 16px;
}

/* =========================
   HEADER
========================= */

.site-header{
position:sticky;
top:0;
z-index:100;
background:rgba(0,0,0,0.85);
backdrop-filter:blur(6px);
border-bottom:1px solid #222;
margin-bottom:20px;
}

.header-inner{
padding:16px 12px;
}

.site-title{
font-size:26px;
font-weight:600;
}

.main-nav{
margin-top:10px;
display:flex;
gap:14px;
font-size:14px;
}

.main-nav a:hover{
color:var(--pink) !important;
}

.main-nav .login-status{
color:#facc15 !important;
font-weight:600;
}

/* =========================
   GRID
========================= */

.video-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:14px;
}

@media(min-width:768px){
.video-grid{
grid-template-columns:repeat(3,1fr);
}
}

/* =========================
   カード
========================= */

.video-item{
background:#18181b;
border-radius:8px;
overflow:hidden;
transition:0.2s;
box-shadow:0 4px 12px rgba(0,0,0,0.5);
}

/* =========================
   THUMB
========================= */

.thumb{
position:relative;
aspect-ratio:16/9;
background:#000;
overflow:hidden;
}

.thumb img{
position:absolute;
inset:0;
width:100%;
height:100%;
object-fit:cover;
z-index:1;
}

/* ▶ 再生ボタン */

.play-icon{
position:absolute;
top:50%;
left:50%;
transform:translate(-50%, -50%);
width:52px;
height:52px;
border-radius:50%;
background:rgba(0,0,0,0.5);
display:flex;
align-items:center;
justify-content:center;
z-index:5;
}

.play-icon::before{
content:"";
border-left:14px solid #fff;
border-top:9px solid transparent;
border-bottom:9px solid transparent;
}

/* =========================
   メタ
========================= */

.video-meta{
position:absolute;
bottom:6px;
left:6px;
display:flex;
align-items:center;
gap:6px;
background:rgba(0,0,0,0.6);
color:#fff;
font-size:11px;
padding:3px 8px;
border-radius:999px;
z-index:10;
}

.video-duration{
position:absolute;
bottom:6px;
right:6px;
background:rgba(0,0,0,0.6);
color:#fff;
font-size:11px;
padding:3px 7px;
border-radius:999px;
z-index:10;
}

/* =========================
   タイトル
========================= */

.video-title{
padding:6px 10px 8px 12px;
font-size:14px;
color:#e5e5e5;
}

/* =========================
   フォーム
========================= */

input,
textarea{
width:100%;
padding:14px;
border-radius:12px;
background:#1a1a1a;
color:#fff;
border:1px solid rgba(255,255,255,0.2);
margin-bottom:14px;
font-size:16px;
transition:.2s;
}

input:focus,
textarea:focus{
outline:none;
border:2px solid var(--pink);
box-shadow:0 0 0 2px rgba(255,79,163,0.3);
}

.comment-form textarea,
.comment-form input{
background:rgba(255,255,255,0.05);
}

/* =========================
   ボタン（🔥修正版）
========================= */

button,
input[type="submit"]{
width:100%;
padding:14px;
border-radius:12px;
background:#1f1f23;
color:#fff;
border:1px solid rgba(255,255,255,0.15);
font-weight:600;
font-size:15px;
box-shadow:0 4px 14px rgba(0,0,0,0.6);
transition:.2s;
}

button:hover,
input[type="submit"]:hover{
background:#26262b;
}

button:active,
input[type="submit"]:active{
transform:scale(0.96);
border:1px solid var(--pink);
box-shadow:0 0 0 2px rgba(255,79,163,0.25);
}

button:focus,
input[type="submit"]:focus{
outline:none;
border:1px solid var(--pink);
}

/* =========================
   説明欄
========================= */

.video-description{
padding:10px;
border-radius:8px;
}

.video-description:active{
border:1px solid var(--pink);
box-shadow:0 0 0 2px rgba(255,79,163,0.3);
}

/* =========================
   フッター
========================= */

.site-footer{
text-align:center;
padding:24px;
color:#777;
}

/* =========================
   その他
========================= */

.title-accent{
background:linear-gradient(135deg,#ff4fa3,#ff6ec7);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
}

.ui-item{
display:flex;
flex-direction:column;
align-items:center;
color:#fff;
}

.ui-item svg{
width:32px;
height:32px;
}

.ui-item span{
font-size:12px;
margin-top:4px;
}

/* =========================
   Uploadページ対策
========================= */

body.page-template .container{
padding-top:20px !important;
}

body.page-template .site-header{
position:sticky !important;
top:0;
}

/* コメント入力欄を大きくする */
.comment-form textarea{
  width:100%;
  min-height:160px;   /* ←ここで高さ調整 */
  height:160px;
  padding:16px;
  font-size:16px;
  border-radius:16px;
}

/* 🎯 動画上の全テキストに強制影 */
video + *,
video ~ * {
  text-shadow: 0 2px 10px rgba(0,0,0,0.9) !important;
}

/* 🎯 右UI（アイコン系） */
.ui-item,
.ui-item * {
  text-shadow: 0 2px 10px rgba(0,0,0,0.9) !important;
}

/* 🎯 SVGアイコンも見やすく */
.ui-item svg {
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.8));
}