/* Import Google Font */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700&display=swap');

/* Root styles */
#ai-resume-root {
    font-family: "Poppins", sans-serif;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background: linear-gradient(135deg, #FF6B6B, #FFD93D, #e2a2ec, #4D96FF, #843BFF);
    background-size: 200% 200%;
    animation: gradientFlow 18s ease infinite;
    padding: 20px;
     border-radius: 10px;
    background-attachment: fixed;
}

/* Animated gradient */
@keyframes gradientFlow {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

/* Card container */
.resume-card {
    background: rgba(255, 255, 255, 0.92);
    padding: 60px 45px;
    border-radius: 24px;
    box-shadow: 0 18px 45px rgba(0,0,0,0.2);
    text-align: center;
    width: 90%;
    max-width: 900px;
    height: auto;
    min-height: 600px;
    backdrop-filter: blur(12px);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.resume-card:hover {
   
    box-shadow: 0 22px 60px rgba(0,0,0,0.25);
}

/* Title */
.resume-card h1 {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 14px;
    background: linear-gradient(90deg, #FF6B6B, #231992, #4D96FF);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.resume-card h2 {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 14px;
}

.resume-card h2 .blue {
    color: #0a08a5f4;
}

.resume-card h2 .yellow {
    color: #FFD400;
}

/* Subtitle */
.resume-card p {
    font-size: 1.1rem;
    margin-bottom: 40px;
    color: #333;
}

/* Shared button base */
.resume-card button {
    font-family: "Poppins", sans-serif;
    font-weight: 600;
    font-size: 1.05rem;
    padding: 14px 32px;
    margin: 10px;
    border-radius: 50px;
    border: none;
    cursor: pointer;
    transition: all 0.35s ease;
    position: relative;
    overflow: hidden;
}

/* Landing page button container
.landing-buttons {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    margin-top: 30px;
} */


/* Landing page button container */
.landing-buttons {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 50px;
    margin-top: 30px;
}

/* Mobile spacing for landing page */
@media (max-width: 768px) {
    .landing-buttons {
        gap: 28px;  /* More space between buttons */
        margin-top: 50px;  /* More space after tagline */
    }
    
    .resume-card h1 {
        margin-bottom: 24px !important;  /* More space after title */
        font-size: 2rem;
    }
    
    .resume-card h2 {
        margin-bottom: 20px !important;  /* More space after title */
    }
    
    .resume-card p {
        margin-bottom: 50px !important;  /* More space after paragraph/tagline */
        font-size: 1.05rem;
    }
    
    .landing-buttons button {
        padding: 16px 40px !important;  /* Slightly taller buttons */
    }
}

/* Landing page buttons specific styling */
.landing-buttons button {
    width: 100%;
    max-width: 320px;
    margin: 0;
    padding: 14px 40px;
    font-size: 1rem;
}

/* Start Button (gradient + glow) */
.resume-card #startBtn {
    background: linear-gradient(135deg, #FF6B6B, #FF8E53, #FFD93D);
    color: #fff;
    box-shadow: 0 6px 20px rgba(255, 107, 107, 0.4);
}

.resume-card #startBtn:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 8px 28px rgba(255, 107, 107, 0.6);
    background: linear-gradient(135deg, #FFD93D, #FF6B6B, #FF8E53);
}

/* Cover Letter Button (purple gradient + glow) */
.resume-card #coverLetterBtn {
    transition: all 0.35s ease;
    box-shadow: 0 6px 20px rgba(223, 102, 234, 0.4);
}

.resume-card #coverLetterBtn:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 8px 28px rgba(223, 102, 234, 0.6);
    background: linear-gradient(135deg, #a855f7, #df66eaff) !important;
}

/* LinkedIn Button (blue gradient + glow) */
.resume-card #linkedinBtn {
    transition: all 0.35s ease;
    box-shadow: 0 6px 20px rgba(0, 119, 181, 0.4);
}

.resume-card #linkedinBtn:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 8px 28px rgba(0, 119, 181, 0.6);
    background: linear-gradient(135deg, #00a0dc, #0077b5) !important;
}

/* Import Button (neon outline) */
.resume-card .import-btn {
    background: #fff;
    color: #4D96FF;
    border: 2px solid #4D96FF;
    box-shadow: 0 0 0 rgba(77,150,255,0);
}

.resume-card .import-btn:hover {
    background: #4D96FF;
    color: #fff;
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 0 18px rgba(77,150,255,0.6);
}

/* Form Styling */
.resume-form {
    text-align: left;
    max-width: 900px;
    width: 90%;
    padding: 40px 50px;
    height: auto;
    min-height: 680px;
    display: flex;
    flex-direction: column;
}

.resume-form h2 {
    text-align: center;
    margin-bottom: 25px;
    color: #333;
    flex-shrink: 0;
    font-size: 1.5rem;
    font-weight: 600;
}

/* Scrollable Content Area */
.form-content-scroll {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 15px;
    margin-bottom: 20px;
    min-height: 500px;
}

/* Custom Scrollbar */
.form-content-scroll::-webkit-scrollbar {
    width: 8px;
}

.form-content-scroll::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 10px;
}

.form-content-scroll::-webkit-scrollbar-thumb {
    background: #4D96FF;
    border-radius: 10px;
}

.form-content-scroll::-webkit-scrollbar-thumb:hover {
    background: #3d7cd9;
}

.resume-form .form-actions {
    flex-shrink: 0;
    margin-top: auto;
}

/* Grid Layout for Horizontal Form Fields */
.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
}

.form-group {
    display: flex;
    flex-direction: column;
}

.form-group.full-width {
    grid-column: 1 / -1;
}

/* Labels */
.form-group label,
.resume-form label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: #333;
    font-size: 0.95rem;
}

/* Inputs & textarea */
.form-group input,
.form-group textarea,
.resume-form input,
.resume-form textarea {
    width: 100%;
    padding: 12px 15px;
    border-radius: 12px;
    border: 2px solid #ddd;
    font-size: 1rem;
    font-family: "Poppins", sans-serif;
    transition: all 0.3s ease;
    box-sizing: border-box;
}

.form-group textarea,
.resume-form textarea {
    resize: vertical;
    min-height: 80px;
}

.form-group input:focus,
.form-group textarea:focus,
.resume-form input:focus,
.resume-form textarea:focus {
    outline: none;
    border-color: #4D96FF;
    box-shadow: 0 0 10px rgba(77,150,255,0.4);
}

/* Add More Button */
.add-more-btn {
    background: #fff;
    color: #6BCB77;
    border: 2px solid #6BCB77;
    padding: 10px 24px;
    font-size: 0.95rem;
    margin: 15px 0;
    display: block;
    width: fit-content;
}

.add-more-btn:hover {
    background: #6BCB77;
    color: #fff;
    transform: translateY(-2px);
}

/* Experience & Education Items */
.exp-item,
.edu-item {
    margin-bottom: 25px;
    padding-bottom: 20px;
}

.exp-item hr,
.edu-item hr {
    margin: 25px 0;
    border: none;
    border-top: 2px solid #eee;
}

.exp-item .removeExpBtn,
.edu-item .removeEduBtn {
    background: #fff;
    color: #FF6B6B;
    border: 2px solid #FF6B6B;
    padding: 8px 20px;
    font-size: 0.9rem;
    margin-top: 10px;
}

.exp-item .removeExpBtn:hover,
.edu-item .removeEduBtn:hover {
    background: #FF6B6B;
    color: #fff;
}

/* Skills Section - Compact Design */
.skill-input-row {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
    align-items: center;
}

.skill-input-row input {
    flex: 1;
    padding: 10px 14px;
    border-radius: 10px;
    border: 2px solid #ddd;
    font-size: 0.95rem;
    font-family: "Poppins", sans-serif;
    transition: all 0.3s ease;
}

.skill-input-row input:focus {
    outline: none;
    border-color: #4D96FF;
    box-shadow: 0 0 10px rgba(77,150,255,0.4);
}

