/* Custom styles for Bappi Portfolio */

/* Import Poppins font with all weights */
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

/* CSS Custom Properties */
:root {
    --primary: #159957;
    --secondary: #155e91;
}

/* Reset and base styles */
* {
    box-sizing: border-box;
    /* Remove tap highlight on mobile devices */
    -webkit-tap-highlight-color: transparent;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

/* Allow text selection for specific elements */
p, span, h1, h2, h3, h4, h5, h6, li, td, th, input, textarea {
    -webkit-user-select: text;
    -khtml-user-select: text;
    -moz-user-select: text;
    -ms-user-select: text;
    user-select: text;
}

/* Hide scrollbar globally */
::-webkit-scrollbar {
    width: 0px;
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: transparent;
}

/* Firefox scrollbar hiding */
html {
    scrollbar-width: none;
}

/* For specific containers that need scroll but hidden scrollbar */
.scroll-hidden {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.scroll-hidden::-webkit-scrollbar {
    display: none;
}

/* No smooth scrolling */
html {
    scroll-behavior: auto;
}

body {
    font-family: 'Poppins', sans-serif;
    line-height: 1.6;
    color: #000;
    background-color: #fff;
}

/* Custom gradient backgrounds */
.gradient-bg {
    background: linear-gradient(135deg, #159957 0%, #155e91 100%);
}

.gradient-text {
    background: linear-gradient(135deg, #159957 0%, #155e91 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Button styles */
.btn-primary {
    background: linear-gradient(135deg, #159957 0%, #155e91 100%) !important;
    color: white !important;
    padding: 12px 24px !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 500 !important;
    font-size: 16px !important;
    border: none !important;
    cursor: pointer !important;
    min-height: 44px !important;
    text-align: center !important;
    transition: all 0.4s ease !important;
}

.btn-primary:hover {
    background: linear-gradient(135deg, #155e91 0%, #159957 100%) !important;
    color: white !important;
}

.btn-outline {
    border: 2px solid #159957 !important;
    color: #159957 !important;
    padding: 10px 22px !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 500 !important;
    font-size: 16px !important;
    background: transparent !important;
    cursor: pointer !important;
    min-height: 44px !important;
    text-align: center !important;
    transition: all 0.4s ease !important;
}

.btn-outline:hover {
    background: white !important;
    color: #155e91 !important;
    border-color: #155e91 !important;
}

/* Card styles */
.card {
    background: white !important;
    border-radius: 16px !important;
    padding: 24px !important;
    margin-bottom: 24px !important;
    border: 1px solid #deefff !important;
}

/* Project card styles */
.project-card {
    background: white !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    margin-bottom: 24px !important;
    border: 1px solid #e2f0fd !important;
}

.project-card img {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

/* Skill badge styles */
.skill-badge {
    background: white;
    color: black;
    border: 1px solid gray ;
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    font-size: 0.875rem;
    font-weight: 500;
    display: inline-block;
    margin: 0.25rem;
}

/* Form styles */
.form-input {
    width: 100% !important;
    padding: 12px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    font-family: 'Poppins', sans-serif !important;
}

.form-input:focus {
    outline: none !important;
    border-color: #159957 !important;
}

.form-textarea {
    width: 100% !important;
    padding: 12px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    resize: vertical !important;
    min-height: 120px !important;
    font-family: 'Poppins', sans-serif !important;
}

.form-textarea:focus {
    outline: none !important;
    border-color: #159957 !important;
}

/* Loading animation - removed */
.loading {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid #f3f3f3;
    border-top: 3px solid #159957;
    border-radius: 50%;
}

/* Hero section styles */
.hero-bg {
    background: linear-gradient(135deg, rgba(21, 153, 87, 0.1) 0%, rgba(21, 94, 145, 0.1) 100%);
}

/* Typewriter effect styles */
.typewriter-cursor {
    display: inline-block;
    animation: blink 1s infinite;
    font-weight: 400;
    margin-left: 2px;
    color: #159957;
}

@keyframes blink {
    0%, 50% {
        opacity: 1;
    }
    51%, 100% {
        opacity: 0;
    }
}

.typewriter-text {
    display: inline-block;
}

/* Section spacing */
.section-padding {
    padding: 64px 0 !important;
}

/* Container spacing */
.container-spacing {
    padding: 0 20px !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
}

/* Page spacing */
.page-container {
    min-height: 100vh !important;
    padding: 20px !important;
}

/* Content spacing */
.content-spacing {
    margin-bottom: 32px !important;
}

.content-spacing-lg {
    margin-bottom: 48px !important;
}

/* Responsive text sizes */
@media (max-width: 640px) {
    .hero-title {
        font-size: 2rem !important;
        line-height: 1.2 !important;
    }
    
    .hero-subtitle {
        font-size: 1.125rem !important;
    }
    
    .btn-primary, .btn-outline {
        width: 100% !important;
        margin-bottom: 12px !important;
        padding: 14px 20px !important;
        font-size: 16px !important;
    }
    
    .card {
        padding: 20px !important;
        margin-bottom: 20px !important;
    }
    
    .section-padding {
        padding: 40px 0 !important;
    }
    
    h1 {
        font-size: 2rem !important;
    }
    
    h2 {
        font-size: 1.75rem !important;
    }
    
    h3 {
        font-size: 1.25rem !important;
    }
}

@media (max-width: 768px) {
    .btn-primary, .btn-outline {
        min-width: 200px !important;
    }
}

/* Admin panel styles */
.admin-nav {
    background: white;
}

/* Ensure all admin nav text and icons are white */
.admin-nav * {
    color: rgb(2, 2, 2) !important;
}

.admin-nav a {
    color: white !important;
}

.admin-nav i {
    color: rgb(2, 2, 2) !important;
}

.admin-nav button {
    color: rgb(2, 2, 2) !important;
}

/* Hover states */
.admin-nav a:hover {
    color: #fde047 !important; /* yellow-300 */
}

.admin-nav button:hover {
    color: #fde047 !important; /* yellow-300 */
}

.admin-card {
    background: white !important;
    border-radius: 8px !important;
    padding: 24px !important;
    border: 1px solid #f1f5f9 !important;
}

.admin-btn {
    background: linear-gradient(135deg, #159957 0%, #155e91 100%) !important;
    color: white !important;
    padding: 8px 16px !important;
    border-radius: 6px !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    border: none !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.admin-btn-danger {
    background: #dc2626 !important;
    color: white !important;
    padding: 8px 16px !important;
    border-radius: 6px !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    border: none !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Table styles */
.admin-table {
    width: 100% !important;
    border-collapse: collapse !important;
    background: white !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    border: 1px solid #f1f5f9 !important;
}

.admin-table th,
.admin-table td {
    padding: 12px !important;
    text-align: left !important;
    border-bottom: 1px solid #e5e7eb !important;
}

.admin-table th {
    background: #f9fafb !important;
    font-weight: 600 !important;
}

/* Message styles */
.message-success {
    background: #d1fae5;
    color: #065f46;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    border-left: 4px solid #10b981;
}

.message-error {
    background: #fee2e2;
    color: #991b1b;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    border-left: 4px solid #ef4444;
}

/* Navigation improvements */
nav a {
    text-decoration: none !important;
}

/* Default navigation link color */
nav a:not(.nav-active-gradient) {
    color: black !important;
}

/* Hover effect for non-gradient links */
nav a:not(.nav-active-gradient):hover {
    color: var(--primary) !important;
}

/* Navigation gradient active state */
nav a.nav-active-gradient {
    background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    font-weight: 600 !important;
}

/* Logo gradient text */
.logo-gradient {
    background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

/* Typography improvements */
h1, h2, h3, h4, h5, h6 {
    font-weight: 600 !important;
    line-height: 1.3 !important;
    margin-bottom: 16px !important;
}

h1 {
    font-size: 2.5rem !important;
}

h2 {
    font-size: 2rem !important;
}

h3 {
    font-size: 1.5rem !important;
}

p {
    margin-bottom: 16px !important;
    line-height: 1.6 !important;
}

/* Link improvements */
a {
    color: #159957 !important;
    text-decoration: none !important;
}

/* Form improvements */
input, textarea, select {
    font-family: 'Poppins', sans-serif !important;
}

/* Spacing utilities */
.mb-4 {
    margin-bottom: 16px !important;
}

.mb-6 {
    margin-bottom: 24px !important;
}

.mb-8 {
    margin-bottom: 32px !important;
}

.mt-4 {
    margin-top: 16px !important;
}

.mt-6 {
    margin-top: 24px !important;
}

.mt-8 {
    margin-top: 32px !important;
}

.py-4 {
    padding-top: 16px !important;
    padding-bottom: 16px !important;
}

.py-6 {
    padding-top: 24px !important;
    padding-bottom: 24px !important;
}

.py-8 {
    padding-top: 32px !important;
    padding-bottom: 32px !important;
}

.px-4 {
    padding-left: 16px !important;
    padding-right: 16px !important;
}

.px-6 {
    padding-left: 24px !important;
    padding-right: 24px !important;
}

.px-8 {
    padding-left: 32px !important;
    padding-right: 32px !important;
}
