/* DO Image Optimizer — Premium Edition */
/* All layout properties use !important to prevent WP theme overrides */
/* Scoped under #doio-app for max specificity */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Sans:wght@400;500;600;700&family=Geist+Mono:wght@400;500;600&display=swap');

/* ========== RESET INSIDE WRAPPER ========== */
#doio-app,
#doio-app *,
#doio-app *::before,
#doio-app *::after {
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    outline: none !important;
    text-decoration: none !important;
    list-style: none !important;
    float: none !important;
    clear: none !important;
}

#doio-app {
    --doio-accent: #0ea5e9;
    --doio-accent-rgb: 14, 165, 233;
    --doio-bg: #f8f6f3;
    --doio-bg-warm: #f3f0eb;
    --doio-card: #ffffff;
    --doio-card-glass: rgba(255, 255, 255, 0.72);
    --doio-border: #e8e4df;
    --doio-border-light: #f0ece7;
    --doio-text: #1c1917;
    --doio-text-secondary: #57534e;
    --doio-text-muted: #a8a29e;
    --doio-success: #16a34a;
    --doio-success-soft: #dcfce7;
    --doio-danger: #dc2626;
    --doio-warning: #d97706;
    --doio-warning-bg: #fef9ee;
    --doio-radius: 20px;
    --doio-radius-sm: 12px;
    --doio-radius-xs: 8px;
    --doio-shadow-xs: 0 1px 2px rgba(28, 25, 23, 0.04);
    --doio-shadow: 0 1px 3px rgba(28, 25, 23, 0.06), 0 6px 16px rgba(28, 25, 23, 0.04);
    --doio-shadow-lg: 0 4px 6px rgba(28, 25, 23, 0.04), 0 12px 32px rgba(28, 25, 23, 0.08);
    --doio-shadow-glow: 0 0 40px rgba(var(--doio-accent-rgb), 0.08);
    --doio-ease: cubic-bezier(0.16, 1, 0.3, 1);
    --doio-transition: 0.3s var(--doio-ease);
    --doio-font: 'Instrument Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --doio-mono: 'Geist Mono', 'SF Mono', 'Cascadia Code', monospace;
}

/* ========== WRAPPER ========== */
#doio-app.doio-wrapper {
    position: relative !important;
    display: block !important;
    max-width: 760px !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding: 56px 24px 72px !important;
    font-family: var(--doio-font) !important;
    font-size: 16px !important;
    color: var(--doio-text) !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
    line-height: 1.6 !important;
    background: transparent !important;
    text-align: left !important;
}

/* ========== AMBIENT BACKGROUND ========== */
#doio-app .doio-ambient {
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
    overflow: hidden !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

#doio-app .doio-ambient-orb {
    position: absolute !important;
    border-radius: 50% !important;
    filter: blur(80px) !important;
    opacity: 0.35 !important;
    animation: doio-drift 20s ease-in-out infinite !important;
}

#doio-app .doio-orb-1 {
    width: 300px !important; height: 300px !important;
    background: rgba(var(--doio-accent-rgb), 0.15) !important;
    top: -60px !important; right: -80px !important;
    animation-delay: 0s !important;
}

#doio-app .doio-orb-2 {
    width: 250px !important; height: 250px !important;
    background: rgba(168, 162, 158, 0.1) !important;
    bottom: 20% !important; left: -100px !important;
    animation-delay: -7s !important;
}

#doio-app .doio-orb-3 {
    width: 200px !important; height: 200px !important;
    background: rgba(var(--doio-accent-rgb), 0.08) !important;
    bottom: -40px !important; right: 20% !important;
    animation-delay: -14s !important;
}

@keyframes doio-drift {
    0%, 100% { transform: translate(0, 0) scale(1); }
    33% { transform: translate(30px, -20px) scale(1.05); }
    66% { transform: translate(-20px, 15px) scale(0.95); }
}

/* ========== HEADER ========== */
#doio-app .doio-header {
    position: relative !important;
    z-index: 1 !important;
    text-align: center !important;
    margin-bottom: 32px !important;
    display: block !important;
}

#doio-app .doio-header-icon-wrap {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 24px !important;
    width: 84px !important;
    height: 84px !important;
}

#doio-app .doio-header-icon {
    position: relative !important;
    z-index: 2 !important;
    width: 68px !important;
    height: 68px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 22px !important;
    background: var(--doio-card) !important;
    border: 1px solid var(--doio-border-light) !important;
    box-shadow: var(--doio-shadow), var(--doio-shadow-glow) !important;
}