.add-skill-btn {
    background: linear-gradient(135deg, #6BCB77, #4D96FF);
    color: #fff;
    padding: 10px 20px;
    font-size: 0.95rem;
    margin: 0;
    box-shadow: 0 4px 15px rgba(107, 203, 119, 0.3);
    border-radius: 10px;
    white-space: nowrap;
}

.add-skill-btn:hover {
    transform: translateY(-2px) scale(1.05);
    box-shadow: 0 6px 20px rgba(107, 109, 203, 0.5);
}

/* Skills List - Compact Pills */
.skills-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.skills-list li {
    display: inline-flex;
    align-items: center;
    background: linear-gradient(135deg, #f5f5f5, #e8e8e8);
    border: 2px solid #ddd;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 0.9rem;
    font-weight: 500;
    transition: all 0.3s ease;
}

/* LinkedIn skill tags styling */
#ai-linkedin-root .skill-tag {
    display: inline-flex !important;
    align-items: center !important;
    background: #e3f2fd !important;
    color: #1976d2 !important;
    padding: 6px 14px !important;
    border-radius: 20px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    margin: 4px !important;
    width: auto !important;
    max-width: fit-content !important;
}

#ai-linkedin-root #targetSkillTags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-top: 12px !important;
}

#ai-linkedin-root .remove-skill {
    background: none !important;
    border: none !important;
    color: #1976d2 !important;
    margin-left: 6px !important;
    cursor: pointer !important;
    font-size: 16px !important;
    font-weight: bold !important;
    padding: 0 !important;
    width: auto !important;
}

.skills-list li:hover {
    background: linear-gradient(135deg, #e8e8e8, #f5f5f5);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.remove-skill-btn {
    background: #FF6B6B;
    color: #fff;
    border: none;
   
    width: 5px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: 8px;
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    padding: 0;
    transition: all 0.2s ease;
}

.remove-skill-btn:hover {
    background: #ff5252;
    transform: scale(1.1);
}

/* Form buttons */
.resume-form .form-actions {
    display: flex;
    justify-content: space-between;
    margin-top: 0;
    gap: 10px;
}

.resume-form button {
    padding: 12px 26px;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 50px;
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    min-width: 120px;
}

/* Back button */
.resume-form #backLandingBtn,
.resume-form #backBtn,
.resume-form #backSummaryBtn,
.resume-form #backExpBtn,
.resume-form #backEduBtn,
.resume-form #backSkillsBtn,
.resume-form #backTemplateBtn,
.resume-form #backAchBtn {
    background: #fff;
    color: #4D96FF;
    border: 2px solid #4D96FF;
    margin: 0;
    padding: 12px 26px;
    font-size: 1rem;
}

.resume-form #backLandingBtn:hover,
.resume-form #backBtn:hover,
.resume-form #backSummaryBtn:hover,
.resume-form #backExpBtn:hover,
.resume-form #backEduBtn:hover,
.resume-form #backSkillsBtn:hover,
.resume-form #backTemplateBtn:hover,
.resume-form #backAchBtn:hover {
    background: #4D96FF;
    color: #fff;
}

/* Next button */
.resume-form #nextBtn,
.resume-form #finishBtn,
.resume-form #nextTemplateBtn {
    background: linear-gradient(135deg, #FF6B6B, #FFD93D);
    color: #fff;
    box-shadow: 0 6px 20px rgba(255, 107, 107, 0.4);
    margin: 0;
    padding: 12px 26px;
    font-size: 1rem;
}

.resume-form #nextBtn:hover,
.resume-form #finishBtn:hover,
.resume-form #nextTemplateBtn:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 8px 28px rgba(255, 107, 107, 0.6);
}

/* AI Improve Button - Enhanced Prominence */
.resume-form #aiImproveBtn,
.resume-form .ai-enhance-btn {
    background: linear-gradient(135deg, #843BFF, #FF6B6B);
    color: #fff;
    box-shadow: 0 8px 25px rgba(132, 59, 255, 0.5);
    margin: 0;
    font-size: 1.05rem;
    padding: 14px 30px;
    position: relative;
    overflow: hidden;
}

.resume-form #aiImproveBtn::before,
.resume-form .ai-enhance-btn::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: linear-gradient(45deg, transparent, rgba(255,255,255,0.3), transparent);
    transform: rotate(45deg);
    animation: shimmer 3s infinite;
}

@keyframes shimmer {
    0% { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
    100% { transform: translateX(100%) translateY(100%) rotate(45deg); }
}

.resume-form #aiImproveBtn:hover,
.resume-form .ai-enhance-btn:hover {
    transform: translateY(-3px) scale(1.08);
    box-shadow: 0 12px 35px rgba(132, 59, 255, 0.7);
    background: linear-gradient(135deg, #9d5fff, #ff8a8a);
}

/* Template Selection */
.template-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
    margin: 20px 0;
    padding: 10px;
}

.template-box {
    background: #fff;
    border: 2px solid #ddd;
    border-radius: 12px;
    padding: 20px;
    text-align: center;
    cursor: pointer;
    transition: all 0.25s ease-in-out;
    box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}

.template-box:hover {
    transform: translateY(-5px);
    border-color: #4CAF50;
    box-shadow: 0 6px 14px rgba(0,0,0,0.12);
}

.template-box h3 {
    margin-bottom: 8px;
    font-size: 1.2rem;
    color: #333;
}

.template-box p {
    font-size: 0.9rem;
    color: #555;
}

.template-box.selected {
    border-color: #2196F3;
    background: #f0f8ff;
    box-shadow: 0 6px 16px rgba(33, 150, 243, 0.3);
    transform: translateY(-5px) scale(1.02);
}

/* Disabled state */
#nextTemplateBtn:disabled {
    background: #ccc;
    color: #666;
    cursor: not-allowed;
    box-shadow: none;
}

/* Active state */
#nextTemplateBtn:not(:disabled) {
    background: #2196F3;
    color: #fff;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(33,150,243,0.4);
    transition: all 0.25s ease-in-out;
}

#nextTemplateBtn:not(:disabled):hover {
    background: #1976D2;
    box-shadow: 0 6px 14px rgba(25,118,210,0.5);
}

/* Download button animation styles */
.download-btn {
    transition: all 0.3s ease;
    background: #007cba !important;
    color: white !important;
}

.download-btn:hover {
    background: #5a60b8 !important;
    transform: translateY(-2px);
    color: white !important;
}

/* Ensure proper printing */
@media print {
    #resume-template-1,
    #resume-template-2, 
    #resume-template-3,
    #resume-template-4 {
        max-width: 100% !important;
        margin: 0 !important;
        padding: 20px !important;
    }
    
    .resume-form,
    .resume-card:not(#resume-template-1):not(#resume-template-2):not(#resume-template-3):not(#resume-template-4) {
        display: none !important;
    }
}

/* Template specific print fixes */
#resume-template-4 {
    page-break-inside: avoid;
}

#resume-template-1 h1,
#resume-template-2 h1,
#resume-template-3 h1,
#resume-template-4 h1 {
    color: #000 !important;
}

/* PDF Export Specific Styles */
#hiddenPreview {
    position: absolute !important;
    left: -9999px !important;
    top: 0 !important;
    width: 800px !important;
    visibility: visible !important;
    opacity: 1 !important;
}

#hiddenPreview #resume-template-1,
#hiddenPreview #resume-template-2,
#hiddenPreview #resume-template-3,
#hiddenPreview #resume-template-4 {
    width: 800px !important;
    max-width: 800px !important;
    margin: 0 !important;
    padding: 40px !important;
    background: white !important;
    display: block !important;
    position: relative !important;
    box-shadow: none !important;
}

/* Ensure all template content is visible for PDF */
#resume-template-1 *,
#resume-template-2 *,
#resume-template-3 *,
#resume-template-4 * {
    visibility: visible !important;
    opacity: 1 !important;
}

