/**
 * Motor Planning Practice Widget Styles
 * Aphasia Studio - Speech Therapy Platform
 * 
 * Direct values, no CSS variables, !important overrides for WordPress/Elementor
 * 
 * @version 2.0.0
 */

/* ============================================================
   BASE CONTAINER
   ============================================================ */
/* Override Elementor Kit global button styles */
.elementor-kit-15048 .as-motor-planning button,
.elementor-kit-15048 .as-motor-planning button:hover,
.elementor-kit-15048 .as-motor-planning button:focus,
.elementor-kit-15048 .as-motor-planning button:active,
body .as-motor-planning button {
    background-color: transparent !important;
    background-image: none !important;
    border-color: transparent !important;
    color: inherit !important;
    border-radius: 0 !important;
    padding: 0 !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    text-transform: none !important;
    line-height: inherit !important;
}

.as-motor-planning {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
    background: linear-gradient(135deg, #f9fafb 0%, #ffffff 100%) !important;
    min-height: 500px !important;
    padding: 16px !important;
    color: #111827 !important;
    line-height: 1.5 !important;
    box-sizing: border-box !important;
    max-width: 100% !important;
}

/* When using exercise layout wrapper */
.exercise-layout-wrapper .as-motor-planning,
.as-motor-planning .exercise-layout-wrapper {
    max-width: 100% !important;
    padding: 0 !important;
}

.as-motor-planning *,
.as-motor-planning *::before,
.as-motor-planning *::after {
    box-sizing: border-box !important;
}

/* ============================================================
   CONFIG SCREEN - COMPACT NO-SCROLL DESIGN
   ============================================================ */

.as-motor-planning .as-mp-config {
    max-width: 900px !important;
    margin: 0 auto !important;
}

.as-motor-planning .as-mp-config-compact {
    padding: 8px !important;
}

/* Header - Compact */
.as-motor-planning .as-mp-header {
    text-align: center !important;
    margin-bottom: 16px !important;
    padding-bottom: 8px !important;
    border-bottom: 1px solid #e5e7eb !important;
}

.as-motor-planning .as-mp-header h1 {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    color: #111827 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

.as-motor-planning .as-mp-header p {
    font-size: 0.85rem !important;
    color: #4b5563 !important;
    margin: 4px 0 0 0 !important;
    padding: 0 !important;
}

/* Options Row - Horizontal Layout */
.as-motor-planning .as-mp-options-row {
    display: flex !important;
    gap: 16px !important;
    margin-bottom: 16px !important;
    flex-wrap: wrap !important;
}

/* Option Column */
.as-motor-planning .as-mp-option-col {
    flex: 1 1 0 !important;
    min-width: 110px !important;
    max-width: 200px !important;
    background: #ffffff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 10px !important;
    padding: 10px !important;
    transition: all 0.2s ease !important;
}

/* End Sound column (coda) - visual differentiation */
.as-motor-planning .as-mp-option-col.coda-col {
    background: linear-gradient(135deg, #faf5ff 0%, #f5f3ff 100%) !important;
    border-color: #ddd6fe !important;
}

.as-motor-planning .as-mp-option-col.coda-col .as-mp-col-label {
    color: #7c3aed !important;
    border-bottom-color: #ddd6fe !important;
}

.as-motor-planning .as-mp-option-col.disabled {
    opacity: 0.35 !important;
    pointer-events: none !important;
    background: #f9fafb !important;
    border-color: #f3f4f6 !important;
}

.as-motor-planning .as-mp-col-label {
    display: block !important;
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    color: #9ca3af !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    margin-bottom: 6px !important;
    padding-bottom: 4px !important;
    border-bottom: 1px solid #f3f4f6 !important;
}

/* Pill Group - Vertical Stack */
.as-motor-planning .as-mp-pill-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

/* Pill Button - Compact */
.as-motor-planning .as-mp-pill {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px 12px !important;
    background: #f9fafb !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: all 0.15s ease !important;
    text-decoration: none !important;
    outline: none !important;
    font-size: 0.85rem !important;
    text-align: left !important;
    width: 100% !important;
}

.as-motor-planning .as-mp-pill:hover:not(:disabled) {
    border-color: #3b82f6 !important;
    background: #f0f9ff !important;
}

.as-motor-planning .as-mp-pill.selected {
    border-color: #3b82f6 !important;
    background: #eff6ff !important;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.25) !important;
}

.as-motor-planning .as-mp-pill.coda.selected {
    border-color: #8b5cf6 !important;
    background: #f5f3ff !important;
    box-shadow: 0 2px 8px rgba(139, 92, 246, 0.25) !important;
}

.as-motor-planning .as-mp-pill:disabled {
    cursor: not-allowed !important;
    opacity: 0.5 !important;
}

.as-motor-planning .as-mp-pill .icon {
    font-size: 1.1rem !important;
    line-height: 1 !important;
    flex-shrink: 0 !important;
}

.as-motor-planning .as-mp-pill .label {
    font-weight: 500 !important;
    color: #374151 !important;
    font-size: 0.85rem !important;
}

.as-motor-planning .as-mp-pill.selected .label {
    color: #1d4ed8 !important;
}

.as-motor-planning .as-mp-pill.coda.selected .label {
    color: #7c3aed !important;
}

/* Locked/Premium Pills */
.as-motor-planning .as-mp-pill.locked {
    opacity: 0.65 !important;
    background: #f3f4f6 !important;
    border-color: #e5e7eb !important;
    position: relative !important;
}

.as-motor-planning .as-mp-pill.locked:hover:not(:disabled) {
    border-color: #f59e0b !important;
    background: #fffbeb !important;
}

.as-motor-planning .as-mp-pill.locked .label {
    color: #6b7280 !important;
}

.as-motor-planning .as-mp-pill .lock-badge {
    font-size: 0.7rem !important;
    margin-left: auto !important;
    opacity: 0.8 !important;
}

/* "Any Sound" Quick-Select Option - Stands out as faster choice */
.as-motor-planning .as-mp-pill.any-option {
    background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%) !important;
    border-color: #10b981 !important;
    border-width: 2px !important;
}

.as-motor-planning .as-mp-pill.any-option .icon {
    color: #059669 !important;
}

.as-motor-planning .as-mp-pill.any-option .label {
    color: #047857 !important;
    font-weight: 600 !important;
}

.as-motor-planning .as-mp-pill.any-option:hover:not(:disabled) {
    background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%) !important;
    border-color: #059669 !important;
}

.as-motor-planning .as-mp-pill.any-option.selected {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    border-color: #047857 !important;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.35) !important;
}

.as-motor-planning .as-mp-pill.any-option.selected .icon,
.as-motor-planning .as-mp-pill.any-option.selected .label {
    color: #ffffff !important;
}

/* Upgrade CTA for Free Users */
.as-motor-planning .as-mp-upgrade-cta {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    padding: 12px 16px !important;
    background: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%) !important;
    border: 1px solid #f59e0b !important;
    border-radius: 10px !important;
    margin-bottom: 12px !important;
}