#doio-app .doio-header-icon svg {
    width: 32px !important;
    height: 32px !important;
    display: block !important;
}

#doio-app .doio-header-icon-ring {
    position: absolute !important;
    top: -8px !important; left: -8px !important; right: -8px !important; bottom: -8px !important;
    border-radius: 28px !important;
    border: 1.5px dashed rgba(var(--doio-accent-rgb), 0.18) !important;
    animation: doio-ring-spin 30s linear infinite !important;
}

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

#doio-app .doio-title {
    font-size: 36px !important;
    font-weight: 700 !important;
    letter-spacing: -0.035em !important;
    margin: 0 0 12px !important;
    color: var(--doio-text) !important;
    line-height: 1.15 !important;
    font-family: var(--doio-font) !important;
    text-align: center !important;
    padding: 0 !important;
}

#doio-app .doio-subtitle {
    font-size: 16px !important;
    color: var(--doio-text-secondary) !important;
    margin: 0 auto 24px !important;
    max-width: 500px !important;
    font-weight: 400 !important;
    line-height: 1.65 !important;
    text-align: center !important;
    font-family: var(--doio-font) !important;
    padding: 0 !important;
}

/* ========== BADGES ========== */
#doio-app .doio-badges {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}

#doio-app .doio-badge {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 7px !important;
    padding: 6px 14px !important;
    background: var(--doio-card-glass) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid var(--doio-border-light) !important;
    border-radius: 100px !important;
    font-size: 12.5px !important;
    font-weight: 500 !important;
    color: var(--doio-text-secondary) !important;
    transition: var(--doio-transition) !important;
    white-space: nowrap !important;
    line-height: 1.4 !important;
    font-family: var(--doio-font) !important;
    cursor: default !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

#doio-app .doio-badge:hover {
    border-color: var(--doio-border) !important;
    box-shadow: var(--doio-shadow-xs) !important;
    transform: translateY(-1px) !important;
}

#doio-app .doio-badge-dot {
    width: 7px !important;
    height: 7px !important;
    min-width: 7px !important;
    min-height: 7px !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
    display: inline-block !important;
    border: none !important;
}

#doio-app .doio-dot-green {
    background: #22c55e !important;
    box-shadow: 0 0 6px rgba(34, 197, 94, 0.45) !important;
}

#doio-app .doio-dot-amber {
    background: #f59e0b !important;
    box-shadow: 0 0 6px rgba(245, 158, 11, 0.45) !important;
}

#doio-app .doio-dot-blue {
    background: var(--doio-accent) !important;
    box-shadow: 0 0 6px rgba(var(--doio-accent-rgb), 0.45) !important;
}

/* ========== STEP INDICATOR ========== */
#doio-app .doio-steps {
    position: relative !important;
    z-index: 1 !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0 !important;
    margin-bottom: 28px !important;
    padding: 0 20px !important;
}

#doio-app .doio-step {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--doio-text-muted) !important;
    transition: var(--doio-transition) !important;
    white-space: nowrap !important;
    font-family: var(--doio-font) !important;
    line-height: 1.4 !important;
}

#doio-app .doio-step span {
    font-size: 13px !important;
    font-weight: 500 !important;
    font-family: var(--doio-font) !important;
    color: inherit !important;
    display: inline !important;
}

#doio-app .doio-step-num {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    background: var(--doio-bg-warm) !important;
    color: var(--doio-text-muted) !important;
    border: 1.5px solid var(--doio-border) !important;
    transition: var(--doio-transition) !important;
    font-family: var(--doio-mono) !important;
    line-height: 1 !important;
}

#doio-app .doio-step-active .doio-step-num {
    background: var(--doio-accent) !important;
    color: #fff !important;
    border-color: var(--doio-accent) !important;
    box-shadow: 0 2px 8px rgba(var(--doio-accent-rgb), 0.3) !important;
}

#doio-app .doio-step-active {
    color: var(--doio-text) !important;
}

#doio-app .doio-step-done .doio-step-num {
    background: var(--doio-success) !important;
    color: #fff !important;
    border-color: var(--doio-success) !important;
}

#doio-app .doio-step-done { color: var(--doio-success) !important; }

#doio-app .doio-step-line {
    flex: 1 1 auto !important;
    max-width: 56px !important;
    min-width: 24px !important;
    height: 2px !important;
    background: var(--doio-border) !important;
    margin: 0 12px !important;
    border-radius: 1px !important;
    overflow: hidden !important;
    display: block !important;
    border: none !important;
}