/* Fix flexbox for PDF rendering */
#resume-template-1 div[style*="display: flex"],
#resume-template-2 div[style*="display: flex"],
#resume-template-3 div[style*="display: flex"],
#resume-template-4 div[style*="display: flex"] {
    display: flex !important;
}

/* Achievement items spacing */
.achievement-item {
    margin-bottom: 20px;
    padding-bottom: 15px;
}

.achievement-item hr {
    margin: 20px 0;
    border: none;
    border-top: 2px solid #eee;
}

.achievement-item .removeAchBtn {
    background: #fff;
    color: #FF6B6B;
    border: 2px solid #FF6B6B;
    padding: 8px 20px;
    font-size: 0.9rem;
    margin-top: 10px;
}

.achievement-item .removeAchBtn:hover {
    background: #FF6B6B;
    color: #fff;
}

/* Template preview styling */
.template-preview-container {
    margin-top: 24px;
    padding: 20px;
    background: #8782ba;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    max-height: 400px;
    overflow-y: auto;
    overflow-x: hidden;
}

/* Custom Scrollbar for template preview */
.template-preview-container::-webkit-scrollbar {
    width: 8px;
}

.template-preview-container::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.2);
    border-radius: 10px;
}

.template-preview-container::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.5);
    border-radius: 10px;
}

.template-preview-container::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.7);
}

.template-preview-image {
    max-width: 500px;
    margin: 0 auto;
    background: white;
    padding: 16px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.template-preview-image img {
    width: 100%;
    height: auto;
    display: block;
    border: 1px solid #ddd;
    border-radius: 4px;
}

/* FIXED HEIGHT PREVIEW FORM (scrollable content) */
.resume-card.resume-form {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 700px;
    max-height: 700px;
    overflow: hidden;
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

/* Fixed bottom action buttons */
.form-actions {
    display: flex;
    justify-content: space-between;
    padding: 15px 20px;

    background: transparent;
    position: sticky;
    bottom: 0;
    z-index: 5;
}

/* Keyword tags */
.keyword-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 20px 0;
    padding: 16px;
    border: 1px solid #ddd;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

.keyword-tag {
    background: #f3f4f6;
    border: 1px solid #e5e7eb;
    color: #333;
    font-size: 14px;
    padding: 6px 10px;
    border-radius: 8px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.1);
    transition: all 0.2s ease-in-out;
}

.keyword-tag:hover {
    background: #e0e7ff;
    border-color: #6366f1;
    color: #1e3a8a;
    transform: scale(1.05);
}

/* COVER LETTER ROOT */
#ai-cover-letter-root {
    font-family: "Poppins", sans-serif;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background: linear-gradient(135deg, #FF6B6B, #FFD93D, #e2a2ec, #4D96FF, #843BFF);
    background-size: 500% 500%;
    animation: gradientFlow 18s ease infinite;
    padding: 20px;
    overflow: auto;
    border-radius: 2%;
}

/* Cover Letter Card */
#ai-cover-letter-root .resume-card {
    background: rgba(255, 255, 255, 0.92);
    padding: 40px 45px;
    border-radius: 24px;
    box-shadow: 0 18px 45px rgba(0,0,0,0.2);
    width: 85%;
    max-width: 850px;
    height: 85vh;
    max-height: 85vh;
    backdrop-filter: blur(12px);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    margin: auto;
}

#ai-cover-letter-root .resume-card:hover {
  
    box-shadow: 0 22px 60px rgba(0,0,0,0.25);
}

#ai-cover-letter-root .resume-card h2 {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 8px;
    flex-shrink: 0;
    text-align: center;
}

#ai-cover-letter-root .resume-card h2 .blue {
    color: #0a08a5f4;
}

#ai-cover-letter-root .resume-card h2 .yellow {
    color: #FFD400;
}

#ai-cover-letter-root .resume-card h1 {
    font-size: 1.4rem;
    font-weight: 700;
    margin-top: 5px;
    margin-bottom: 15px;
    flex-shrink: 0;
    text-align: center;
}

#ai-cover-letter-root .form-content-scroll {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 10px;
    margin-top: 10px;
    margin-bottom: 15px;
}

#ai-cover-letter-root .form-content-scroll::-webkit-scrollbar {
    width: 8px;
}

#ai-cover-letter-root .form-content-scroll::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 10px;
}

#ai-cover-letter-root .form-content-scroll::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 10px;
}

#ai-cover-letter-root .form-content-scroll::-webkit-scrollbar-thumb:hover {
    background: #555;
}

#ai-cover-letter-root .form-actions {
    margin-top: auto;
    padding-top: 20px;
    /* border-top: 1px solid #eee; */
    display: flex;
    gap: 15px;
    justify-content: flex-start;
    flex-shrink: 0;
    flex-wrap: wrap;
}

#ai-cover-letter-root .form-group {
    margin-bottom: 20px;
}

#ai-cover-letter-root .form-group.full-width {
    width: 100%;
}

#ai-cover-letter-root input,
#ai-cover-letter-root textarea {
    width: 100%;
    box-sizing: border-box;
    font-family: "Poppins", sans-serif;
}

#ai-cover-letter-root label {
    display: block;
    margin-bottom: 8px;
}

#ai-cover-letter-root .resume-card.resume-form {
    text-align: left;
}

/* LINKEDIN ROOT */
#ai-linkedin-root {
    font-family: "Poppins", sans-serif;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background: linear-gradient(135deg, #FF6B6B, #FFD93D, #e2a2ec, #4D96FF, #843BFF);
    background-size: 500% 500%;
    animation: gradientFlow 18s ease infinite;
    padding: 20px;
    overflow: auto;
    border-radius: 2%;
}

/* LinkedIn Card */
#ai-linkedin-root .resume-card {
    background: rgba(255, 255, 255, 0.92);
    padding: 40px 45px;
    border-radius: 24px;
    box-shadow: 0 18px 45px rgba(0,0,0,0.2);
    width: 85%;
    max-width: 850px;
    height: 85vh;
    max-height: 85vh;
    backdrop-filter: blur(12px);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    margin: auto;
}

#ai-linkedin-root .resume-card:hover {
   
    box-shadow: 0 22px 60px rgba(0,0,0,0.25);
}

#ai-linkedin-root .resume-card h2 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 8px;
    flex-shrink: 0;
    text-align: center;
}

#ai-linkedin-root .resume-card h1 {
    font-size: 1.4rem;
    font-weight: 700;
    margin-top: 5px;
    margin-bottom: 15px;
    flex-shrink: 0;
    text-align: center;
}

#ai-linkedin-root .form-content-scroll,
#ai-linkedin-root .linkedin-results-scroll-area {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 10px;
    margin-top: 10px;
    margin-bottom: 15px;
}

#ai-linkedin-root .form-content-scroll::-webkit-scrollbar,
#ai-linkedin-root .linkedin-results-scroll-area::-webkit-scrollbar {
    width: 8px;
}

#ai-linkedin-root .form-content-scroll::-webkit-scrollbar-track,
#ai-linkedin-root .linkedin-results-scroll-area::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 10px;
}

#ai-linkedin-root .form-content-scroll::-webkit-scrollbar-thumb,
#ai-linkedin-root .linkedin-results-scroll-area::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 10px;
}

#ai-linkedin-root .form-content-scroll::-webkit-scrollbar-thumb:hover,
#ai-linkedin-root .linkedin-results-scroll-area::-webkit-scrollbar-thumb:hover {
    background: #555;
}

#ai-linkedin-root .form-actions,
#ai-linkedin-root .linkedin-results-button-section {
    margin-top: auto;
    padding-top: 20px;
    border-top: none;
    display: flex;
    gap: 30px;
  justify-content: center;  /* Changed from space-between */
    align-items: center; 
    flex-shrink: 0;
    flex-wrap: wrap;
}

.optimization-section {
    margin-bottom: 30px;
    padding: 20px;
    background: #f8f9fa;
    border-radius: 12px;
    border: 1px solid #e0e0e0;
}

