/* ==============================================
  Tosinso Professional Uploader Component Styles
  Version: 2.2.0 - Added cancel button styles and white text for preview overlay status
  ============================================== */

/* --- Main Wrapper --- */
.tosinso-uploader {
    width: 100%;
    font-family: 'PinarRegular', sans-serif;
    border-radius: var(--border-radius);
    background-color: var(--component-bg-color);
}

/* --- Drop Zone (Common Styles) --- */
.uploader-drop-zone {
    border: 2px dashed var(--medium-gray-color);
    border-radius: var(--border-radius);
    padding: 40px 20px;
    text-align: center;
    cursor: pointer;
    transition: background-color 0.3s, border-color 0.3s;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.uploader-drop-zone.is-dragover {
    border-color: var(--primary-color);
    background-color: #f0f6ff;
}

.uploader-drop-zone__icon {
    font-size: 48px;
    color: var(--primary-color);
    margin-bottom: 15px;
}

.uploader-drop-zone__text {
    font-size: 16px;
    color: var(--dark-gray-color);
    margin-bottom: 5px;
}

.uploader-drop-zone__text .browse-link {
    color: var(--primary-color);
    font-weight: 600;
}

.uploader-drop-zone__hint {
    font-size: 13px;
    color: var(--text-color-muted);
}

/* --- Hidden File Input --- */
.uploader-input {
    display: none;
}

/* ==============================================
   LIST DISPLAY MODE STYLES
   ============================================== */

/* --- File List --- */
.tosinso-uploader[data-mode="list"] .uploader-file-list {
    margin-top: 25px;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

/* --- Individual File Item --- */
.tosinso-uploader[data-mode="list"] .uploader-file-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    border: 1px solid var(--medium-gray-color);
    border-radius: var(--border-radius);
    transition: background-color 0.3s;
}

/* --- File Thumbnail/Icon --- */
.tosinso-uploader[data-mode="list"] .uploader-file-item__thumbnail {
    flex-shrink: 0;
    width: 50px;
    height: 50px;
    border-radius: 6px;
    background-color: var(--light-gray-color);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.tosinso-uploader[data-mode="list"] .uploader-file-item__thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tosinso-uploader[data-mode="list"] .uploader-file-item__thumbnail .file-icon {
    font-size: 24px;
    color: var(--dark-gray-color);
}

/* --- File Info & Progress --- */
.tosinso-uploader[data-mode="list"] .uploader-file-item__details {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0; /* Fix for text-overflow */
}

.tosinso-uploader[data-mode="list"] .uploader-file-item__name {
    font-size: 15px;
    font-weight: 600;
    color: var(--text-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.tosinso-uploader[data-mode="list"] .uploader-file-item__meta {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--text-color-muted);
}

.tosinso-uploader[data-mode="list"] .uploader-file-item__status {
    font-weight: 600;
}

/* --- Progress Bar --- */
.tosinso-uploader[data-mode="list"] .uploader-progress {
    height: 6px;
    background-color: var(--medium-gray-color);
    border-radius: 3px;
    overflow: hidden;
}

.tosinso-uploader[data-mode="list"] .uploader-progress__bar {
    width: 0;
    height: 100%;
    background-color: var(--primary-color);
    transition: width 0.3s ease;
}

/* --- File Actions --- */
.tosinso-uploader[data-mode="list"] .uploader-file-item__actions {
    flex-shrink: 0;
}

.tosinso-uploader[data-mode="list"] .uploader-file-item__actions button {
    background: none;
    border: none;
    cursor: pointer;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--dark-gray-color);
    font-size: 18px;
    transition: background-color 0.2s, color 0.2s;
}

.tosinso-uploader[data-mode="list"] .uploader-file-item__actions button:hover {
    background-color: var(--light-gray-color);
}

/* --- File Item States --- */
.tosinso-uploader[data-mode="list"] .uploader-file-item.is-success {
    background-color: #f0fff4;
    border-color: var(--success-color);
}
.tosinso-uploader[data-mode="list"] .uploader-file-item.is-success .uploader-file-item__status {
    color: var(--success-color);
}
.tosinso-uploader[data-mode="list"] .uploader-file-item.is-error {
    background-color: #fff1f2;
    border-color: var(--error-color);
}
.tosinso-uploader[data-mode="list"] .uploader-file-item.is-error .uploader-file-item__status {
    color: var(--error-color);
}
.tosinso-uploader[data-mode="list"] .uploader-file-item.is-error .remove-btn:hover {
    background-color: #ffe0e3;
    color: var(--error-color);
}

/* ==============================================
   PREVIEW DISPLAY MODE STYLES (NEW in v2.0.0)
   ============================================== */

.tosinso-uploader[data-mode="preview"] .uploader-preview-wrapper {
    position: relative;
    width: 100%;
    aspect-ratio: var(--aspect-ratio, 16 / 9);
    border-radius: var(--border-radius);
    overflow: hidden;
    background-color: var(--light-gray-color);
}

.tosinso-uploader[data-mode="preview"] .uploader-drop-zone {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
    transition: opacity 0.3s, visibility 0.3s;
}

.tosinso-uploader[data-mode="preview"] .uploader-preview-wrapper.has-file .uploader-drop-zone {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.tosinso-uploader[data-mode="preview"] .uploader-media-preview {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.tosinso-uploader[data-mode="preview"] .uploader-media-preview img,
.tosinso-uploader[data-mode="preview"] .uploader-media-preview video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tosinso-uploader[data-mode="preview"] .uploader-media-actions {
    position: absolute;
    top: 15px;
    right: 15px;
    z-index: 3;
    display: flex;
    gap: 10px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
}

.tosinso-uploader[data-mode="preview"] .uploader-preview-wrapper.has-file .uploader-media-actions {
    opacity: 1;
    visibility: visible;
}

.tosinso-uploader[data-mode="preview"] .uploader-media-actions .remove-btn {
    background-color: rgba(26, 32, 44, 0.6);
    border: none;
    cursor: pointer;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 18px;
    transition: background-color 0.2s;
}

.tosinso-uploader[data-mode="preview"] .uploader-media-actions .remove-btn:hover {
    background-color: rgba(26, 32, 44, 0.8);
}

.tosinso-uploader[data-mode="preview"] .uploader-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 5px;
    background-color: transparent;
    z-index: 4;
    opacity: 0;
    transition: opacity 0.3s;
}

.tosinso-uploader[data-mode="preview"] .uploader-preview-wrapper.is-uploading .uploader-progress {
    opacity: 1;
}

.tosinso-uploader[data-mode="preview"] .uploader-progress__bar {
    width: 0;
    height: 100%;
    background-color: var(--primary-color);
    transition: width 0.3s ease;
}

.tosinso-uploader[data-mode="preview"] .uploader-preview-wrapper.is-success .uploader-media-preview {
    outline: 3px solid var(--success-color);
    outline-offset: -3px;
}

.tosinso-uploader[data-mode="preview"] .uploader-preview-wrapper.is-error .uploader-media-preview {
    outline: 3px solid var(--error-color);
    outline-offset: -3px;
}

/* NEW: Preview Overlay for spinner/status */
.tosinso-uploader[data-mode="preview"] .uploader-preview-overlay {
    position: absolute;
    inset: 0; /* Covers the entire preview area */
    background-color: rgba(0, 0, 0, 0.6); /* Semi-transparent dark background */
    z-index: 5; /* Above media preview and actions */
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 15px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
}

.tosinso-uploader[data-mode="preview"] .uploader-preview-overlay.is-visible {
    opacity: 1;
    visibility: visible;
}

.tosinso-uploader[data-mode="preview"] .uploader-preview-overlay__spinner {
    display: none; /* Hidden by default, shown by JS */
    border-top-color: #fff; /* White spinner for dark background */
}

.tosinso-uploader[data-mode="preview"] .uploader-preview-overlay__message {
    color: #fff; /* White text */
    font-size: 1.1rem;
    font-weight: 600;
    text-align: center;
}

/* Status colors for the message - now white */
.tosinso-uploader[data-mode="preview"] .uploader-preview-overlay__message.is-success {
    color: #fff; /* Changed to white */
}

.tosinso-uploader[data-mode="preview"] .uploader-preview-overlay__message.is-error {
    color: #fff; /* Changed to white */
}

/* NEW: Styles for cancel button inside the overlay */
.tosinso-uploader[data-mode="preview"] .uploader-preview-overlay__actions {
    position: absolute;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
}

.tosinso-uploader[data-mode="preview"] .uploader-cancel-btn {
    background-color: rgba(220, 53, 69, 0.8); /* Red with transparency */
    color: #fff;
    border: none;
    padding: 8px 15px;
    border-radius: var(--border-radius);
    font-size: 14px;
    cursor: pointer;
    transition: background-color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}

.tosinso-uploader[data-mode="preview"] .uploader-cancel-btn:hover {
    background-color: rgba(220, 53, 69, 1);
}

/* NEW: Styling for file-preview-name and its container */
.uploader-media-preview {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column; /* Stack icon and text vertically */
	height: 100%; /* Ensure it takes full height for centering */
	width: 100%; /* Ensure it takes full width for centering */
	text-align: center; /* Fallback for older browsers */
}
.file-preview-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	width: 100%;
	padding: 10px; /* Add some padding */
	box-sizing: border-box; /* Include padding in width/height */
}
.file-preview-name {
	margin-top: 10px; /* Space between icon and name */
	font-size: 1.2em; /* Slightly larger font */
	font-weight: bold;
	color: var(--dark-gray-color);
	text-align: center;
	word-break: break-all; /* Ensures long file names wrap */
	padding: 0 5px; /* Add horizontal padding to prevent text from touching edges */
}
.uploader-media-preview .file-icon {
	font-size: 4em; /* Larger icon size */
	color: var(--primary-color); /* Use primary color for icons */
	margin-bottom: 10px; /* Space between icon and name */
}