#doio-app .doio-step-line-fill {
    width: 0% !important;
    height: 100% !important;
    background: var(--doio-accent) !important;
    border-radius: 1px !important;
    transition: width 0.6s var(--doio-ease) !important;
    display: block !important;
}

/* ========== UPLOAD ZONE ========== */
#doio-app .doio-upload-zone {
    position: relative !important;
    z-index: 1 !important;
    border-radius: var(--doio-radius) !important;
    background: var(--doio-card-glass) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    cursor: pointer !important;
    transition: var(--doio-transition) !important;
    overflow: hidden !important;
    border: 1px solid var(--doio-border-light) !important;
    box-shadow: var(--doio-shadow) !important;
    display: block !important;
}

#doio-app .doio-upload-zone:hover {
    border-color: rgba(var(--doio-accent-rgb), 0.2) !important;
    box-shadow: var(--doio-shadow-lg), var(--doio-shadow-glow) !important;
    transform: translateY(-3px) !important;
}

#doio-app .doio-upload-zone.doio-drag-over {
    transform: translateY(-3px) scale(1.005) !important;
    border-color: rgba(var(--doio-accent-rgb), 0.4) !important;
    box-shadow: 0 0 0 4px rgba(var(--doio-accent-rgb), 0.1), var(--doio-shadow-lg) !important;
}

#doio-app .doio-upload-glow {
    position: absolute !important;
    top: -50% !important; left: 50% !important;
    transform: translateX(-50%) !important;
    width: 300px !important; height: 300px !important;
    background: radial-gradient(circle, rgba(var(--doio-accent-rgb), 0.06) 0%, transparent 70%) !important;
    pointer-events: none !important;
    transition: opacity 0.5s ease !important;
    opacity: 0 !important;
}

#doio-app .doio-upload-zone:hover .doio-upload-glow { opacity: 1 !important; }

#doio-app .doio-upload-border {
    position: absolute !important;
    top: 14px !important; left: 14px !important; right: 14px !important; bottom: 14px !important;
    border: 2px dashed var(--doio-border) !important;
    border-radius: calc(var(--doio-radius) - 6px) !important;
    pointer-events: none !important;
    transition: var(--doio-transition) !important;
    opacity: 0.5 !important;
}

#doio-app .doio-upload-zone:hover .doio-upload-border,
#doio-app .doio-upload-zone.doio-drag-over .doio-upload-border {
    border-color: var(--doio-accent) !important;
    opacity: 0.3 !important;
}

#doio-app .doio-upload-inner {
    position: relative !important;
    z-index: 1 !important;
    padding: 56px 32px 48px !important;
    text-align: center !important;
    display: block !important;
}

/* Upload Circle */
#doio-app .doio-upload-visual {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 20px !important;
    width: 96px !important;
    height: 96px !important;
}

#doio-app .doio-upload-circle {
    width: 88px !important;
    height: 88px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: linear-gradient(145deg, rgba(var(--doio-accent-rgb), 0.06), rgba(var(--doio-accent-rgb), 0.12)) !important;
    border: 1.5px solid rgba(var(--doio-accent-rgb), 0.1) !important;
    animation: doio-breathe 4s ease-in-out infinite !important;
    position: relative !important;
    z-index: 2 !important;
}

#doio-app .doio-upload-circle svg {
    width: 40px !important;
    height: 40px !important;
    display: block !important;
}

@keyframes doio-breathe {
    0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(var(--doio-accent-rgb), 0.1); }
    50% { transform: scale(1.04); box-shadow: 0 0 24px 4px rgba(var(--doio-accent-rgb), 0.06); }
}

#doio-app .doio-upload-particles {
    position: absolute !important;
    top: -20px !important; left: -20px !important; right: -20px !important; bottom: -20px !important;
    pointer-events: none !important;
}

#doio-app .doio-upload-particles span {
    position: absolute !important;
    width: 4px !important;
    height: 4px !important;
    border-radius: 50% !important;
    background: rgba(var(--doio-accent-rgb), 0.3) !important;
    animation: doio-particle 6s ease-in-out infinite !important;
    display: block !important;
    border: none !important;
}

