/**
 * IPTV Trial - Frontend Styles
 */

/* =========================================================
   0) BASE RESET
   ========================================================= */
.iptv-trial-wrapper,
.iptv-trial-wrapper * {
  box-sizing: border-box !important;
}

/* =========================================================
   1) HIDDEN MUST WIN
   ========================================================= */
.iptv-trial-wrapper .iptv-hidden,
.iptv-trial-wrapper .iptv-trial-field.iptv-hidden,
.iptv-trial-wrapper .iptv-trial-container .iptv-hidden,
.iptv-trial-wrapper .iptv-trial-container .iptv-trial-field.iptv-hidden {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* =========================================================
   2) LAYOUT
   ========================================================= */
.iptv-trial-wrapper {
  max-width: 480px !important;
  margin: 0 auto !important;
  padding: 16px !important;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
}

.iptv-trial-wrapper .iptv-trial-container {
  background: #fff !important;
  border-radius: 14px !important;
  box-shadow: 0 4px 28px rgba(0,0,0,.12) !important;
  padding: 28px !important;
  position: relative !important;
}

.iptv-trial-wrapper .iptv-trial-title {
  margin: 0 0 8px !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #1a1a1a !important;
  text-align: center !important;
}

.iptv-trial-wrapper .iptv-trial-description {
  margin: 0 0 22px !important;
  color: #666 !important;
  text-align: center !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
}

/* =========================================================
   3) FORM
   ========================================================= */