.optimization-section h3 {
    margin: 0 0 15px 0;
    color: #0077b5;
    font-size: 1.1rem;
    font-weight: 600;
}

.optimization-section .section-description {
    margin: 10px 0 0 0;
    color: #666;
    font-size: 13px;
    font-style: italic;
}

.optimized-content {
    margin-top: 10px;
}

#ai-linkedin-root .form-group {
    margin-bottom: 20px;
}

#ai-linkedin-root .form-group label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: #333;
    font-size: 0.95rem;
}

#ai-linkedin-root .form-group input,
#ai-linkedin-root .form-group textarea,
#ai-linkedin-root .form-group select {
    width: 100%;
    padding: 12px 15px;
    border-radius: 12px;
    border: 2px solid #ddd;
    font-size: 1rem;
    font-family: "Poppins", sans-serif;
    transition: all 0.3s ease;
    box-sizing: border-box;
}

#ai-linkedin-root .form-group input:focus,
#ai-linkedin-root .form-group textarea:focus,
#ai-linkedin-root .form-group select:focus {
    outline: none;
    border-color: #0077b5;
    box-shadow: 0 0 10px rgba(0, 119, 181, 0.4);
}

/* Reset styles when switching between tools */
#ai-resume-root,
#ai-cover-letter-root,
#ai-linkedin-root {
    position: relative;
    width: 100%;
    min-height: 100vh;
    overflow: visible;
}

.resume-card {
    position: relative;
    z-index: 1;
}

body.ai-resume-active {
    overflow: auto;
    position: relative;
}



/* Cover Letter - Back Button */
#ai-cover-letter-root .resume-card button#backLandingBtn {
    background: #fff !important;
    color: #4D96FF !important;
    border: 2px solid #4D96FF !important;
    padding: 12px 26px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    min-width: 120px !important;
}

#ai-cover-letter-root .resume-card button#backLandingBtn:hover {
    background: #4D96FF !important;
    color: #fff !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 4px 12px rgba(77, 150, 255, 0.4) !important;
}

/* Cover Letter - Generate Button */
#ai-cover-letter-root .resume-card button#generateBtn:not(:disabled) {
    background: linear-gradient(135deg, #FF6B6B, #FFD93D) !important;
    color: #fff !important;
    border: none !important;
    padding: 12px 26px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    box-shadow: 0 6px 20px rgba(255, 107, 107, 0.4) !important;
    min-width: 120px !important;
}


/* Desktop: Position buttons at opposite ends */
@media (min-width: 769px) {
    #ai-cover-letter-root .resume-card .form-actions {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        width: 100% !important;
    }
}

#ai-cover-letter-root .resume-card button#generateBtn:not(:disabled):hover {
    transform: translateY(-3px) scale(1.05) !important;
    box-shadow: 0 8px 28px rgba(255, 107, 107, 0.6) !important;
}

#ai-cover-letter-root .resume-card button#generateBtn:disabled {
    background: #ccc !important;
    color: #666 !important;
    cursor: not-allowed !important;
    box-shadow: none !important;
}

/* Cover Letter - Change Resume Button */
#ai-cover-letter-root .resume-card button#changeResumeBtn {
    background: #fff !important;
    color: #4D96FF !important;
    border: 2px solid #4D96FF !important;
    padding: 12px 26px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    min-width: 180px !important;
    box-shadow: none !important;
}

#ai-cover-letter-root .resume-card button#changeResumeBtn:hover {
    background: #4D96FF !important;
    color: #fff !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 4px 12px rgba(77, 150, 255, 0.4) !important;
}

/* Cover Letter - Copy Button */
#ai-cover-letter-root .resume-card button#copyCoverLetterBtn {
    background: linear-gradient(135deg, #843BFF, #FF6B6B) !important;
    color: #fff !important;
    border: none !important;
    padding: 14px 30px !important;
    font-size: 1.05rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    box-shadow: 0 8px 25px rgba(132, 59, 255, 0.5) !important;
    min-width: 180px !important;
    position: relative !important;
    overflow: hidden !important;
}

#ai-cover-letter-root .resume-card button#copyCoverLetterBtn::before {
    content: '' !important;
    position: absolute !important;
    top: -50% !important;
    left: -50% !important;
    width: 200% !important;
    height: 200% !important;
    background: linear-gradient(45deg, transparent, rgba(255,255,255,0.3), transparent) !important;
    transform: rotate(45deg) !important;
    animation: shimmer 3s infinite !important;
}

#ai-cover-letter-root .resume-card button#copyCoverLetterBtn:hover {
    transform: translateY(-3px) scale(1.08) !important;
    box-shadow: 0 12px 35px rgba(132, 59, 255, 0.7) !important;
    background: linear-gradient(135deg, #9d5fff, #ff8a8a) !important;
}

/* LinkedIn - All Back Buttons */
#ai-linkedin-root .resume-card button#backLinkedInLandingBtn,
#ai-linkedin-root .resume-card button#backToProfileInfoFromExpBtn,
#ai-linkedin-root .resume-card button#backToExperienceBtn,
#ai-linkedin-root .resume-card button#backToResumeUploadBtn,
#ai-linkedin-root .resume-card button#backToCareerGoalsBtn {
    background: #fff !important;
    color: #4D96FF !important;
    border: 2px solid #4D96FF !important;
    padding: 12px 26px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    min-width: 120px !important;
}

#ai-linkedin-root .resume-card button#backLinkedInLandingBtn:hover,
#ai-linkedin-root .resume-card button#backToProfileInfoFromExpBtn:hover,
#ai-linkedin-root .resume-card button#backToExperienceBtn:hover,
#ai-linkedin-root .resume-card button#backToResumeUploadBtn:hover,
#ai-linkedin-root .resume-card button#backToCareerGoalsBtn:hover {
    background: #4D96FF !important;
    color: #fff !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 4px 12px rgba(77, 150, 255, 0.4) !important;
}

/* LinkedIn - All Next Buttons */
#ai-linkedin-root .resume-card button#nextToExperienceBtn,
#ai-linkedin-root .resume-card button#nextToResumeUploadFromExpBtn,
#ai-linkedin-root .resume-card button#nextToCareerGoalsBtn,
#ai-linkedin-root .resume-card button#finishLinkedInBtn {
    background: linear-gradient(135deg, #FF6B6B, #FFD93D) !important;
    color: #fff !important;
    border: none !important;
    padding: 12px 26px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    box-shadow: 0 6px 20px rgba(255, 107, 107, 0.4) !important;
    min-width: 120px !important;
}

#ai-linkedin-root .resume-card button#nextToExperienceBtn:hover,
#ai-linkedin-root .resume-card button#nextToResumeUploadFromExpBtn:hover,
#ai-linkedin-root .resume-card button#nextToCareerGoalsBtn:hover,
#ai-linkedin-root .resume-card button#finishLinkedInBtn:hover {
    transform: translateY(-3px) scale(1.05) !important;
    box-shadow: 0 8px 28px rgba(255, 107, 107, 0.6) !important;
}

/* LinkedIn - Analyze & Optimize Button */
#ai-linkedin-root .resume-card button#analyzeLinkedInBtn {
    background: linear-gradient(135deg, #843BFF, #FF6B6B) !important;
    color: #fff !important;
    border: none !important;
    padding: 14px 30px !important;
    font-size: 1.05rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    box-shadow: 0 8px 25px rgba(132, 59, 255, 0.5) !important;
    margin-left: auto !important;
    position: relative !important;
    overflow: hidden !important;
}

#ai-linkedin-root .resume-card button#analyzeLinkedInBtn::before {
    content: '' !important;
    position: absolute !important;
    top: -50% !important;
    left: -50% !important;
    width: 200% !important;
    height: 200% !important;
    background: linear-gradient(45deg, transparent, rgba(255,255,255,0.3), transparent) !important;
    transform: rotate(45deg) !important;
    animation: shimmer 3s infinite !important;
}