#doio-app .doio-upload-particles span:nth-child(1) { top: 10% !important; left: 15% !important; animation-delay: 0s !important; }
#doio-app .doio-upload-particles span:nth-child(2) { top: 5% !important; right: 20% !important; animation-delay: -1s !important; width: 3px !important; height: 3px !important; }
#doio-app .doio-upload-particles span:nth-child(3) { bottom: 15% !important; left: 10% !important; animation-delay: -2s !important; width: 5px !important; height: 5px !important; }
#doio-app .doio-upload-particles span:nth-child(4) { bottom: 10% !important; right: 15% !important; animation-delay: -3s !important; }
#doio-app .doio-upload-particles span:nth-child(5) { top: 40% !important; left: 0 !important; animation-delay: -4s !important; width: 3px !important; height: 3px !important; }
#doio-app .doio-upload-particles span:nth-child(6) { top: 35% !important; right: 5% !important; animation-delay: -5s !important; width: 5px !important; height: 5px !important; }

@keyframes doio-particle {
    0%, 100% { transform: translateY(0) scale(1); opacity: 0.3; }
    50% { transform: translateY(-12px) scale(1.5); opacity: 0.7; }
}

#doio-app .doio-upload-title {
    font-size: 21px !important;
    font-weight: 600 !important;
    margin: 0 0 8px !important;
    color: var(--doio-text) !important;
    letter-spacing: -0.01em !important;
    font-family: var(--doio-font) !important;
    line-height: 1.3 !important;
    text-align: center !important;
    padding: 0 !important;
}

#doio-app .doio-upload-hint {
    font-size: 15px !important;
    color: var(--doio-text-muted) !important;
    margin: 0 0 20px !important;
    font-weight: 400 !important;
    font-family: var(--doio-font) !important;
    text-align: center !important;
    line-height: 1.5 !important;
}

#doio-app .doio-upload-browse {
    color: var(--doio-accent) !important;
    font-weight: 600 !important;
    text-decoration: underline !important;
    text-decoration-color: rgba(var(--doio-accent-rgb), 0.3) !important;
    text-underline-offset: 3px !important;
    cursor: pointer !important;
}

#doio-app .doio-upload-chips {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
}

#doio-app .doio-chip {
    font-size: 10.5px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    padding: 3px 10px !important;
    background: rgba(var(--doio-accent-rgb), 0.06) !important;
    color: var(--doio-accent) !important;
    border-radius: 6px !important;
    font-family: var(--doio-mono) !important;
    display: inline-block !important;
    line-height: 1.5 !important;
    border: none !important;
}

#doio-app .doio-chip-sep {
    color: var(--doio-border) !important;
    font-size: 16px !important;
    line-height: 1 !important;
}

#doio-app .doio-chip-text {
    font-size: 12px !important;
    color: var(--doio-text-muted) !important;
    font-family: var(--doio-font) !important;
}

/* ========== CONTROLS ========== */
#doio-app .doio-controls {
    position: relative !important;
    z-index: 1 !important;
    margin-top: 16px !important;
    background: var(--doio-card-glass) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border-radius: var(--doio-radius) !important;
    border: 1px solid var(--doio-border-light) !important;
    box-shadow: var(--doio-shadow) !important;
    overflow: hidden !important;
    animation: doio-slide-up 0.45s var(--doio-ease) !important;
    display: block !important;
}

@keyframes doio-slide-up {
    from { opacity: 0; transform: translateY(16px); }
    to { opacity: 1; transform: translateY(0); }
}

#doio-app .doio-controls-top {
    padding: 24px 28px 20px !important;
    display: block !important;
}

#doio-app .doio-controls-bottom {
    display: flex !important;
    flex-direction: row !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 14px 28px !important;
    background: rgba(var(--doio-accent-rgb), 0.02) !important;
    border-top: 1px solid var(--doio-border-light) !important;
}

#doio-app .doio-control-header {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 16px !important;
}

#doio-app .doio-control-label {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    color: var(--doio-text) !important;
    font-family: var(--doio-font) !important;
}

#doio-app .doio-control-label svg {
    opacity: 0.4 !important;
    width: 15px !important;
    height: 15px !important;
}

#doio-app .doio-quality-badge {
    font-size: 13px !important;
    font-weight: 700 !important;
    font-family: var(--doio-mono) !important;
    color: var(--doio-accent) !important;
    background: rgba(var(--doio-accent-rgb), 0.08) !important;
    padding: 4px 12px !important;
    border-radius: 100px !important;
    letter-spacing: 0.02em !important;
    display: inline-block !important;
    line-height: 1.4 !important;
    border: none !important;
}

