@charset "utf-8";

.koma-youtu {
	max-width: 100%;
	width: 420px; /* 초기 로딩 너비 */
	margin: 0 auto;
	background: #000;
	position: relative;
	font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	user-select: none;
	transition: width 0.5s ease-in-out; /* 커지는 애니메이션 유지 */
}

.uni-player-wrapper {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	background: #000;
	overflow: hidden;
}

/* MP4 전용 래퍼 스타일 */
.uni-player-wrapper.mp4-wrapper {
	padding-top: 0;
	height: auto;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* 데스크톱: 높이 기준 */
@media (min-width: 769px) {
	.uni-player-wrapper.mp4-wrapper {
		max-height: 80vh;
	}
}

/* 모바일: 너비 기준 */
@media (max-width: 768px) {
	.uni-player-wrapper.mp4-wrapper {
		max-width: 90vw;
	}
}

.uni-player-content {
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 100%;
	pointer-events: none;
	z-index: 1;
}

/* MP4 전용 콘텐츠 스타일 */
.mp4-wrapper .uni-player-content {
	position: relative;
	width: 100%;
	height: 100%;
}

.uni-player-content iframe {
	position: absolute;
	top: -60px;
	left: 0;
	width: 100%;
	height: calc(100% + 60px);
	border: 0;
}

.uni-player-content video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

/* MP4 비디오 스타일 */
.mp4-wrapper .uni-player-content video {
	position: relative;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

/* 중앙 플레이 버튼 */
/* 중앙 플레이 버튼 */
.center-play-btn {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 80px;
	height: 80px;
	background: rgba(255, 0, 0, 0.5); /* 0.9 → 0.7로 변경 (더 투명하게) */
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 0.3s ease, transform 0.2s ease;
	pointer-events: none;
}

.center-play-btn svg {
	width: 40px;
	height: 40px;
	fill: #fff;
}

/* 일시정지 상태일 때만 중앙 플레이 버튼 표시 */
.uni-player-wrapper.paused .center-play-btn {
	opacity: 1;
}

.center-play-btn:active {
	transform: translate(-50%, -50%) scale(0.95);
}

.custom-controls {
	position: absolute;
	bottom: 0; left: 0; right: 0;
	background: linear-gradient(transparent, rgba(0,0,0,0.85));
	padding: 15px;
	opacity: 0;
	transition: opacity 0.3s ease;
	z-index: 10;
}

/* 데스크톱: hover로 컨트롤 표시 */
@media (min-width: 769px) {
	.uni-player-wrapper:hover .custom-controls {
		opacity: 1;
	}
}

/* 일시정지 상태일 때 항상 컨트롤 표시 */
.uni-player-wrapper.paused .custom-controls { 
	opacity: 1; 
}

/* 모바일: show-controls 클래스로만 컨트롤 표시 */
.uni-player-wrapper.show-controls .custom-controls {
	opacity: 1;
}

.progress-area {
	position: relative;
	width: 100%;
	height: 4px;
	background: rgba(255,255,255,0.25);
	margin-bottom: 7px;
	cursor: pointer;
	border-radius: 2px;
	transition: height 0.1s;
}

.progress-area:hover {
	height: 6px;
}
    
.progress-filled {
	height: 100%;
	background: #f00;
	width: 0%;
	position: relative;
	border-radius: 2px;
}
    
.progress-handle {
	width: 13px;
	height: 13px;
	background: #f00;
	border-radius: 50%;
	position: absolute;
	right: -6.5px;
	top: 50%;
	transform: translateY(-50%);
	box-shadow: 0 0 4px rgba(0,0,0,0.6);
}

.time-tooltip {
	position: absolute;
	top: -35px;
	background: rgba(0,0,0,0.8);
	color: #fff;
	padding: 4px 10px;
	border-radius: 4px;
	font-size: 12px;
	display: none;
	transform: translateX(-50%);
	pointer-events: none;
	white-space: nowrap;
}

.progress-area:hover .time-tooltip {
	display: block;
}

.control-buttons {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.left-controls, .right-controls {
	display: flex;
	align-items: center;
	gap: 15px;
}

.control-buttons button {
	background: none;
	border: none;
	cursor: pointer;
	padding: 2px;
	display: flex;
	align-items: center;
	transition: transform 0.1s;
}

.control-buttons button:active {
	transform: scale(0.9);
}

.control-buttons button svg {
	width: 28px;
	height: 28px;
	fill: #fff;
}

.control-buttons button:hover svg {
	fill: #f00;
}

.time-display {
	color: #fff;
	font-size: 13px;
	letter-spacing: 0.5px;
}

.volume-control {
	display: flex;
	align-items: center;
	gap: 8px;
}

.volume-range {
	width: 65px;
	cursor: pointer;
	accent-color: #f00;
	height: 3px;
}

@media (max-width: 768px) {
	.volume-range {
		display: none;
	}

	.control-buttons button svg {
		width: 20px;
		height: 20px;
		fill: #fff;
	}

	.center-play-btn {
		width: 40px;
		height: 40px;
	}

	.center-play-btn svg {
		width: 20px;
		height: 20px;
	}
}

.koma-youtu:fullscreen .uni-player-wrapper { padding-top: 0; height: 100vh; }

/* 유튜브 Iframe 자체는 클릭이 안 되게 막음 */
.uni-player-content iframe {
    pointer-events: none;
}

/* 감싸고 있는 래퍼와 오버레이는 클릭이 되게 설정 */
.uni-player-content-wrapper {
    position: relative;
    overflow: hidden;
}

.video-overlay {
    background: rgba(0,0,0,0); /* 완전 투명 */
}