.as-motor-planning .as-mp-upgrade-text {
    font-size: 0.85rem !important;
    color: #92400e !important;
    font-weight: 500 !important;
}

.as-motor-planning .as-mp-upgrade-btn {
    display: inline-block !important;
    padding: 8px 16px !important;
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%) !important;
    color: #ffffff !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 2px 8px rgba(245, 158, 11, 0.3) !important;
}

.as-motor-planning .as-mp-upgrade-btn:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.4) !important;
    color: #ffffff !important;
    text-decoration: none !important;
}

/* Summary Row */
.as-motor-planning .as-mp-summary-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    padding: 12px 16px !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
}

.as-motor-planning .as-mp-selection-summary {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    flex: 1 !important;
}

.as-motor-planning .as-mp-summary-chip {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    padding: 4px 10px !important;
    background: #eff6ff !important;
    color: #1d4ed8 !important;
    border-radius: 9999px !important;
    font-size: 0.75rem !important;
    font-weight: 500 !important;
}

.as-motor-planning .as-mp-summary-chip.coda {
    background: #f5f3ff !important;
    color: #7c3aed !important;
}

.as-motor-planning .as-mp-summary-chip.topic {
    background: #ecfdf5 !important;
    color: #059669 !important;
}

/* Topic Selection Row */
.as-motor-planning .as-mp-topic-row {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 8px 16px !important;
    background: #f0fdf4 !important;
    border-radius: 8px !important;
    margin-bottom: 8px !important;
}