#doio-app .doio-slider-wrap { position: relative !important; display: block !important; }
#doio-app .doio-slider-track { position: relative !important; padding: 4px 0 !important; display: block !important; }

#doio-app .doio-slider {
    -webkit-appearance: none !important;
    appearance: none !important;
    width: 100% !important;
    height: 5px !important;
    border-radius: 3px !important;
    background: var(--doio-border) !important;
    outline: none !important;
    display: block !important;
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

#doio-app .doio-slider::-webkit-slider-thumb {
    -webkit-appearance: none !important;
    width: 24px !important;
    height: 24px !important;
    border-radius: 50% !important;
    background: #fff !important;
    cursor: pointer !important;
    border: 2px solid var(--doio-accent) !important;
    box-shadow: 0 1px 4px rgba(28, 25, 23, 0.1), 0 0 0 3px rgba(var(--doio-accent-rgb), 0.08) !important;
    margin-top: -10px !important;
}

#doio-app .doio-slider::-webkit-slider-thumb:hover {
    transform: scale(1.12) !important;
    box-shadow: 0 2px 8px rgba(28, 25, 23, 0.12), 0 0 0 5px rgba(var(--doio-accent-rgb), 0.12) !important;
}

#doio-app .doio-slider::-moz-range-thumb {
    width: 24px !important; height: 24px !important;
    border-radius: 50% !important;
    background: #fff !important;
    cursor: pointer !important;
    border: 2px solid var(--doio-accent) !important;
    box-shadow: 0 1px 4px rgba(28, 25, 23, 0.1) !important;
}

#doio-app .doio-slider-labels {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    margin-top: 10px !important;
    font-size: 11.5px !important;
    color: var(--doio-text-muted) !important;
    font-weight: 500 !important;
    font-family: var(--doio-font) !important;
}

#doio-app .doio-slider-labels span {
    font-size: 11.5px !important;
    color: var(--doio-text-muted) !important;
    font-weight: 500 !important;
    font-family: var(--doio-font) !important;
}

/* ========== BUTTONS ========== */
#doio-app .doio-btn {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 11px 22px !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    border-radius: var(--doio-radius-sm) !important;
    border: none !important;
    cursor: pointer !important;
    transition: var(--doio-transition) !important;
    font-family: var(--doio-font) !important;
    white-space: nowrap !important;
    letter-spacing: -0.005em !important;
    line-height: 1.4 !important;
    text-transform: none !important;
    text-decoration: none !important;
    box-shadow: none !important;
    outline: none !important;
}

#doio-app .doio-btn svg {
    width: 15px !important;
    height: 15px !important;
    flex-shrink: 0 !important;
}

#doio-app .doio-btn-primary {
    background: var(--doio-accent) !important;
    color: #fff !important;
    box-shadow: 0 1px 3px rgba(var(--doio-accent-rgb), 0.2), inset 0 1px 0 rgba(255,255,255,0.15) !important;
}

#doio-app .doio-btn-primary:hover {
    filter: brightness(0.92) !important;
    box-shadow: 0 4px 16px rgba(var(--doio-accent-rgb), 0.3), inset 0 1px 0 rgba(255,255,255,0.15) !important;
    transform: translateY(-1px) !important;
}

#doio-app .doio-btn-primary:active {
    transform: translateY(0) !important;
    filter: brightness(0.88) !important;
}

#doio-app .doio-btn-ghost {
    background: transparent !important;
    color: var(--doio-text-secondary) !important;
    border: 1.5px solid var(--doio-border) !important;
}

#doio-app .doio-btn-ghost:hover {
    border-color: rgba(var(--doio-accent-rgb), 0.3) !important;
    color: var(--doio-accent) !important;
    background: rgba(var(--doio-accent-rgb), 0.03) !important;
}

#doio-app .doio-btn-lg {
    padding: 14px 32px !important;
    font-size: 14.5px !important;
    border-radius: 14px !important;
}

#doio-app .doio-btn-text {
    background: none !important;
    border: none !important;
    color: var(--doio-text-muted) !important;
    cursor: pointer !important;
    font-size: 12.5px !important;
    font-weight: 500 !important;
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 5px !important;
    padding: 5px 10px !important;
    border-radius: 8px !important;
    transition: var(--doio-transition) !important;
    font-family: var(--doio-font) !important;
}

#doio-app .doio-btn-text:hover {
    color: var(--doio-danger) !important;
    background: rgba(220, 38, 38, 0.05) !important;
}

