/* Responsive Design */

/* Tablets - 768px e abaixo */
@media (max-width: 768px) {
    .container {
        padding: 15px;
    }
    
    .app-header h1 {
        font-size: 2rem;
    }
    
    .logo {
        flex-direction: column;
        gap: 10px;
    }
    
    .logo-icon {
        font-size: 2.5rem;
    }
    
    .subtitle {
        font-size: 1rem;
    }
    
    /* Content Grid */
    .content-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    /* Key Management */
    .key-input-row {
        flex-direction: column;
    }
    
    .key-input-row input, 
    .add-key-btn {
        width: 100%;
    }
    
    #keyName, #newApiKey {
        flex-basis: 100%;
    }
    
    .key-input-row .toggle-password {
        right: 15px;
        top: 50%;
    }
    
    .key-item {
        grid-template-columns: 40px 1fr auto;
        grid-template-areas: 
            "status name actions"
            "status details details";
        padding: 12px;
    }
    
    .key-details {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    
    .key-value, .key-stats {
        width: 100%;
    }
    
    .key-actions {
        flex-direction: row;
    }
    
    .keys-actions {
        flex-direction: column;
        gap: 10px;
    }
    
    /* Model Buttons */
    .model-buttons {
        flex-direction: column;
    }
    
    /* Humanization */
    .humanization-features {
        grid-template-columns: 1fr;
    }
    
    /* Audio Section */
    .audio-header {
        flex-direction: column;
        gap: 10px;
        align-items: stretch;
    }
    
    .audio-actions {
        justify-content: center;
    }
    
    /* Info Cards */
    .info-cards {
        grid-template-columns: 1fr;
    }
    
    /* Toast Notifications */
    .toast-container {
        bottom: 10px;
        right: 10px;
        left: 10px;
        max-width: none;
    }
    
    .toast {
        padding: 12px 16px;
    }
}

/* Mobile - 480px e abaixo */
@media (max-width: 480px) {
    .container {
        padding: 10px;
    }
    
    .app-header h1 {
        font-size: 1.8rem;
    }
    
    .logo-icon {
        font-size: 2rem;
    }
    
    .subtitle {
        font-size: 0.9rem;
    }
    
    /* Botões menores */
    .btn-base {
        padding: 10px 15px;
        font-size: 0.9rem;
    }
    
    .generate-btn,
    .analyze-btn {
        padding: 12px;
        font-size: 0.9rem;
    }
    
    /* Inputs menores */
    .input-base {
        padding: 10px;
        font-size: 0.9rem;
    }
    
    .input-group textarea {
        padding: 12px;
        font-size: 0.9rem;
        min-height: 100px;
    }
    
    /* Cards menores */
    .card-base {
        padding: 20px;
    }
    
    .api-config,
    .text-input-section,
    .audio-section {
        padding: 20px;
    }
    
    /* Info cards */
    .info-card {
        padding: 15px;
    }
    
    .info-icon {
        font-size: 2rem;
    }
    
    /* Key management mobile */
    .key-item {
        padding: 10px;
        gap: 8px;
    }
    
    .key-actions {
        flex-direction: column;
        gap: 5px;
    }
    
    .key-action-btn {
        width: 28px;
        height: 28px;
        font-size: 0.9rem;
    }
    
    /* Toast mobile */
    .toast {
        padding: 10px 14px;
    }
    
    .toast-content {
        gap: 10px;
    }
    
    .toast-icon {
        font-size: 1.3rem;
    }
    
    .toast-message {
        font-size: 0.9rem;
    }
}

/* Large screens - 1200px e acima */
@media (min-width: 1200px) {
    .container {
        max-width: 1400px;
        padding: 30px;
    }
    
    .content-grid {
        gap: 40px;
    }
    
    .info-cards {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .humanization-features {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Ultra-wide screens - 1600px e acima */
@media (min-width: 1600px) {
    .container {
        max-width: 1600px;
    }
    
    .content-grid {
        grid-template-columns: 1fr 1.2fr;
    }
    
    .info-cards {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Landscape orientation em dispositivos móveis */
@media (max-width: 768px) and (orientation: landscape) {
    .app-header {
        margin-bottom: 20px;
    }
    
    .app-header h1 {
        font-size: 1.8rem;
    }
    
    .logo {
        flex-direction: row;
        gap: 15px;
    }
    
    .content-grid {
        grid-template-columns: 1fr 1fr;
        gap: 20px;
    }
}

/* Print styles */
@media print {
    .app-header,
    .app-footer,
    .loading-overlay,
    .toast-container {
        display: none !important;
    }
    
    .container {
        max-width: none;
        padding: 0;
    }
    
    .card-base {
        border: 1px solid #ccc;
        box-shadow: none;
        background: white;
        color: black;
    }
}