#ai-linkedin-root .resume-card button#analyzeLinkedInBtn:hover {
    transform: translateY(-3px) scale(1.08) !important;
    box-shadow: 0 12px 35px rgba(132, 59, 255, 0.7) !important;
    background: linear-gradient(135deg, #9d5fff, #ff8a8a) !important;
}

/* LinkedIn - Skip Button */
#ai-linkedin-root .resume-card button#skipResumeBtn {
    background: #fff !important;
    color: #6BCB77 !important;
    border: 2px solid #6BCB77 !important;
    padding: 12px 26px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    min-width: 120px !important;
}

#ai-linkedin-root .resume-card button#skipResumeBtn:hover {
    background: #6BCB77 !important;
    color: #fff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(107, 203, 119, 0.4) !important;
}

/* LinkedIn - Start Optimization Button */
#ai-linkedin-root .resume-card button#startLinkedInBtn {
    background: linear-gradient(135deg, #FF6B6B, #FF8E53, #FFD93D) !important;
    color: #fff !important;
    border: none !important;
    padding: 12px 24px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.35s ease !important;
    font-family: "Poppins", sans-serif !important;
    box-shadow: 0 6px 20px rgba(255, 107, 107, 0.4) !important;
    width: 280px !important;
}

#ai-linkedin-root .resume-card button#startLinkedInBtn:hover {
    transform: translateY(-3px) scale(1.05) !important;
    box-shadow: 0 8px 28px rgba(255, 107, 107, 0.6) !important;
    background: linear-gradient(135deg, #FFD93D, #FF6B6B, #FF8E53) !important;
}

/* LinkedIn - Add Experience Button */
#ai-linkedin-root button#addExperienceBtn {
    background: #fff !important;
    color: #6BCB77 !important;
    border: 2px solid #6BCB77 !important;
    padding: 10px 24px !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    width: fit-content !important;
    margin: 15px 0 !important;
    display: block !important;
}

#ai-linkedin-root button#addExperienceBtn:hover {
    background: #6BCB77 !important;
    color: #fff !important;
    transform: translateY(-2px) !important;
}

/* LinkedIn - Remove Experience Button */
#ai-linkedin-root button.remove-experience-btn {
    background: #fff !important;
    color: #FF6B6B !important;
    border: 2px solid #FF6B6B !important;
    padding: 8px 20px !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    margin-top: 10px !important;
}

#ai-linkedin-root button.remove-experience-btn:hover {
    background: #FF6B6B !important;
    color: #fff !important;
    transform: translateY(-2px) !important;
}

/* LinkedIn - Select Resume Button */
#ai-linkedin-root button#selectResumeBtn {
    background: #fff !important;
    color: #4D96FF !important;
    border: 2px solid #4D96FF !important;
    padding: 12px 24px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
}

#ai-linkedin-root button#selectResumeBtn:hover {
    background: #4D96FF !important;
    color: #fff !important;
    transform: translateY(-3px) scale(1.05) !important;
    box-shadow: 0 0 18px rgba(77,150,255,0.6) !important;
}

/* LinkedIn - Add Skill Button */
#ai-linkedin-root button#addTargetSkillBtn,
#ai-linkedin-root button.add-more-btn {
    background: linear-gradient(135deg, #6BCB77, #4D96FF) !important;
    color: #fff !important;
    border: none !important;
    padding: 10px 20px !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    box-shadow: 0 4px 15px rgba(107, 203, 119, 0.3) !important;
    white-space: nowrap !important;
    margin: 0 !important;
}

#ai-linkedin-root button#addTargetSkillBtn:hover,
#ai-linkedin-root button.add-more-btn:hover {
    transform: translateY(-2px) scale(1.05) !important;
    box-shadow: 0 6px 20px rgba(107, 203, 119, 0.5) !important;
}

/* LinkedIn - Remove Skill Button */
#ai-linkedin-root button.remove-skill {
    background: #FF6B6B !important;
    color: #fff !important;
    border: none !important;
    border-radius: 50% !important;
    width: 18px !important;
    height: 18px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-left: 8px !important;
    cursor: pointer !important;
    font-size: 14px !important;
    font-weight: bold !important;
    padding: 0 !important;
    transition: all 0.2s ease !important;
}

#ai-linkedin-root button.remove-skill:hover {
    background: #ff5252 !important;
    transform: scale(1.1) !important;
}

/* LinkedIn - Copy Buttons */
#ai-linkedin-root button.copy-btn {
    background: #fff !important;
    color: #4D96FF !important;
    border: 2px solid #4D96FF !important;
    padding: 8px 16px !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "Poppins", sans-serif !important;
    margin-top: 8px !important;
}

#ai-linkedin-root button.copy-btn:hover {
    background: #4D96FF !important;
    color: #fff !important;
    transform: translateY(-2px) !important;
}

/* Force spacing for LinkedIn results buttons */
#ai-linkedin-root .linkedin-results-button-section .form-actions {
    display: flex !important;
    justify-content: space-between !important;
    gap: 25px !important;
    width: 100% !important;
}

#ai-linkedin-root .resume-card button#finishLinkedInBtn {
    margin-left: 0 !important;
}

/* RESPONSIVE BREAKPOINTS */

/* Large tablets and small desktops (1024px and below) */
@media (max-width: 1024px) {
    .resume-card {
        width: 90%;
        padding: 50px 35px;
        min-height: 550px;
    }

    .resume-form {
        width: 90%;
        padding: 35px 40px;
    }

    .resume-card.resume-form {
        height: 600px;
        max-height: 600px;
    }

    .form-content-scroll {
        padding: 16px;
    }

    .form-grid {
        gap: 18px;
    }

    .template-preview-container {
        max-height: 380px;
    }

    .template-preview-image {
        max-width: 400px;
    }
}

/* Tablets (768px and below) */
@media (max-width: 768px) {
    .resume-card {
        min-height: auto;
        padding: 40px 25px;
        width: 95%;
        height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
    }


       #ai-linkedin-root .skill-input-row {
        flex-direction: column !important;
        gap: 10px !important;
    }

    #ai-linkedin-root .skill-input-row input {
        width: 100% !important;
        flex: none !important;
    }

    #ai-linkedin-root .skill-input-row button,
    #ai-linkedin-root button#addTargetSkillBtn {
        width: 100% !important;
    }

    .resume-form {
        width: 95%;
        max-width: 95%;
        padding: 30px 25px;
    }

    .resume-card.resume-form {
        height: 550px;
        max-height: 550px;
    }

    .resume-card h1 {
        font-size: 2rem;
    }

    .resume-card h2 {
        font-size: 2.0rem !important;
        padding-bottom: 30px;
    }

    .form-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .form-actions {
        flex-direction: column;
        gap: 10px;
    }

    .form-actions button {
        width: 100%;
        margin: 0;
    }

    .skill-input-row {
        flex-direction: column;
    }

    .skill-input-row input,
    .skill-input-row button {
        width: 100%;
    }

    .template-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .template-preview-container {
        padding: 15px;
        max-height: 350px;
    }

    .template-preview-image {
        max-width: 100%;
        padding: 12px;
    }

    /* Cover Letter Buttons */
    #ai-cover-letter-root .resume-card button#backLandingBtn,
    #ai-cover-letter-root .resume-card button#generateBtn,
    #ai-cover-letter-root .resume-card button#changeResumeBtn,
    #ai-cover-letter-root .resume-card button#copyCoverLetterBtn {
        width: 100% !important;
        margin: 5px 0 !important;
    }

    /* LinkedIn Buttons */
    #ai-linkedin-root .resume-card button {
        width: 100% !important;
        margin: 5px 0 !important;
        min-width: auto !important;
    }

    #ai-linkedin-root .resume-card .form-actions {
        flex-direction: column !important;
        gap: 10px !important;
    }

    /* Fix skill input to be full width on separate lines */
    #ai-linkedin-root .skill-input-row {
        flex-direction: column !important;
        gap: 10px !important;
    }

    #ai-linkedin-root .skill-input-row input {
        width: 100% !important;
    }

    #ai-linkedin-root .skill-input-row button,
    #ai-linkedin-root button#addTargetSkillBtn {
        width: 100% !important;
    }

    /* Center Back and Complete buttons on results page */
  /* Center Back and Complete buttons on results page - MOBILE */