/* ========== FILE LIST ========== */
#doio-app .doio-file-list {
    position: relative !important;
    z-index: 1 !important;
    margin-top: 16px !important;
    animation: doio-slide-up 0.45s var(--doio-ease) !important;
    display: block !important;
}

#doio-app .doio-file-list-header {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 0 6px !important;
    margin-bottom: 10px !important;
}

#doio-app .doio-fl-count {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--doio-text-secondary) !important;
    font-family: var(--doio-font) !important;
}

#doio-app .doio-files-container {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
}

/* File Item */
#doio-app .doio-file-item {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 12px 16px !important;
    background: var(--doio-card-glass) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border-radius: var(--doio-radius-sm) !important;
    border: 1px solid var(--doio-border-light) !important;
    transition: var(--doio-transition) !important;
    animation: doio-slide-up 0.35s var(--doio-ease) !important;
}

#doio-app .doio-file-item:hover {
    border-color: rgba(var(--doio-accent-rgb), 0.15) !important;
    box-shadow: var(--doio-shadow-xs) !important;
}

#doio-app .doio-file-thumb {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    border-radius: var(--doio-radius-xs) !important;
    object-fit: cover !important;
    background: var(--doio-bg-warm) !important;
    flex-shrink: 0 !important;
    border: 1px solid var(--doio-border-light) !important;
    display: block !important;
}

#doio-app .doio-file-info { flex: 1 1 auto !important; min-width: 0 !important; }

#doio-app .doio-file-name {
    font-size: 13.5px !important;
    font-weight: 500 !important;
    color: var(--doio-text) !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    margin: 0 0 3px !important;
    font-family: var(--doio-font) !important;
    line-height: 1.4 !important;
}

#doio-app .doio-file-meta {
    font-size: 11.5px !important;
    color: var(--doio-text-muted) !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    font-family: var(--doio-font) !important;
}

#doio-app .doio-file-type {
    text-transform: uppercase !important;
    font-weight: 700 !important;
    font-size: 9.5px !important;
    padding: 2px 7px !important;
    background: rgba(var(--doio-accent-rgb), 0.06) !important;
    color: var(--doio-accent) !important;
    border-radius: 5px !important;
    letter-spacing: 0.06em !important;
    font-family: var(--doio-mono) !important;
    display: inline-block !important;
    line-height: 1.5 !important;
    border: none !important;
}

#doio-app .doio-file-status {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
    flex-shrink: 0 !important;
}

#doio-app .doio-file-progress {
    width: 72px !important;
    height: 3px !important;
    background: var(--doio-border) !important;
    border-radius: 2px !important;
    overflow: hidden !important;
    display: block !important;
    border: none !important;
}

#doio-app .doio-file-progress-bar {
    height: 100% !important;
    background: linear-gradient(90deg, var(--doio-accent), rgba(var(--doio-accent-rgb), 0.6)) !important;
    border-radius: 2px !important;
    transition: width 0.4s var(--doio-ease) !important;
    display: block !important;
}

#doio-app .doio-file-savings {
    font-size: 12.5px !important;
    font-weight: 700 !important;
    color: var(--doio-success) !important;
    font-family: var(--doio-mono) !important;
    white-space: nowrap !important;
}

#doio-app .doio-file-new-size {
    font-size: 11.5px !important;
    color: var(--doio-text-muted) !important;
    font-family: var(--doio-mono) !important;
    white-space: nowrap !important;
}

#doio-app .doio-file-done-icon {
    color: var(--doio-success) !important;
    flex-shrink: 0 !important;
    animation: doio-pop 0.4s var(--doio-ease) !important;
    display: inline-flex !important;
}

@keyframes doio-pop {
    0% { transform: scale(0); opacity: 0; }
    60% { transform: scale(1.2); }
    100% { transform: scale(1); opacity: 1; }
}

#doio-app .doio-file-error {
    font-size: 12px !important;
    color: var(--doio-danger) !important;
    font-weight: 600 !important;
}

#doio-app .doio-file-download {
    background: none !important;
    border: none !important;
    color: var(--doio-accent) !important;
    cursor: pointer !important;
    padding: 6px !important;
    border-radius: 8px !important;
    transition: var(--doio-transition) !important;
    display: inline-flex !important;
    align-items: center !important;
}

#doio-app .doio-file-download:hover {
    background: rgba(var(--doio-accent-rgb), 0.06) !important;
}