.iptv-trial-wrapper .iptv-trial-form {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.iptv-trial-wrapper .iptv-trial-field,
.iptv-trial-wrapper .iptv-trial-container .iptv-trial-field {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}

.iptv-trial-wrapper .iptv-trial-field label {
  display: block !important;
  margin: 0 0 6px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  color: #444 !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}

.iptv-trial-wrapper .iptv-trial-field select,
.iptv-trial-wrapper .iptv-trial-field input[type="text"],
.iptv-trial-wrapper .iptv-trial-field input[type="email"] {
  width: 100% !important;
  padding: 11px 14px !important;
  font-size: 14px !important;
  border: 1.5px solid #e0e0e0 !important;
  border-radius: 8px !important;
  background: #fafafa !important;
  color: #333 !important;
  transition: border-color .2s, box-shadow .2s !important;
  margin: 0 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.iptv-trial-wrapper .iptv-trial-field select {
  cursor: pointer !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  padding-right: 38px !important;
}

.iptv-trial-wrapper .iptv-trial-field select:focus,
.iptv-trial-wrapper .iptv-trial-field input:focus {
  outline: none !important;
  border-color: #0073aa !important;
  background: #fff !important;
  box-shadow: 0 0 0 3px rgba(0,115,170,.12) !important;
}

.iptv-trial-wrapper .iptv-trial-hint {
  margin: 5px 0 0 !important;
  font-size: 12px !important;
  color: #999 !important;
}

.iptv-trial-wrapper .iptv-trial-error-msg {
  margin: 5px 0 0 !important;
  font-size: 13px !important;
  color: #dc3545 !important;
  font-weight: 500 !important;
}

/* =========================================================
   4) BUTTON
   ========================================================= */
.iptv-trial-wrapper .iptv-trial-button {
  width: 100% !important;
  padding: 13px 20px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #fff !important;
  background: linear-gradient(135deg, #0073aa 0%, #005a87 100%) !important;
  border: none !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  transition: transform .15s, box-shadow .15s !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  letter-spacing: .03em !important;
}

.iptv-trial-wrapper .iptv-trial-button:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 14px rgba(0,115,170,.35) !important;
}

.iptv-trial-wrapper .iptv-trial-button:disabled {
  opacity: .7 !important;
  cursor: not-allowed !important;
  transform: none !important;
  box-shadow: none !important;
}

.iptv-trial-wrapper .iptv-trial-button .iptv-spinner,
.iptv-trial-wrapper .iptv-trial-button .iptv-loading-text {
  display: none !important;
}

.iptv-trial-wrapper .iptv-trial-button.is-loading .iptv-spinner,
.iptv-trial-wrapper .iptv-trial-button.is-loading .iptv-loading-text {
  display: inline-block !important;
}

.iptv-trial-wrapper .iptv-trial-button.is-loading .iptv-trial-button-text {
  display: none !important;
}

.iptv-trial-wrapper .iptv-spinner {
  width: 16px !important;
  height: 16px !important;
  border: 2px solid rgba(255,255,255,.3) !important;
  border-top-color: #fff !important;
  border-radius: 50% !important;
  animation: iptv-spin .8s linear infinite !important;
}

@keyframes iptv-spin { to { transform: rotate(360deg); } }

/* =========================================================
   5) RESULT AREA
   ========================================================= */
.iptv-trial-wrapper .iptv-trial-result {
  margin-top: 20px !important;
}

/* Success box */
.iptv-trial-wrapper .iptv-trial-success-box {
  background: #f0fdf4 !important;
  border: 1.5px solid #bbf7d0 !important;
  border-radius: 12px !important;
  padding: 20px !important;
}

.iptv-trial-wrapper .iptv-trial-success-header {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 16px !important;
}

.iptv-trial-wrapper .iptv-trial-success-header .iptv-icon {
  font-size: 22px !important;
  line-height: 1 !important;
}

.iptv-trial-wrapper .iptv-trial-success-header h4 {
  margin: 0 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #15803d !important;
}

/* Credentials */
.iptv-trial-wrapper .iptv-trial-credentials {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  margin-bottom: 16px !important;
}

.iptv-trial-wrapper .iptv-credential-item {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: #fff !important;
  border: 1px solid #d1fae5 !important;
  border-radius: 8px !important;
  padding: 9px 12px !important;
  flex-wrap: wrap !important;
}

.iptv-trial-wrapper .iptv-credential-label {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #666 !important;
  text-transform: uppercase !important;
  letter-spacing: .03em !important;
  min-width: 90px !important;
}

.iptv-trial-wrapper .iptv-credential-value {
  font-family: 'Courier New', monospace !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #1a1a1a !important;
  background: #f0fdf4 !important;
  padding: 2px 8px !important;
  border-radius: 4px !important;
  flex: 1 !important;
  word-break: break-all !important;
}

/* Sections (M3U, Xtream) */
.iptv-trial-wrapper .iptv-trial-section {
  margin-top: 14px !important;
  padding-top: 14px !important;
  border-top: 1px solid #d1fae5 !important;
}

.iptv-trial-wrapper .iptv-trial-section h5 {
  margin: 0 0 10px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #374151 !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
}

/* M3U link input */
.iptv-trial-wrapper .iptv-input-group {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
}

.iptv-trial-wrapper .iptv-input-group input[type="text"] {
  flex: 1 !important;
  font-size: 12px !important;
  font-family: 'Courier New', monospace !important;
  padding: 8px 10px !important;
  background: #fff !important;
  border: 1px solid #d1fae5 !important;
  border-radius: 6px !important;
  color: #555 !important;
}

/* Trial note */
.iptv-trial-wrapper .iptv-trial-note {
  margin: 14px 0 0 !important;
  font-size: 12px !important;
  color: #6b7280 !important;
  line-height: 1.5 !important;
  text-align: center !important;
}

/* Copy button */
.iptv-trial-wrapper .iptv-copy-btn {
  padding: 5px 12px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #15803d !important;
  background: #fff !important;
  border: 1.5px solid #15803d !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  transition: background .2s, color .2s !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}

.iptv-trial-wrapper .iptv-copy-btn:hover,
.iptv-trial-wrapper .iptv-copy-btn.iptv-copied {
  background: #15803d !important;
  color: #fff !important;
}

/* Error box */
.iptv-trial-wrapper .iptv-trial-error-box {
  background: #fef2f2 !important;
  border: 1.5px solid #fecaca !important;
  border-radius: 12px !important;
  padding: 20px !important;
}

.iptv-trial-wrapper .iptv-trial-error-container {
  text-align: center !important;
}

.iptv-trial-wrapper .iptv-trial-error-header {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  margin-bottom: 10px !important;
}

.iptv-trial-wrapper .iptv-trial-error-header h4 {
  margin: 0 !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #dc2626 !important;
}

.iptv-trial-wrapper .iptv-trial-error-text {
  color: #7f1d1d !important;
  font-size: 13px !important;
  margin: 0 0 14px !important;
}

.iptv-trial-wrapper .iptv-trial-retry-btn {
  padding: 8px 20px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #fff !important;
  background: #dc2626 !important;
  border: none !important;
  border-radius: 6px !important;
  cursor: pointer !important;
}

.iptv-trial-wrapper .iptv-trial-retry-btn:hover {
  background: #b91c1c !important;
}

/* Admin error */
.iptv-trial-admin-error {
  max-width: 480px !important;
  margin: 20px auto !important;
  padding: 14px 18px !important;
  background: #fff3cd !important;
  border: 1px solid #ffc107 !important;
  border-radius: 8px !important;
  color: #856404 !important;
  font-size: 14px !important;
}