.as-motor-planning .as-mp-topic-label {
    font-size: 0.75rem !important;
    font-weight: 500 !important;
    color: #059669 !important;
    white-space: nowrap !important;
}

.as-motor-planning .as-mp-topic-select {
    flex: 1 !important;
    padding: 6px 10px !important;
    font-size: 0.8rem !important;
    border: 1px solid #d1fae5 !important;
    border-radius: 6px !important;
    background: #ffffff !important;
    color: #111827 !important;
    cursor: pointer !important;
    max-width: 250px !important;
}

.as-motor-planning .as-mp-topic-select:focus {
    outline: none !important;
    border-color: #10b981 !important;
    box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.2) !important;
}

/* Start Button in Summary Row */
.as-motor-planning .as-mp-summary-row .as-mp-start-btn {
    margin: 0 !important;
    padding: 8px 16px !important;
    font-size: 0.8rem !important;
    flex-shrink: 0 !important;
    width: auto !important;
}

/* Legacy styles kept for backwards compatibility */
.as-motor-planning .as-mp-section {
    margin-bottom: 24px !important;
}

.as-motor-planning .as-mp-section h2 {
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: #111827 !important;
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

/* Start Button */
.as-motor-planning .as-mp-start-btn {
    width: 100% !important;
    padding: 16px 24px !important;
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
    color: #ffffff !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    border: none !important;
    border-radius: 12px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35) !important;
    margin-top: 12px !important;
    text-decoration: none !important;
    outline: none !important;
}

.as-motor-planning .as-mp-start-btn:hover:not(:disabled) {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.4) !important;
}

.as-motor-planning .as-mp-start-btn:active:not(:disabled) {
    transform: translateY(0) !important;
}

.as-motor-planning .as-mp-start-btn:disabled {
    background: #d1d5db !important;
    color: #9ca3af !important;
    box-shadow: none !important;
    cursor: not-allowed !important;
    transform: none !important;
}

/* Error */
.as-motor-planning .as-mp-error {
    color: #ef4444 !important;
    text-align: center !important;
    margin-top: 12px !important;
    font-size: 0.9rem !important;
    padding: 12px !important;
    background: #fef2f2 !important;
    border-radius: 8px !important;
}

/* ============================================================
   PRACTICE SCREEN
   ============================================================ */

.as-motor-planning .as-mp-practice-screen {
    max-width: 500px !important;
    margin: 0 auto !important;
}

/* Top Bar */
.as-motor-planning .as-mp-topbar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 12px !important;
}

.as-motor-planning .as-mp-back {
    padding: 8px 12px !important;
    background: transparent !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    font-size: 0.9rem !important;
    color: #4b5563 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    text-decoration: none !important;
    outline: none !important;
}

.as-motor-planning .as-mp-back:hover {
    background: #f3f4f6 !important;
    color: #111827 !important;
}

.as-motor-planning .as-mp-progress-text {
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    color: #4b5563 !important;
}

.as-motor-planning .as-mp-spacer {
    width: 60px !important;
}

/* Progress Bar */
.as-motor-planning .as-mp-progress-bar {
    height: 6px !important;
    background: #e5e7eb !important;
    border-radius: 9999px !important;
    margin-bottom: 24px !important;
    overflow: hidden !important;
}

.as-motor-planning .as-mp-progress-fill {
    height: 100% !important;
    background: linear-gradient(90deg, #3b82f6 0%, #8b5cf6 100%) !important;
    border-radius: 9999px !important;
    transition: width 0.3s ease !important;
}

/* Main Practice Area */
.as-motor-planning .as-mp-practice {
    background: #ffffff !important;
    border-radius: 16px !important;
    padding: 24px !important;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.07), 0 2px 4px rgba(0, 0, 0, 0.06) !important;
    text-align: center !important;
}

/* Mouth Position Image */
.as-motor-planning .as-mp-mouth-image {
    width: 120px !important;
    height: 120px !important;
    margin: 0 auto 16px !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: #f3f4f6 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.as-motor-planning .as-mp-mouth-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.as-motor-planning .as-mp-mouth-image .placeholder {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 4px !important;
    color: #9ca3af !important;
}