#doio-app .doio-file-remove {
    background: none !important;
    border: none !important;
    color: var(--doio-text-muted) !important;
    cursor: pointer !important;
    padding: 6px !important;
    border-radius: 8px !important;
    transition: var(--doio-transition) !important;
    display: inline-flex !important;
    align-items: center !important;
    opacity: 0.5 !important;
}

#doio-app .doio-file-item:hover .doio-file-remove { opacity: 1 !important; }

#doio-app .doio-file-remove:hover {
    background: rgba(220, 38, 38, 0.05) !important;
    color: var(--doio-danger) !important;
}

/* ========== RESULTS ========== */
#doio-app .doio-results {
    position: relative !important;
    z-index: 1 !important;
    margin-top: 20px !important;
    animation: doio-slide-up 0.5s var(--doio-ease) !important;
    display: block !important;
}

#doio-app .doio-results-inner {
    text-align: center !important;
    background: var(--doio-card-glass) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border-radius: var(--doio-radius) !important;
    padding: 48px 32px 44px !important;
    box-shadow: var(--doio-shadow-lg) !important;
    border: 1px solid var(--doio-border-light) !important;
    position: relative !important;
    overflow: hidden !important;
}

#doio-app .doio-results-inner::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    height: 3px !important;
    background: linear-gradient(90deg, var(--doio-accent), rgba(var(--doio-accent-rgb), 0.3), var(--doio-accent)) !important;
    background-size: 200% 100% !important;
    animation: doio-shimmer 2s linear infinite !important;
    display: block !important;
}

@keyframes doio-shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

#doio-app .doio-result-icon {
    margin-bottom: 16px !important;
    animation: doio-pop 0.6s var(--doio-ease) 0.15s both !important;
    display: inline-block !important;
}

#doio-app .doio-result-icon svg {
    width: 44px !important;
    height: 44px !important;
    display: block !important;
}

#doio-app .doio-result-title {
    font-size: 24px !important;
    font-weight: 700 !important;
    margin: 0 0 8px !important;
    color: var(--doio-text) !important;
    letter-spacing: -0.02em !important;
    font-family: var(--doio-font) !important;
    line-height: 1.3 !important;
}

#doio-app .doio-result-subtitle {
    font-size: 14px !important;
    color: var(--doio-text-muted) !important;
    margin: 0 0 28px !important;
    font-family: var(--doio-font) !important;
    line-height: 1.5 !important;
}

#doio-app .doio-result-stats {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 10px !important;
    margin-bottom: 32px !important;
}

#doio-app .doio-stat-card-mini {
    padding: 16px 12px !important;
    background: rgba(var(--doio-accent-rgb), 0.02) !important;
    border: 1px solid var(--doio-border-light) !important;
    border-radius: var(--doio-radius-sm) !important;
    transition: var(--doio-transition) !important;
    text-align: center !important;
}

#doio-app .doio-stat-card-mini:hover {
    border-color: var(--doio-border) !important;
}

#doio-app .doio-stat-accent {
    background: rgba(var(--doio-accent-rgb), 0.05) !important;
    border-color: rgba(var(--doio-accent-rgb), 0.1) !important;
}

#doio-app .doio-stat-card-label {
    display: block !important;
    font-size: 10.5px !important;
    font-weight: 600 !important;
    color: var(--doio-text-muted) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    margin-bottom: 6px !important;
    font-family: var(--doio-font) !important;
}

#doio-app .doio-stat-card-val {
    display: block !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--doio-text) !important;
    font-family: var(--doio-mono) !important;
    letter-spacing: -0.02em !important;
    line-height: 1.2 !important;
}

#doio-app .doio-stat-accent .doio-stat-card-val {
    color: var(--doio-accent) !important;
}

#doio-app .doio-result-actions {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
}

/* ========== RATE NOTICE ========== */
#doio-app .doio-rate-notice {
    position: relative !important;
    z-index: 1 !important;
    margin-top: 16px !important;
    padding: 14px 18px !important;
    background: var(--doio-warning-bg) !important;
    border: 1px solid rgba(217, 119, 6, 0.15) !important;
    border-radius: var(--doio-radius-sm) !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 13.5px !important;
    color: #92400e !important;
    font-weight: 500 !important;
    animation: doio-slide-up 0.35s var(--doio-ease) !important;
    font-family: var(--doio-font) !important;
}

#doio-app .doio-notice-icon {
    flex-shrink: 0 !important;
    opacity: 0.7 !important;
    display: inline-flex !important;
}