#ai-linkedin-root .linkedin-results-button-section {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-direction: column !important;
    gap: 15px !important;
    padding: 20px !important;
}

#ai-linkedin-root .linkedin-results-button-section .form-actions {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-direction: column !important;
    width: 100% !important;
    gap: 15px !important;
    margin: 0 !important;
    padding: 0 !important;
}

#ai-linkedin-root .linkedin-results-button-section .form-actions button {
    width: 100% !important;
    max-width: 280px !important;
    margin: 0 auto !important;
}

#ai-linkedin-root .linkedin-results-button-section button {
    width: 100% !important;
    max-width: 280px !important;
    margin: 0 auto !important;
}
    #ai-linkedin-root .resume-card {
        width: 95%;
        padding: 30px 25px;
      height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
    }


    #ai-linkedin-root .resume-card.resume-form {
    height: calc(100vh - 30px) !important;
    max-height: calc(100vh - 30px) !important;
}
    #ai-cover-letter-root .resume-card {
        width: 95%;
        padding: 30px 25px;
          height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
    }
}

/* Small tablets and large phones (600px and below) */
@media (max-width: 600px) {
    #ai-resume-root {
        padding: 15px;
    }

    #ai-linkedin-root .skill-input-row {
    flex-direction: column !important;
}

#ai-linkedin-root .skill-input-row input,
#ai-linkedin-root .skill-input-row button {
    width: 100% !important;
}

    .resume-card {
        padding: 30px 20px;
        border-radius: 16px;
         height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
    }

    .resume-form {
        padding: 25px 20px;
    }

    .resume-card.resume-form {
        height: 900px;
        max-height: 900px;
    }

    .resume-card h1 {
        font-size: 1.6rem;
    }

    .resume-card h2 {
        font-size: 1.2rem;
    }

    .resume-card p {
        font-size: 1rem;
    }

    .resume-card button {
        font-size: 0.95rem;
        padding: 12px 24px;
    }

    .form-content-scroll {
        padding-right: 10px;
        min-height: 400px;
    }

    .landing-buttons button {
        max-width: 100%;
        padding: 12px 30px;
    }

    .template-box {
        padding: 18px;
    }

    .template-box h3 {
        font-size: 1.1rem;
    }

    .template-preview-container {
        max-height: 320px;
    }

    .form-group input,
    .form-group textarea,
    .resume-form input,
    .resume-form textarea {
        font-size: 0.95rem;
        padding: 10px 12px;
    }

    #ai-linkedin-root .resume-card {
        width: 95%;
        padding: 25px 20px;
        height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
    }

    #ai-linkedin-root .resume-card.resume-form {
    height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
}

    #ai-cover-letter-root .resume-card {
        width: 95%;
        padding: 25px 20px;
          height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
    }
}

/* Small phones (480px and below) */
@media (max-width: 480px) {
    .resume-card {
        padding: 25px 15px;
        min-height: auto;
          height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
    }



    #ai-linkedin-root .skill-input-row {
    flex-direction: column !important;
}

#ai-linkedin-root .skill-input-row input,
#ai-linkedin-root .skill-input-row button {
    width: 100% !important;
}

    .resume-form {
        padding: 20px 15px;
    }

    .resume-card.resume-form {
        height: 750px;
        max-height: 750px;
    }

    .resume-card h1 {
        font-size: 1.4rem;
        margin-bottom: 10px;
    }

    .resume-card h2 {
        font-size: 1.1rem;
        margin-bottom: 15px;
    }

    .resume-card p {
        font-size: 0.9rem;
        margin-bottom: 30px;
    }

    .resume-card button {
        font-size: 0.9rem;
        padding: 10px 20px;
        margin: 8px;
    }

    .resume-form button {
        font-size: 0.9rem;
        padding: 10px 20px;
        min-width: 100px;
    }

    .form-content-scroll {
        min-height: 350px;
    }

    .form-group label,
    .resume-form label {
        font-size: 0.9rem;
    }

    .template-box {
        padding: 15px;
    }

    .template-box h3 {
        font-size: 1rem;
    }

    .template-box p {
        font-size: 0.85rem;
    }

    .add-more-btn,
    .exp-item .removeExpBtn,
    .edu-item .removeEduBtn,
    .achievement-item .removeAchBtn {
        font-size: 0.85rem;
        padding: 8px 16px;
    }

    .skills-list li {
        font-size: 0.85rem;
        padding: 5px 10px;
    }

    .template-preview-container {
        padding: 10px;
        max-height: 300px;
    }

    .template-preview-image {
        padding: 8px;
    }

    #ai-cover-letter-root .resume-card button,
    #ai-linkedin-root .resume-card button {
        font-size: 0.9rem !important;
        padding: 10px 20px !important;
        min-width: 100px !important;
    }

    #ai-cover-letter-root .resume-card button#copyCoverLetterBtn,
    #ai-linkedin-root .resume-card button#analyzeLinkedInBtn {
        font-size: 0.95rem !important;
        padding: 12px 24px !important;
    }

    #ai-linkedin-root .resume-card {
        padding: 20px 15px;
         height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
    }

    #ai-linkedin-root .resume-card.resume-form {
    height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
}

    #ai-cover-letter-root .resume-card {
        padding: 20px 15px;
          height: calc(100vh - 30px);
    max-height: calc(100vh - 30px);
    }
}

/* Extra small phones (360px and below) */
@media (max-width: 360px) {
    .resume-card {
        padding: 20px 12px;
    }

    .resume-form {
        padding: 18px 12px;
    }

    .resume-card.resume-form {
        height: 400px;
        max-height: 400px;
    }

    .resume-card h1 {
        font-size: 1.2rem;
    }

    .resume-card h2 {
        font-size: 1rem;
    }

    .resume-card button {
        font-size: 0.85rem;
        padding: 8px 16px;
    }

    .form-content-scroll {
        min-height: 300px;
    }

    .template-preview-container {
        max-height: 280px;
    }
}

/* Landscape orientation fixes for mobile devices */
@media (max-height: 500px) and (orientation: landscape) {
    .resume-card {
        min-height: auto;
        padding: 20px 25px;
    }

    .resume-form {
        min-height: auto;
        padding: 20px 25px;
    }

    .resume-card.resume-form {
        height: 350px;
        max-height: 350px;
    }

    .form-content-scroll {
        min-height: 250px;
    }

    .template-preview-container {
        max-height: 250px;
    }
}


/* === Landing Page Mobile Center Fix === */
@media (max-width: 768px) {
  .career-tool-container,
  .ai-tool-section,
  .ai-tool-card {
    width: 95% !important;
    max-width: 480px !important;
    margin: 0 auto !important;
    background: #fff !important;
    border-radius: 12px !important;
    padding: 20px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  }

  .ai-tool-section h1,
  .ai-tool-section h2,
  .ai-tool-section p {
    text-align: center !important;
    word-break: break-word;
  }

  .ai-tool-buttons,
  .ai-tool-section .btn-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .ai-tool-buttons a,
  .ai-tool-section button {
    width: 100% !important;
    max-width: 350px !important;
    text-align: center;
    font-size: 16px !important;
    padding: 12px !important;
  }

  body,
  html {
    overflow-x: hidden !important;
  }
}

@media (max-width: 480px) {
  .career-tool-container,
  .ai-tool-card {
    padding: 15px !important;
    border-radius: 10px !important;
  }

  .ai-tool-section h1,
  .ai-tool-section h2 {
    font-size: 1.3rem !important;
  }
}