.as-motor-planning .as-mp-mouth-image .placeholder span {
    font-size: 2.5rem !important;
    opacity: 0.5 !important;
    line-height: 1 !important;
}

.as-motor-planning .as-mp-mouth-image .placeholder small {
    font-size: 0.75rem !important;
}

/* Target Display */
.as-motor-planning .as-mp-target {
    font-size: 3.5rem !important;
    font-weight: 700 !important;
    color: #111827 !important;
    margin: 0 0 4px 0 !important;
    letter-spacing: 0.02em !important;
    line-height: 1.2 !important;
}

/* Target Display - Large Version (simplified practice screen) */
.as-motor-planning .as-mp-target-large {
    font-size: 6rem !important;
    font-weight: 700 !important;
    color: #111827 !important;
    margin: 20px 0 30px 0 !important;
    letter-spacing: 0.02em !important;
    line-height: 1 !important;
    text-align: center !important;
}

.as-motor-planning .as-mp-ipa {
    font-size: 1.25rem !important;
    color: #4b5563 !important;
    font-family: 'SF Mono', Monaco, 'Consolas', monospace !important;
    margin: 0 0 8px 0 !important;
}

.as-motor-planning .as-mp-example {
    font-size: 0.9rem !important;
    color: #9ca3af !important;
    font-style: italic !important;
    margin: 0 0 16px 0 !important;
}

/* Audio Controls */
.as-motor-planning .as-mp-audio-controls {
    display: flex !important;
    justify-content: center !important;
    gap: 12px !important;
    margin-bottom: 16px !important;
}

.as-motor-planning .as-mp-audio-btn {
    width: 64px !important;
    height: 64px !important;
    border-radius: 9999px !important;
    border: none !important;
    font-size: 1.75rem !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    outline: none !important;
    padding: 0 !important;
    line-height: 1 !important;
}

.as-motor-planning .as-mp-audio-btn.hear {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35) !important;
}

.as-motor-planning .as-mp-audio-btn.hear:hover:not(:disabled) {
    transform: scale(1.05) !important;
}

.as-motor-planning .as-mp-audio-btn.hear:disabled {
    background: #d1d5db !important;
    box-shadow: none !important;
    cursor: not-allowed !important;
}

.as-motor-planning .as-mp-audio-btn.record {
    background: #ffffff !important;
    border: 2px solid #d1d5db !important;
    color: #4b5563 !important;
}

.as-motor-planning .as-mp-audio-btn.record:hover {
    border-color: #ef4444 !important;
    color: #ef4444 !important;
    background: #fef2f2 !important;
}

.as-motor-planning .as-mp-audio-btn.record.recording {
    background: #ef4444 !important;
    border-color: #ef4444 !important;
    color: #ffffff !important;
    animation: mp-pulse 1.5s infinite !important;
}

.as-motor-planning .as-mp-audio-btn.play {
    background: #ffffff !important;
    border: 2px solid #d1d5db !important;
    color: #4b5563 !important;
}

.as-motor-planning .as-mp-audio-btn.play:hover {
    border-color: #10b981 !important;
    color: #10b981 !important;
    background: #ecfdf5 !important;
}

.as-motor-planning .as-mp-audio-btn.play.playing {
    background: #10b981 !important;
    border-color: #10b981 !important;
    color: #ffffff !important;
}

@keyframes mp-pulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.4) !important;
    }
    50% {
        box-shadow: 0 0 0 12px rgba(239, 68, 68, 0) !important;
    }
}

/* Microphone Error */
.as-motor-planning .as-mp-mic-error {
    color: #dc2626 !important;
    background: #fef2f2 !important;
    border: 1px solid #fecaca !important;
    padding: 10px 16px !important;
    border-radius: 8px !important;
    font-size: 0.9rem !important;
    margin-bottom: 12px !important;
}

/* ============================================================
   INLINE SELF-ASSESSMENT (Replaces Modal)
   ============================================================ */

.as-motor-planning .as-mp-inline-rating {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 16px 0 !important;
    padding: 16px !important;
    background: #f9fafb !important;
    border-radius: 12px !important;
    border: 1px solid #e5e7eb !important;
}