/* ========== FOOTER ========== */
#doio-app .doio-footer {
    position: relative !important;
    z-index: 1 !important;
    margin-top: 48px !important;
    text-align: center !important;
    display: block !important;
}

#doio-app .doio-footer-lock {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 12.5px !important;
    color: var(--doio-text-muted) !important;
    padding: 8px 18px !important;
    background: var(--doio-card-glass) !important;
    border: 1px solid var(--doio-border-light) !important;
    border-radius: 100px !important;
    margin-bottom: 16px !important;
    font-family: var(--doio-font) !important;
    line-height: 1.5 !important;
}

#doio-app .doio-footer-lock svg {
    opacity: 0.5 !important;
    flex-shrink: 0 !important;
    width: 13px !important;
    height: 13px !important;
}

#doio-app .doio-footer-lock span {
    font-size: 12.5px !important;
    color: var(--doio-text-muted) !important;
    font-family: var(--doio-font) !important;
}

#doio-app .doio-powered {
    font-size: 12.5px !important;
    color: var(--doio-text-muted) !important;
    margin: 0 !important;
    font-family: var(--doio-font) !important;
    line-height: 1.5 !important;
}

#doio-app .doio-powered a {
    color: var(--doio-accent) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    transition: var(--doio-transition) !important;
}

#doio-app .doio-powered a:hover {
    text-decoration: underline !important;
    text-underline-offset: 3px !important;
}

/* ========== DISABLED STATE ========== */
.doio-disabled {
    max-width: 760px !important;
    margin: 80px auto !important;
    text-align: center !important;
    font-family: var(--doio-font) !important;
}

.doio-disabled .doio-disabled-inner {
    padding: 64px 32px !important;
    background: var(--doio-card-glass) !important;
    border-radius: 20px !important;
    box-shadow: 0 1px 3px rgba(28, 25, 23, 0.06), 0 6px 16px rgba(28, 25, 23, 0.04) !important;
    border: 1px solid #f0ece7 !important;
}

.doio-disabled .doio-disabled-icon { margin-bottom: 16px !important; }
.doio-disabled .doio-disabled-inner svg { color: #a8a29e !important; }

.doio-disabled .doio-disabled-inner h3 {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #1c1917 !important;
    margin: 0 0 8px !important;
    letter-spacing: -0.02em !important;
    font-family: 'Instrument Sans', sans-serif !important;
}

.doio-disabled .doio-disabled-inner p {
    color: #57534e !important;
    margin: 0 !important;
    font-family: 'Instrument Sans', sans-serif !important;
}

/* ========== SPINNER ========== */
#doio-app .doio-spinner {
    display: inline-block !important;
    width: 15px !important;
    height: 15px !important;
    border: 2px solid rgba(255,255,255,0.25) !important;
    border-top-color: #fff !important;
    border-radius: 50% !important;
    animation: doio-spin 0.55s linear infinite !important;
    background: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

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

/* ========== RESPONSIVE ========== */
@media (max-width: 640px) {
    #doio-app.doio-wrapper { padding: 36px 16px 52px !important; }
    #doio-app .doio-title { font-size: 28px !important; }
    #doio-app .doio-subtitle { font-size: 14.5px !important; }
    #doio-app .doio-upload-inner { padding: 44px 20px 40px !important; }

    #doio-app .doio-steps { padding: 0 12px !important; }
    #doio-app .doio-step > span { display: none !important; }
    #doio-app .doio-step-line { max-width: 40px !important; margin: 0 8px !important; }

    #doio-app .doio-controls-bottom {
        flex-direction: column !important;
    }

    #doio-app .doio-controls-bottom .doio-btn {
        justify-content: center !important;
        width: 100% !important;
    }

    #doio-app .doio-result-stats {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    #doio-app .doio-stat-card-val { font-size: 18px !important; }

    #doio-app .doio-file-item { flex-wrap: wrap !important; }
    #doio-app .doio-file-status {
        width: 100% !important;
        justify-content: flex-end !important;
        margin-top: 4px !important;
    }

    #doio-app .doio-badges { gap: 6px !important; }
    #doio-app .doio-badge { font-size: 11.5px !important; padding: 5px 12px !important; }
}

@media (max-width: 400px) {
    #doio-app .doio-title { font-size: 24px !important; }
    #doio-app .doio-result-stats { grid-template-columns: 1fr 1fr !important; }
}