/* === AI Resume Builder Mobile Responsiveness Fix === */
@media (max-width: 768px) {
  .resume-builder-container,
  .builder-wrapper,
  .builder-section,
  .builder-form,
  .form-step,
  .resume-step-content {
    width: 95% !important;
    max-width: 480px !important;
    margin: 0 auto !important;
    background: #fff !important;
    border-radius: 10px !important;
    padding: 20px !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
  }

  .builder-section h2,
  .form-step h2,
  .builder-form h3 {
    text-align: center !important;
    font-size: 1.25rem !important;
    margin-bottom: 15px !important;
  }

  .builder-form input,
  .builder-form textarea,
  .builder-form select {
    width: 100% !important;
    box-sizing: border-box;
    margin-bottom: 15px !important;
    font-size: 16px !important;
  }

  .builder-form button,
  .resume-builder-container button {
    width: 100% !important;
    font-size: 16px !important;
    padding: 12px !important;
    margin-top: 10px !important;
  }

  .builder-progress,
  .step-indicator {
    width: 100% !important;
    text-align: center !important;
    margin-bottom: 15px !important;
  }

  body,
  html {
    overflow-x: hidden !important;
  }
}

@media (max-width: 480px) {
  .resume-builder-container,
  .builder-wrapper,
  .builder-form {
    padding: 15px !important;
    border-radius: 8px !important;
  }

  .builder-form input,
  .builder-form textarea {
    font-size: 15px !important;
  }

  button,
  .builder-form button {
    font-size: 15px !important;
    padding: 10px !important;
  }

  h2, h3 {
    font-size: 1.1rem !important;
  }
}
/* === Ultra Small Devices (below 320px) === */
@media (max-width: 319px) {
  .career-tool-container,
  .ai-tool-section,
  .ai-tool-card,
  .resume-builder-container,
  .builder-wrapper,
  .builder-form {
    width: 98% !important;
    max-width: none !important;
    margin: 0 auto !important;
    padding: 10px !important;
    border-radius: 8px !important;
  }

  h1, h2, h3, p {
    font-size: 0.95rem !important;
    line-height: 1.3 !important;
    text-align: center !important;
  }

  .builder-form input,
  .builder-form textarea,
  .builder-form select {
    font-size: 14px !important;
    padding: 8px !important;
  }

  button,
  .builder-form button,
  .ai-tool-section button {
    font-size: 14px !important;
    padding: 9px !important;
    width: 100% !important;
  }

  /* Prevent scroll and overflow */
  body, html {
    overflow-x: hidden !important;
  }
}
/* === Mobile Form Size Alignment with Gradient Box === */
@media (max-width: 768px) {
  /* Adjust main white form width inside gradient */
  .resume-builder-container,
  .builder-wrapper,
  .builder-section,
  .builder-form,
  .form-step,
  .resume-step-content {
    width: 92% !important; /* fills more of the gradient */
    max-width: 500px !important;
    margin: 0 auto !important;
    background: #fff !important;
    border-radius: 18px !important;
    padding: 25px 20px !important;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.08);
  }

  /* Keep inside spacing comfortable */
  .builder-form input,
  .builder-form textarea,
  .builder-form select {
    width: 100% !important;
    font-size: 16px !important;
    margin-bottom: 15px !important;
  }

  /* Buttons full width with proper gap */
  .builder-form button,
  .resume-builder-container button {
    width: 100% !important;
    padding: 12px !important;
    font-size: 16px !important;
    border-radius: 10px !important;
  }

  /* Center headings */
  .builder-section h2,
  .form-step h2,
  .builder-form h3 {
    text-align: center !important;
    font-size: 1.3rem !important;
  }

  /* Keep everything scrollable without breaking layout */
  body,
  html {
    overflow-x: hidden !important;
  }
}

@media (max-width: 480px) {
  .resume-builder-container,
  .builder-form {
    width: 94% !important;
    padding: 20px 16px !important;
    border-radius: 15px !important;
  }
}

@media (max-width: 319px) {
  .resume-builder-container,
  .builder-form {
    width: 96% !important;
    padding: 16px 12px !important;
  }
}
/* === Extra small screens: 300px–359px === */
@media (max-width: 359px) {
  .resume-builder-container,
  .builder-wrapper,
  .builder-section,
  .builder-form,
  .form-step,
  .resume-step-content {
    width: 95% !important;   /* fills almost entire gradient area */
    max-width: none !important;
    margin: 0 auto !important;
    padding: 16px 12px !important;
    border-radius: 14px !important;
  }

  .builder-form input,
  .builder-form textarea,
  .builder-form select {
    width: 100% !important;
    font-size: 15px !important;
    margin-bottom: 12px !important;
  }

  .builder-form button,
  .resume-builder-container button {
    width: 100% !important;
    padding: 10px !important;
    font-size: 15px !important;
    border-radius: 9px !important;
  }

  .builder-section h2,
  .form-step h2,
  .builder-form h3 {
    text-align: center !important;
    font-size: 1.2rem !important;
  }

  body,
  html {
    overflow-x: hidden !important;
  }
}



/* 🔧 Universal mobile fix for forms — buttons pinned to bottom */
@media (max-width: 768px) {
  form,
  .resume-form,
  .form-container,
  .form-wrapper {
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    min-height: 100vh !important;
    box-sizing: border-box !important;
    padding-bottom: 0 !important;
  }

  /* Make form content scrollable if needed */
  .form-body,
  .form-content,
  .resume-form-content {
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    margin-bottom: 0 !important;
  }

  /* Buttons wrapper always at the bottom */
  .form-actions,
  .resume-form-buttons,
  .form-buttons,
  .button-group {
    flex-shrink: 0 !important;
    margin-top: auto !important;
    padding-bottom: 0 !important;
    display: flex !important;
    flex-direction: column;
    gap: 10px;
    align-items: center;
    justify-content: center;
  }

  /* Individual buttons — full width on mobile */
  button,
  .form-actions button,
  .form-buttons button {
    width: 100% !important;
    max-width: 320px;
    margin: 0 auto !important;
  }
}

/* Ultra-small devices (below 360px) */
@media (max-width: 360px) {
  form,
  .resume-form,
  .form-container {
    padding: 12px 10px !important;
  }

  .form-buttons,
  .form-actions {
    gap: 8px !important;
  }

  button {
    font-size: 14px !important;
    padding: 10px 0 !important;
  }
}












@media (max-width: 480px) {
    /* Reduce heading size only */
    .resume-card h1,
    .resume-card h2 {
        font-size: 1.0rem !important;
    }

    /* Allow more scroll area on small screens */
    .resume-card {
        height: 90vh !important;
        overflow-y: auto !important;
    }
}





/* ✅ Mobile adjustments for the "Add Skills" section only */
@media (max-width: 480px) {
  /* Target the flex container wrapping the input and button */
  .resume-form .form-group[style*="display: flex"] {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
  }

  /* Make the input take full width */
  #skillInput {
    width: 100% !important;
    flex: unset !important;
    font-size: 14px !important;
    padding: 10px !important;
  }

  #addSkillBtn {
    width: 100% !important;
    text-align: center !important;
    font-size: 14px !important;
    padding: 10px !important;
  }
}