.as-motor-planning .as-mp-rating-label {
    font-size: 0.85rem !important;
    font-weight: 500 !important;
    color: #6b7280 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.as-motor-planning .as-mp-rating-buttons {
    display: flex !important;
    gap: 12px !important;
}

.as-motor-planning .as-mp-rate-btn {
    width: 60px !important;
    height: 60px !important;
    border-radius: 50% !important;
    border: 3px solid transparent !important;
    font-size: 1.75rem !important;
    cursor: pointer !important;
    transition: all 0.15s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #ffffff !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
    padding: 0 !important;
    line-height: 1 !important;
}

.as-motor-planning .as-mp-rate-btn:hover {
    transform: scale(1.1) !important;
}

.as-motor-planning .as-mp-rate-btn:active {
    transform: scale(0.95) !important;
}

.as-motor-planning .as-mp-rate-btn.good {
    border-color: #10b981 !important;
}

.as-motor-planning .as-mp-rate-btn.good:hover {
    background: #ecfdf5 !important;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3) !important;
}

.as-motor-planning .as-mp-rate-btn.close {
    border-color: #f59e0b !important;
}

.as-motor-planning .as-mp-rate-btn.close:hover {
    background: #fffbeb !important;
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3) !important;
}

.as-motor-planning .as-mp-rate-btn.retry {
    border-color: #6b7280 !important;
}

.as-motor-planning .as-mp-rate-btn.retry:hover {
    background: #f3f4f6 !important;
    box-shadow: 0 4px 12px rgba(107, 114, 128, 0.3) !important;
}

/* Status Text */
.as-motor-planning .as-mp-status {
    font-size: 0.9rem !important;
    color: #9ca3af !important;
    margin: 0 0 24px 0 !important;
    min-height: 24px !important;
}

/* Navigation */
.as-motor-planning .as-mp-nav {
    display: flex !important;
    gap: 12px !important;
}

.as-motor-planning .as-mp-nav-btn {
    flex: 1 !important;
    padding: 12px 16px !important;
    border-radius: 8px !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    text-decoration: none !important;
    outline: none !important;
}

.as-motor-planning .as-mp-nav-btn.prev {
    background: #ffffff !important;
    border: 2px solid #e5e7eb !important;
    color: #4b5563 !important;
}

.as-motor-planning .as-mp-nav-btn.prev:hover:not(:disabled) {
    border-color: #d1d5db !important;
    background: #f9fafb !important;
}

.as-motor-planning .as-mp-nav-btn.prev:disabled {
    opacity: 0.4 !important;
    cursor: not-allowed !important;
}

.as-motor-planning .as-mp-nav-btn.next {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
    border: none !important;
    color: #ffffff !important;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35) !important;
}

.as-motor-planning .as-mp-nav-btn.next:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.4) !important;
}

/* Skip button - subtle, for those who don't want to rate */
.as-motor-planning .as-mp-nav-btn.skip {
    background: #ffffff !important;
    border: 2px solid #e5e7eb !important;
    color: #9ca3af !important;
    font-size: 0.85rem !important;
}

.as-motor-planning .as-mp-nav-btn.skip:hover {
    border-color: #d1d5db !important;
    color: #6b7280 !important;
    background: #f9fafb !important;
}

/* ============================================================
   RATING OVERLAY
   ============================================================ */

.as-motor-planning .as-mp-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(0, 0, 0, 0.5) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 1000 !important;
    padding: 16px !important;
    backdrop-filter: blur(4px) !important;
}

.as-motor-planning .as-mp-rating-modal {
    background: #ffffff !important;
    border-radius: 16px !important;
    padding: 24px !important;
    max-width: 320px !important;
    width: 100% !important;
    text-align: center !important;
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.1), 0 4px 6px rgba(0, 0, 0, 0.05) !important;
}

.as-motor-planning .as-mp-rating-modal h3 {
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    color: #111827 !important;
    margin: 0 0 16px 0 !important;
    padding: 0 !important;
    border: none !important;
}

