/* Mobile Responsive Styles - Generator Page */

@media only screen and (max-width: 768px) {
    body.generator-page {
        padding-top: 78px !important;
        padding-bottom: 30px !important;
    }
    
    .generator-section {
        padding: 24px 0 !important;
    }
    
    .container-narrow {
        max-width: 100% !important;
        padding: 0 16px !important;
        margin: 0 auto !important;
    }
    
    .generator-header {
        margin-bottom: 24px !important;
        text-align: center !important;
    }
    
    .generator-header h1 {
        font-size: 1.65rem !important;
        line-height: 1.25 !important;
        margin-bottom: 10px !important;
        font-weight: 800 !important;
    }
    
    .generator-header p {
        font-size: 0.9rem !important;
        line-height: 1.5 !important;
        opacity: 0.9 !important;
    }
    
    .generator-card {
        padding: 24px 20px !important;
        border-radius: 20px !important;
        margin: 0 !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .form-grid {
        gap: 24px !important;
    }
    
    .form-section {
        margin-bottom: 0 !important;
    }
    
    .form-section-title {
        font-size: 1.15rem !important;
        margin-bottom: 16px !important;
        gap: 10px !important;
        display: flex !important;
        align-items: center !important;
    }
    
    .section-icon {
        width: 22px !important;
        height: 22px !important;
        flex-shrink: 0 !important;
    }
    
    .form-row {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 16px !important;
        margin-bottom: 16px !important;
    }
    
    .form-group {
        gap: 8px !important;
        width: 100% !important;
    }
    
    .form-group label {
        font-size: 0.9rem !important;
        font-weight: 600 !important;
        display: block !important;
    }
    
    .form-group input,
    .form-group select {
        width: 100% !important;
        padding: 14px 16px !important;
        font-size: 16px !important;
        border-radius: 12px !important;
        box-sizing: border-box !important;
    }
    
    .form-hint {
        font-size: 0.8rem !important;
        margin-top: 4px !important;
    }
    
    .form-actions {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        margin-top: 24px !important;
        padding-top: 24px !important;
        width: 100% !important;
    }
    
    .form-actions button {
        width: 100% !important;
        padding: 15px 20px !important;
        box-sizing: border-box !important;
    }
    
    .btn-secondary,
    .btn-primary {
        padding: 15px 20px !important;
        font-size: 0.95rem !important;
        border-radius: 12px !important;
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
    }
    
    .captcha-container {
        padding: 12px !important;
        margin-top: 24px !important;
        border-radius: 14px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
        box-sizing: border-box !important;
    }
    
    .cf-turnstile {
        transform: scale(0.9) !important;
        transform-origin: center !important;
        margin: 0 auto !important;
        max-width: 100% !important;
    }
    
    .captcha-hint {
        margin-top: 10px !important;
        text-align: center !important;
    }
    
    .navbar-generator {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        z-index: 1000 !important;
        padding: 12px 0 !important;
        background: rgba(10, 10, 15, 0.95) !important;
        backdrop-filter: blur(12px) !important;
        -webkit-backdrop-filter: blur(12px) !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
    }
    
    .nav-content {
        padding: 0 16px !important;
    }
    
    .brand-icon {
        width: 38px !important;
        height: 38px !important;
    }
    
    .brand-icon svg {
        width: 28px !important;
        height: 28px !important;
    }
    
    .brand-name {
        font-size: 1.25rem !important;
    }
    
    .brand-tag {
        font-size: 0.65rem !important;
    }
    
    .btn-nav {
        padding: 8px 16px !important;
        font-size: 0.85rem !important;
        border-radius: 10px !important;
    }
    
    .btn-nav svg {
        width: 16px !important;
        height: 16px !important;
    }
    
    .loading-state,
    .results-state,
    .error-state {
        padding: 20px 16px !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .loading-animation {
        margin-bottom: 24px !important;
        width: 100% !important;
        display: flex !important;
        justify-content: center !important;
    }
    
    .loading-state h3,
    .results-state h3 {
        font-size: 1.4rem !important;
        margin-bottom: 10px !important;
        text-align: center !important;
    }
    
    .loading-state p,
    .results-state p {
        font-size: 0.9rem !important;
        text-align: center !important;
        margin-bottom: 20px !important;
    }
    
    .progress-steps {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        width: 100% !important;
        margin-top: 24px !important;
    }
    
    .progress-step {
        padding: 14px 16px !important;
        width: 100% !important;
        box-sizing: border-box !important;
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
    }
    
    .step-number {
        width: 32px !important;
        height: 32px !important;
        font-size: 0.9rem !important;
        flex-shrink: 0 !important;
    }
    
    .step-icon {
        width: 24px !important;
        height: 24px !important;
        flex-shrink: 0 !important;
    }
    
    .step-label {
        font-size: 0.9rem !important;
    }
    
    .download-cards {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        width: 100% !important;
        margin: 24px 0 !important;
    }
    
    .download-card {
        padding: 16px !important;
        width: 100% !important;
        box-sizing: border-box !important;
        display: flex !important;
        align-items: center !important;
        gap: 14px !important;
        position: relative !important;
    }
    
    .download-card::before {
        pointer-events: none !important;
    }
    
    .download-icon {
        font-size: 2rem !important;
        flex-shrink: 0 !important;
    }
    
    .download-info {
        flex: 1 !important;
        min-width: 0 !important;
    }
    
    .download-info h4 {
        font-size: 0.95rem !important;
        margin-bottom: 4px !important;
    }
    
    .download-info p {
        font-size: 0.8rem !important;
        margin: 0 !important;
    }
    
    .btn-download {
        padding: 10px 16px !important;
        font-size: 0.85rem !important;
        white-space: nowrap !important;
        flex-shrink: 0 !important;
        pointer-events: auto !important;
        position: relative !important;
        z-index: 10 !important;
        cursor: pointer !important;
        touch-action: manipulation !important;
        -webkit-tap-highlight-color: rgba(0, 212, 255, 0.3) !important;
    }
    
    .next-steps {
        padding: 20px 16px !important;
        margin: 24px 0 !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .next-steps h4 {
        font-size: 1.1rem !important;
        margin-bottom: 14px !important;
    }
    
    .next-steps ol {
        padding-left: 24px !important;
        margin-bottom: 16px !important;
    }
    
    .next-steps li {
        font-size: 0.9rem !important;
        line-height: 1.6 !important;
        margin-bottom: 10px !important;
    }
    
    .next-steps .note {
        font-size: 0.85rem !important;
        padding: 12px 14px !important;
        margin-top: 16px !important;
    }
    
    .success-animation {
        margin-bottom: 20px !important;
        display: flex !important;
        justify-content: center !important;
    }
    
    .checkmark {
        width: 60px !important;
        height: 60px !important;
    }
    
    .teacher-name {
        font-size: 1.05rem !important;
        margin-bottom: 20px !important;
        text-align: center !important;
    }
    
    #generate-again-btn {
        width: 100% !important;
        margin-top: 20px !important;
        padding: 14px 20px !important;
    }
}

@media only screen and (max-width: 480px) {
    body.generator-page {
        padding-top: 70px !important;
    }
    
    .container-narrow {
        padding: 0 14px !important;
    }
    
    .generator-header h1 {
        font-size: 1.45rem !important;
    }
    
    .generator-header p {
        font-size: 0.85rem !important;
    }
    
    .generator-card {
        padding: 20px 16px !important;
        border-radius: 18px !important;
    }
    
    .form-grid {
        gap: 20px !important;
    }
    
    .form-section-title {
        font-size: 1.05rem !important;
        margin-bottom: 14px !important;
    }
    
    .section-icon {
        width: 20px !important;
        height: 20px !important;
    }
    
    .form-row {
        gap: 14px !important;
    }
    
    .form-group label {
        font-size: 0.85rem !important;
    }
    
    .form-group input,
    .form-group select {
        font-size: 15px !important;
        padding: 13px 14px !important;
    }
    
    .form-actions {
        gap: 10px !important;
        margin-top: 20px !important;
        padding-top: 20px !important;
    }
    
    .btn-secondary,
    .btn-primary {
        padding: 14px 18px !important;
        font-size: 0.9rem !important;
    }
    
    .cf-turnstile {
        transform: scale(0.82) !important;
    }
    
    .captcha-container {
        padding: 10px 8px !important;
    }
    
    .brand-icon {
        width: 34px !important;
        height: 34px !important;
    }
    
    .brand-icon svg {
        width: 26px !important;
        height: 26px !important;
    }
    
    .brand-name {
        font-size: 1.15rem !important;
    }
    
    .loading-state h3,
    .results-state h3 {
        font-size: 1.25rem !important;
    }
    
    .progress-step {
        padding: 12px 14px !important;
    }
    
    .download-card {
        padding: 14px !important;
        gap: 12px !important;
    }
    
    .btn-download {
        min-width: 80px !important;
        text-align: center !important;
    }
    
    .download-icon {
        font-size: 1.75rem !important;
    }
    
    .next-steps {
        padding: 18px 14px !important;
    }
    
    .next-steps h4 {
        font-size: 1rem !important;
    }
    
    .next-steps li {
        font-size: 0.85rem !important;
    }
}