@media (max-width: 480px) {


  .resume-card.resume-form h2 {
    margin-bottom: 6px !important;    
    font-size: 1rem !important;       
    line-height: 1.05 !important;
  }

  .resume-card.resume-form h1 {
    margin-top: 4px !important;      
    font-size: 1.15rem !important;    
    line-height: 1.15 !important;
    margin-bottom: 6px !important;
  }


  .resume-card.resume-form {
    
    height: calc(100vh - 28px) !important;
    max-height: calc(100vh - 28px) !important;
    padding-top: 14px !important;   
    padding-bottom: 10px !important;
  }

  
  .resume-card.resume-form .form-content-scroll {
    margin-top: 6px !important;
    padding-right: 8px !important;
    max-height: calc(100vh - 220px) !important; 
    overflow-y: auto !important;
  }

 
  .resume-card.resume-form .form-group.full-width > div[style*="display: flex"] {
    display: block !important;
    gap: 10px !important;
  }

  .resume-card.resume-form #skillInput,
  .resume-card.resume-form .skill-input-row input,
  .resume-card.resume-form .form-group.full-width input[type="text"],
  .resume-card.resume-form .form-group.full-width input[type="url"],
  .resume-card.resume-form .form-group.full-width textarea {
    width: 100% !important;
    box-sizing: border-box !important;
    margin-bottom: 8px !important;
    padding: 12px !important;
    border-radius: 12px !important;
  }

  /* Place Add button on new line, full width (but keep its look) */
  .resume-card.resume-form #addSkillBtn,
  .resume-card.resume-form .add-more-btn {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 12px !important;
    border-radius: 12px !important;
    box-sizing: border-box !important;
  }


  html, body {
    overflow-x: hidden !important;
  
  }


  ::-webkit-scrollbar {
    height: 0 !important;    
    width: 0 !important;     
  }

  /* But re-enable scrollbar for inner scrollable areas (form content) */
  .resume-card.resume-form .form-content-scroll::-webkit-scrollbar {
    width: 8px !important;
    height: 8px !important;
  }
  .resume-card.resume-form .form-content-scroll::-webkit-scrollbar-thumb {
    background: #4D96FF !important;
    border-radius: 10px !important;
  }
}

/* Extra tiny screens: keep consistent behaviour on 300–359 px */
@media (max-width: 359px) {
  .resume-card.resume-form {
    padding-top: 10px !important;
    padding-bottom: 8px !important;
    height: calc(100vh - 18px) !important;
    max-height: calc(100vh - 18px) !important;
  }

  .resume-card.resume-form .form-content-scroll {
    max-height: calc(100vh - 200px) !important;
    padding-right: 6px !important;
  }

  .resume-card.resume-form h1 { font-size: 1.05rem !important; }
  .resume-card.resume-form h2 { font-size: 0.98rem !important; }
}




/* Decrease size of "Upload Your Resume *" only on mobile */
@media (max-width: 480px) {
  .resume-card.resume-form label[for="resumeUpload"] {
    font-size: 0.95rem !important;
    font-weight: 600 !important;
  }
}

/* Extra small screens (optional fine-tuning for ~320px) */
@media (max-width: 360px) {
  .resume-card.resume-form label[for="resumeUpload"] {
    font-size: 0.9rem !important;
  }
}








/* === MOBILE VIEW FIXES FOR COVER LETTER TOOL === */
@media (max-width: 480px) {

  /* Smaller Copy Button */
  #copyCoverLetterBtn {
    padding: 10px 18px !important;
    font-size: 14px !important;
    min-width: 140px !important;
    border-radius: 8px !important;
  }

  /* Smaller Finish Button to match Copy Button */
  #finishCoverLetterBtn {
    padding: 10px 18px !important;
    font-size: 14px !important;
    min-width: 140px !important;
    border-radius: 8px !important;
  }

  /* Fix white form output to blend perfectly into gradient box */
  #coverLetterPreview {
    background: #ffffff !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    border: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 15px !important;
  }

  /* Ensure spacing around the preview looks clean */
  .form-content-scroll {
    padding: 0 10px !important;
  }
}





@media (max-width: 480px) {
  #ai-resume-root .resume-card.resume-form {
    width: 99.5% !important;    
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 12px !important;
    border-radius: 0 !important;
  }

  #ai-resume-root .form-content-scroll {
    width: 100% !important;
    padding: 0 4px !important;   
  }

  #ai-resume-root input,
  #ai-resume-root textarea {
    width: 100% !important;
  }
}


@media (max-width: 360px) {
  #ai-resume-root .resume-card.resume-form {
    width: 100% !important;    
    padding: 10px !important;
    border-radius: 0 !important;
  }
}






@media (max-width: 480px) {
  #ai-cover-letter-root .resume-card.resume-form {
    width: 99.5% !important;       
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 12px !important;
    border-radius: 0 !important;   
  }

  #ai-cover-letter-root .form-content-scroll {
    width: 100% !important;
    padding: 0 4px !important;
  }
}

/* For very small screens */
@media (max-width: 360px) {
  #ai-cover-letter-root .resume-card.resume-form {
    width: 100% !important;
    padding: 10px !important;
  }
}





/* === LinkedIn Mobile Form Expansion Fix === */
@media (max-width: 480px) {
  #ai-linkedin-root .resume-card {
    width: 99.5% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 12px !important;
    border-radius: 0 !important;
  }

  #ai-linkedin-root .resume-card.resume-form {
    width: 99.5% !important;
    max-width: 100% !important;
    height: calc(100vh - 28px) !important;
    max-height: calc(100vh - 28px) !important;
  }

  #ai-linkedin-root .form-content-scroll {
    width: 100% !important;
    padding: 0 4px !important;
  }

  #ai-linkedin-root h1 {
    font-size: 1.4rem !important;
    font-weight: 700 !important;
  }

  #ai-linkedin-root p {
    color: #120707ff !important;
    font-weight: 600 !important;
  }

  #ai-linkedin-root .landing-buttons {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    gap: 10px;
    margin-top: 18px;
  }

  #ai-linkedin-root #startLinkedInBtn {
    width: 100% !important;
    max-width: 320px !important;
    padding: 12px 24px !important;
    font-size: 14px !important;
    background: linear-gradient(135deg, #7b61ff, #a855f7) !important;
    color: white !important;
    border: none !important;
    border-radius: 50px !important;
  }

  #ai-linkedin-root #backToResumeBtn {
    padding: 10px 20px !important;
    font-size: 12px !important;
    color: #0d0e15ff !important;
    background: none !important;
    border: none !important;
  }

  #ai-linkedin-root button {
    width: 100% !important;
    max-width: 320px !important;
  }
}

@media (max-width: 360px) {
  #ai-linkedin-root .resume-card {
    width: 100% !important;
    padding: 10px !important;
  }
}









#ai-resume-root,
#ai-cover-letter-root,
#ai-linkedin-root {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  box-sizing: border-box;
}

/* === Mobile LinkedIn Results Fix === */
@media (max-width: 768px) {
  
  /* Hide the circle, show only score number */
  #ai-linkedin-root .resume-card > div > div > svg {
    display: none !important;
  }
  
  #ai-linkedin-root #scoreNumber {
    position: static !important;
    transform: none !important;
    font-size: 2.5rem !important;
    display: block !important;
    margin: 0 !important;
    line-height: 1 !important;
  }
  
  /* Make score section very small & compact */
  #ai-linkedin-root .resume-card > div[style*="padding: 18px"] {
    padding: 12px 15px !important;
    margin-bottom: 10px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 100px !important;
  }
  
  /* Title smaller */
  #ai-linkedin-root .resume-card > div[style*="padding: 18px"] h3 {
    font-size: 0.9rem !important;
    margin: 0 0 8px 0 !important;
  }
  
  /* Score display container - centered */
  #ai-linkedin-root .resume-card > div[style*="padding: 18px"] > div {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2px !important;
  }
  
  /* "Out of 100" text very close to score */
  #ai-linkedin-root .resume-card > div[style*="padding: 18px"] > p {
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
    font-size: 13px !important;
  }
  
  /* Give more space to scrollable content */
  #ai-linkedin-root .linkedin-results-scroll-area {
    flex: 1 !important;
    max-height: calc(100vh - 250px) !important;
    overflow-y: auto !important;
    padding-bottom: 80px !important;
  }
  
  /* Fix buttons to bottom of page (not scroll area) */
  #ai-linkedin-root .linkedin-results-button-section {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    background: white !important;
    padding: 12px 15px !important;
    margin: 0 !important;
    box-shadow: 0 -2px 10px rgba(0,0,0,0.1) !important;
    z-index: 100 !important;
  }
  
  #ai-linkedin-root .linkedin-results-button-section .form-actions {
    margin: 0 !important;
    max-width: 500px !important;
    margin: 0 auto !important;
  }
}