.as-motor-planning .rating-btn {
    width: 100% !important;
    padding: 12px 16px !important;
    border-radius: 8px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    margin-bottom: 8px !important;
    border: 2px solid transparent !important;
    text-decoration: none !important;
    outline: none !important;
}

.as-motor-planning .rating-btn:last-child {
    margin-bottom: 0 !important;
}

.as-motor-planning .rating-btn.good {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 14px rgba(16, 185, 129, 0.35) !important;
}

.as-motor-planning .rating-btn.good:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(16, 185, 129, 0.4) !important;
}

.as-motor-planning .rating-btn.close {
    background: #fffbeb !important;
    border-color: #f59e0b !important;
    color: #92400e !important;
}

.as-motor-planning .rating-btn.close:hover {
    background: #fef3c7 !important;
}

.as-motor-planning .rating-btn.retry {
    background: #ffffff !important;
    border-color: #d1d5db !important;
    color: #4b5563 !important;
}

.as-motor-planning .rating-btn.retry:hover {
    border-color: #9ca3af !important;
    background: #f9fafb !important;
}

/* ============================================================
   COMPLETE SCREEN
   ============================================================ */

.as-motor-planning .as-mp-complete {
    max-width: 400px !important;
    margin: 0 auto !important;
    text-align: center !important;
    padding: 24px !important;
}

.as-motor-planning .as-mp-complete-icon {
    font-size: 4rem !important;
    margin-bottom: 16px !important;
    line-height: 1 !important;
}

.as-motor-planning .as-mp-complete h2 {
    font-size: 1.75rem !important;
    font-weight: 700 !important;
    color: #111827 !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

.as-motor-planning .as-mp-complete > p {
    font-size: 1rem !important;
    color: #4b5563 !important;
    margin: 0 0 24px 0 !important;
}

/* Stats */
.as-motor-planning .as-mp-stats {
    display: flex !important;
    justify-content: center !important;
    gap: 16px !important;
    margin-bottom: 24px !important;
}

.as-motor-planning .as-mp-stats .stat {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    padding: 12px 16px !important;
    background: #f9fafb !important;
    border-radius: 12px !important;
    min-width: 80px !important;
}

.as-motor-planning .as-mp-stats .stat .num {
    font-size: 1.75rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
}

.as-motor-planning .as-mp-stats .stat .label {
    font-size: 0.8rem !important;
    color: #4b5563 !important;
    margin-top: 2px !important;
}

.as-motor-planning .as-mp-stats .stat.good .num {
    color: #10b981 !important;
}

.as-motor-planning .as-mp-stats .stat.close .num {
    color: #f59e0b !important;
}

.as-motor-planning .as-mp-stats .stat.retry .num {
    color: #4b5563 !important;
}

/* Complete Actions */
.as-motor-planning .as-mp-complete-actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

.as-motor-planning .as-mp-btn {
    padding: 12px 24px !important;
    border-radius: 8px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    border: 2px solid transparent !important;
    text-decoration: none !important;
    outline: none !important;
}

.as-motor-planning .as-mp-btn.primary {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35) !important;
}

.as-motor-planning .as-mp-btn.primary:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.4) !important;
}

.as-motor-planning .as-mp-btn.secondary {
    background: #ffffff !important;
    border-color: #e5e7eb !important;
    color: #4b5563 !important;
}

.as-motor-planning .as-mp-btn.secondary:hover {
    border-color: #d1d5db !important;
    background: #f9fafb !important;
}

/* ============================================================
   LOADING STATE
   ============================================================ */

.motor-planning-loading {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 300px !important;
    color: #4b5563 !important;
}

.motor-planning-loading .loading-spinner {
    width: 40px !important;
    height: 40px !important;
    border: 3px solid #e5e7eb !important;
    border-top-color: #3b82f6 !important;
    border-radius: 50% !important;
    animation: mp-spin 0.8s linear infinite !important;
    margin-bottom: 12px !important;
}

@keyframes mp-spin {
    to { transform: rotate(360deg) !important; }
}

/* ============================================================
   PREVIEW MODE (Elementor Editor)
   ============================================================ */

.motor-planning-preview {
    padding: 24px !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05), 0 1px 2px rgba(0, 0, 0, 0.1) !important;
}

.motor-planning-preview .preview-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 16px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #e5e7eb !important;
}

.motor-planning-preview .preview-header h3 {
    margin: 0 !important;
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    color: #111827 !important;
}

.motor-planning-preview .preview-badge {
    padding: 4px 8px !important;
    background: #8b5cf6 !important;
    color: #ffffff !important;
    border-radius: 9999px !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
}

.motor-planning-preview .preview-settings {
    margin-bottom: 16px !important;
}

.motor-planning-preview .preview-settings p {
    margin: 4px 0 !important;
    font-size: 0.9rem !important;
    color: #4b5563 !important;
}

.motor-planning-preview .preview-exercise {
    text-align: center !important;
    padding: 16px !important;
    background: #f9fafb !important;
    border-radius: 8px !important;
}

.motor-planning-preview .preview-target {
    font-size: 2.5rem !important;
    font-weight: 700 !important;
    color: #111827 !important;
}

.motor-planning-preview .preview-ipa {
    font-size: 1rem !important;
    color: #4b5563 !important;
    font-family: monospace !important;
    margin-bottom: 12px !important;
}

.motor-planning-preview .preview-buttons {
    display: flex !important;
    justify-content: center !important;
    gap: 8px !important;
}

.motor-planning-preview .preview-btn {
    padding: 8px 12px !important;
    background: #3b82f6 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 0.85rem !important;
    cursor: default !important;
}

/* ============================================================
   RESPONSIVE DESIGN - MOBILE ACCORDION STYLE
   ============================================================ */

@media (max-width: 600px) {
    .as-motor-planning {
        padding: 12px !important;
        min-height: auto !important;
    }

    .as-motor-planning .as-mp-config-compact {
        padding: 0 !important;
    }

    .as-motor-planning .as-mp-header {
        margin-bottom: 12px !important;
        padding-bottom: 8px !important;
    }

    .as-motor-planning .as-mp-header h1 {
        font-size: 1.1rem !important;
    }

    /* Mobile: Stack columns vertically as accordion steps */
    .as-motor-planning .as-mp-options-row {
        flex-direction: column !important;
        gap: 8px !important;
    }

    .as-motor-planning .as-mp-option-col {
        max-width: 100% !important;
        min-width: 100% !important;
        padding: 0 !important;
        border: none !important;
        background: transparent !important;
        border-radius: 0 !important;
    }

    /* Mobile Step Header - Clickable accordion header */
    .as-motor-planning .as-mp-col-label {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: 12px 16px !important;
        margin-bottom: 0 !important;
        background: #f9fafb !important;
        border: 1px solid #e5e7eb !important;
        border-radius: 10px !important;
        font-size: 0.8rem !important;
        cursor: pointer !important;
        transition: all 0.2s ease !important;
    }

    .as-motor-planning .as-mp-col-label::after {
        content: '▼' !important;
        font-size: 0.6rem !important;
        color: #9ca3af !important;
        transition: transform 0.2s ease !important;
    }

    .as-motor-planning .as-mp-option-col.expanded .as-mp-col-label::after {
        transform: rotate(180deg) !important;
    }

    .as-motor-planning .as-mp-option-col.has-selection .as-mp-col-label {
        background: #eff6ff !important;
        border-color: #3b82f6 !important;
        color: #1d4ed8 !important;
    }

    .as-motor-planning .as-mp-option-col.has-selection.coda-col .as-mp-col-label {
        background: #f5f3ff !important;
        border-color: #8b5cf6 !important;
        color: #7c3aed !important;
    }

    /* Show selected value in header on mobile */
    .as-motor-planning .as-mp-selected-value {
        display: none !important;
    }

    @media (max-width: 600px) {
        .as-motor-planning .as-mp-selected-value {
            display: inline-flex !important;
            align-items: center !important;
            gap: 4px !important;
            font-size: 0.75rem !important;
            font-weight: 600 !important;
            color: #1d4ed8 !important;
            background: #dbeafe !important;
            padding: 2px 8px !important;
            border-radius: 9999px !important;
            margin-left: auto !important;
            margin-right: 8px !important;
            text-transform: none !important;
            letter-spacing: normal !important;
        }

        .as-motor-planning .as-mp-option-col.coda-col .as-mp-selected-value {
            color: #7c3aed !important;
            background: #ede9fe !important;
        }
    }

    /* Mobile Pill Group - Hidden by default, shown when expanded */
    .as-motor-planning .as-mp-pill-group {
        max-height: 0 !important;
        overflow: hidden !important;
        opacity: 0 !important;
        transition: all 0.25s ease !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .as-motor-planning .as-mp-option-col.expanded .as-mp-pill-group {
        max-height: 500px !important;
        opacity: 1 !important;
        padding: 8px 0 !important;
        margin-top: 8px !important;
    }

    /* Mobile Pills - Full width, larger tap targets with better icon ratio */
    .as-motor-planning .as-mp-pill {
        padding: 12px 16px !important;
        font-size: 0.95rem !important;
        border-radius: 10px !important;
        margin-bottom: 6px !important;
        gap: 10px !important;
    }

    .as-motor-planning .as-mp-pill .icon {
        font-size: 1.25rem !important;
    }

    .as-motor-planning .as-mp-pill .label {
        font-size: 0.95rem !important;
    }

    /* Disabled columns on mobile */
    .as-motor-planning .as-mp-option-col.disabled {
        opacity: 0.4 !important;
    }

    .as-motor-planning .as-mp-option-col.disabled .as-mp-col-label {
        cursor: not-allowed !important;
        background: #f9fafb !important;
        border-color: #f3f4f6 !important;
        color: #9ca3af !important;
    }

    /* Mobile Upgrade CTA */
    .as-motor-planning .as-mp-upgrade-cta {
        flex-direction: column !important;
        gap: 8px !important;
        text-align: center !important;
    }

    .as-motor-planning .as-mp-upgrade-btn {
        width: 100% !important;
        text-align: center !important;
    }

    /* Mobile Summary Row */
    .as-motor-planning .as-mp-summary-row {
        flex-direction: column !important;
        gap: 12px !important;
        padding: 12px !important;
        margin-top: 8px !important;
    }

    .as-motor-planning .as-mp-selection-summary {
        justify-content: center !important;
        display: none !important; /* Hide on mobile since we show in accordion headers */
    }

    .as-motor-planning .as-mp-summary-row .as-mp-start-btn {
        width: 100% !important;
        padding: 14px 20px !important;
        font-size: 1rem !important;
    }

    /* Mobile Topic Row */
    .as-motor-planning .as-mp-topic-row {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 8px !important;
        padding: 12px !important;
    }

    .as-motor-planning .as-mp-topic-select {
        max-width: 100% !important;
    }

    /* Practice Screen Mobile */
    .as-motor-planning .as-mp-target-large {
        font-size: 4rem !important;
        margin: 16px 0 24px 0 !important;
    }

    .as-motor-planning .as-mp-target {
        font-size: 2.75rem !important;
    }

    .as-motor-planning .as-mp-audio-btn {
        width: 56px !important;
        height: 56px !important;
        font-size: 1.5rem !important;
    }

    .as-motor-planning .as-mp-practice {
        padding: 16px !important;
        border-radius: 12px !important;
    }

    .as-motor-planning .as-mp-nav {
        flex-direction: row !important;
    }

    .as-motor-planning .as-mp-nav-btn {
        padding: 14px 12px !important;
        font-size: 0.9rem !important;
    }

    /* Mobile Inline Rating */
    .as-motor-planning .as-mp-inline-rating {
        margin: 12px 0 !important;
        padding: 12px !important;
    }

    .as-motor-planning .as-mp-rate-btn {
        width: 54px !important;
        height: 54px !important;
        font-size: 1.5rem !important;
    }

    .as-motor-planning .as-mp-rating-buttons {
        gap: 16px !important;
    }

    /* Complete Screen Mobile */
    .as-motor-planning .as-mp-stats {
        gap: 8px !important;
    }

    .as-motor-planning .as-mp-stats .stat {
        padding: 8px 12px !important;
        min-width: 70px !important;
    }

    .as-motor-planning .as-mp-stats .stat .num {
        font-size: 1.5rem !important;
    }

    .as-motor-planning .as-mp-complete {
        padding: 16px !important;
    }

    .as-motor-planning .as-mp-complete h2 {
        font-size: 1.5rem !important;
    }
}