/** * Five Stars Jobs - Main Stylesheet * Light Theme - Modern & Professional */ /* ============================================ CSS Variables ============================================ */:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#3b82f6;--secondary:#f59e0b;--secondary-dark:#d97706;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#06b6d4;--white:#ffffff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--bg-primary:var(--white);--bg-secondary:var(--gray-50);--bg-card:var(--white);--text-primary:var(--gray-900);--text-secondary:var(--gray-600);--text-muted:var(--gray-500);--border-color:var(--gray-200);--border-radius:12px;--border-radius-lg:16px;--border-radius-xl:24px;--shadow-sm:0 1px 2px rgba(0,0,0,0.05);--shadow:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -2px rgba(0,0,0,0.1);--shadow-md:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -4px rgba(0,0,0,0.1);--shadow-lg:0 20px 25px -5px rgba(0,0,0,0.1),0 8px 10px -6px rgba(0,0,0,0.1);--shadow-xl:0 25px 50px -12px rgba(0,0,0,0.25);--font-sans:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--font-display:'Plus Jakarta Sans',sans-serif;--transition-fast:150ms ease;--transition:200ms ease;--transition-slow:300ms ease;--container-max:1320px;--header-height:80px}/* ============================================ Reset & Base ============================================ */ *,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--text-primary);background:var(--bg-secondary);min-height:100vh}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--primary-dark)}img{max-width:100%;height:auto;display:block}button{cursor:pointer;font-family:inherit}input,select,textarea,button{font-family:inherit;font-size:inherit}ul,ol{list-style:none}/* ============================================ Utilities ============================================ */ .container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 24px}.section{padding:80px 0}.section-header{text-align:center;margin-bottom:48px}.section-title{font-size:2.25rem;font-weight:800;color:var(--text-primary);margin-bottom:12px;letter-spacing:-0.02em}.section-subtitle{font-size:1.125rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.text-primary{color:var(--primary) !important}.text-secondary{color:var(--text-secondary) !important}.text-success{color:var(--success) !important}.text-warning{color:var(--warning) !important}.bg-primary{background-color:var(--primary) !important}.bg-secondary{background-color:var(--bg-secondary) !important}.bg-white{background-color:var(--white) !important}/* ============================================ Header ============================================ */ .header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,0.95);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);height:var(--header-height)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%}.logo{display:flex;align-items:center;gap:12px}.logo-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.logo-icon svg{width:100%;height:100%}.logo-text{font-size:1.375rem;font-weight:800;color:var(--text-primary);letter-spacing:-0.02em}.logo-text span{color:var(--primary)}.nav{display:flex;align-items:center;gap:8px}.nav-link{padding:10px 16px;font-size:0.9375rem;font-weight:500;color:var(--text-secondary);border-radius:8px;transition:all var(--transition)}.nav-link:hover,.nav-link.active{color:var(--primary);background:rgba(37,99,235,0.08)}.lang-switcher{display:flex;align-items:center;gap:4px;margin-left:16px;padding:4px;background:var(--gray-100);border-radius:8px}.lang-btn{padding:6px 12px;font-size:0.8125rem;font-weight:600;color:var(--text-secondary);background:transparent;border:none;border-radius:6px;transition:all var(--transition)}.lang-btn:hover{color:var(--text-primary)}.lang-btn.active{color:var(--primary);background:var(--white);box-shadow:var(--shadow-sm)}.menu-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-primary)}/* ============================================ Hero Slider ============================================ */ .hero{position:relative;padding:calc(var(--header-height) + 60px) 0 80px;background:linear-gradient(135deg,var(--gray-50) 0%,var(--white) 50%,rgba(37,99,235,0.03) 100%);overflow:hidden}.hero::before{content:'';position:absolute;top:0;right:-20%;width:60%;height:100%;background:radial-gradient(circle at center,rgba(37,99,235,0.08) 0%,transparent 70%);pointer-events:none}.hero-slider{position:relative;overflow:hidden}.hero-slides{display:flex;transition:transform 0.6s cubic-bezier(0.4,0,0.2,1)}.hero-slide{min-width:100%;padding:40px 0}.hero-content{max-width:700px;margin:0 auto;text-align:center;position:relative;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(37,99,235,0.1);border:1px solid rgba(37,99,235,0.2);border-radius:100px;font-size:0.875rem;font-weight:500;color:var(--primary);margin-bottom:24px}.hero-badge::before{content:'';width:8px;height:8px;background:var(--success);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.6;transform:scale(0.9)}}.hero-title{font-size:clamp(2.5rem,5vw,3.75rem);font-weight:800;color:var(--text-primary);line-height:1.1;letter-spacing:-0.03em;margin-bottom:20px}.hero-title span{color:var(--primary);position:relative}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary);line-height:1.7;margin-bottom:32px}.hero-cta{display:inline-flex;align-items:center;gap:8px;padding:16px 32px;font-size:1rem;font-weight:600;color:var(--white);background:var(--primary);border:none;border-radius:var(--border-radius);transition:all var(--transition);box-shadow:0 4px 14px rgba(37,99,235,0.3)}.hero-cta:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 25px rgba(37,99,235,0.35);color:var(--white)}.slider-dots{display:flex;justify-content:center;gap:10px;margin-top:32px}.slider-dot{width:12px;height:12px;background:var(--gray-300);border:none;border-radius:50%;transition:all var(--transition);cursor:pointer}.slider-dot.active{width:32px;border-radius:6px;background:var(--primary)}/* ============================================ Search & Filters ============================================ */ .search-section{margin-top:-40px;padding:0 0 60px;position:relative;z-index:10}.search-card{background:var(--white);border-radius:var(--border-radius-xl);padding:32px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color)}.search-form{display:flex;flex-direction:column;gap:20px}.search-input-wrapper{position:relative}.search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none}.search-input{width:100%;padding:18px 20px 18px 56px;font-size:1.0625rem;color:var(--text-primary);background:var(--gray-50);border:2px solid transparent;border-radius:var(--border-radius);transition:all var(--transition)}.search-input:focus{outline:none;background:var(--white);border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,0.1)}.search-input::placeholder{color:var(--gray-400)}.filter-row{display:grid;grid-template-columns:repeat(3,1fr) auto;gap:16px}.filter-select{padding:16px 48px 16px 20px;font-size:1rem;color:var(--text-primary);background:var(--gray-50);border:2px solid transparent;border-radius:var(--border-radius);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;transition:all var(--transition)}.filter-select:focus{outline:none;background-color:var(--white);border-color:var(--primary)}.btn-search{padding:16px 32px;font-size:1rem;font-weight:600;color:var(--white);background:var(--primary);border:none;border-radius:var(--border-radius);transition:all var(--transition);white-space:nowrap}.btn-search:hover{background:var(--primary-dark)}.active-filters{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.filter-tag{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;font-size:0.875rem;color:var(--primary);background:rgba(37,99,235,0.1);border-radius:100px}.filter-tag-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;color:var(--primary);background:transparent;border:none;border-radius:50%;font-size:1.25rem;line-height:1;transition:background var(--transition)}.filter-tag-remove:hover{background:rgba(37,99,235,0.15)}/* ============================================ Stats Section ============================================ */ .stats-section{padding:40px 0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.stat-card{background:var(--white);border-radius:var(--border-radius-lg);padding:28px;text-align:center;border:1px solid var(--border-color);transition:all var(--transition)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-icon{width:56px;height:56px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;background:rgba(37,99,235,0.1);border-radius:var(--border-radius);font-size:1.5rem}.stat-value{font-size:2rem;font-weight:800;color:var(--primary);margin-bottom:4px}.stat-label{font-size:0.9375rem;color:var(--text-secondary)}/* ============================================ Jobs Grid ============================================ */ .jobs-section{padding:60px 0}.jobs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.jobs-count{font-size:1rem;color:var(--text-secondary)}.jobs-count strong{color:var(--text-primary);font-weight:700}.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:24px}.job-card{background:var(--white);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:28px;transition:all var(--transition);position:relative}.job-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(37,99,235,0.2)}.job-card-header{display:flex;gap:16px;margin-bottom:16px}.job-card-link{display:block;text-decoration:none;color:inherit}.job-logo{width:56px;height:56px;border-radius:var(--border-radius);object-fit:cover;background:var(--gray-100);flex-shrink:0}.job-logo-placeholder{width:56px;height:56px;border-radius:var(--border-radius);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;color:var(--white);flex-shrink:0}.job-card-meta{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.job-company{font-size:0.9375rem;font-weight:500;color:var(--text-secondary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.company-logo{width:60px;height:60px;border-radius:var(--border-radius);object-fit:cover;background:var(--gray-100);flex-shrink:0}.company-logo-placeholder{width:60px;height:60px;border-radius:var(--border-radius);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.375rem;color:var(--white);flex-shrink:0}.job-meta{flex:1;min-width:0}.company-name{font-size:0.9375rem;color:var(--text-secondary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);line-height:1.4;margin:0}.job-title a{color:inherit;transition:color var(--transition)}.job-title a:hover{color:var(--primary)}.job-description{font-size:0.9375rem;color:var(--text-secondary);line-height:1.6;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.job-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.tag{padding:6px 12px;font-size:0.75rem;font-weight:600;border-radius:100px;text-transform:uppercase;letter-spacing:0.03em}.tag-remote{background:rgba(16,185,129,0.1);color:var(--success)}.tag-onsite{background:rgba(245,158,11,0.1);color:var(--warning)}.tag-location{background:var(--gray-100);color:var(--text-secondary)}.tag-category{background:rgba(37,99,235,0.1);color:var(--primary)}.job-footer{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--gray-100)}.job-date{font-size:0.8125rem;color:var(--text-muted)}.job-link{display:inline-flex;align-items:center;gap:6px;font-size:0.9375rem;font-weight:600;color:var(--primary);transition:gap var(--transition)}.job-link:hover{gap:10px}/* ============================================ Blog Section ============================================ */ .blog-section{padding:80px 0;background:var(--white)}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:32px}.blog-card{background:var(--bg-secondary);border-radius:var(--border-radius-lg);overflow:hidden;transition:all var(--transition)}.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.blog-image{height:200px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:3rem}.blog-image img{width:100%;height:100%;object-fit:cover}.blog-content{padding:28px}.blog-meta{display:flex;align-items:center;gap:16px;margin-bottom:12px;font-size:0.8125rem;color:var(--text-muted)}.blog-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:12px;line-height:1.4}.blog-title a{color:inherit}.blog-title a:hover{color:var(--primary)}.blog-excerpt{font-size:0.9375rem;color:var(--text-secondary);line-height:1.6;margin-bottom:16px}.blog-link{font-size:0.9375rem;font-weight:600;color:var(--primary);display:inline-flex;align-items:center;gap:6px}.blog-link:hover{gap:10px}/* ============================================ Newsletter Section ============================================ */ .newsletter-section{padding:80px 0;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);position:relative;overflow:hidden}.newsletter-section::before{content:'';position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(circle,rgba(255,255,255,0.1) 0%,transparent 60%);pointer-events:none}.newsletter-content{max-width:600px;margin:0 auto;text-align:center;position:relative;z-index:1}.newsletter-title{font-size:2.25rem;font-weight:800;color:var(--white);margin-bottom:12px}.newsletter-subtitle{font-size:1.125rem;color:rgba(255,255,255,0.85);margin-bottom:32px}.newsletter-form{display:flex;gap:12px;max-width:500px;margin:0 auto}.newsletter-input{flex:1;padding:16px 24px;font-size:1rem;background:var(--white);border:none;border-radius:var(--border-radius);color:var(--text-primary)}.newsletter-input::placeholder{color:var(--gray-400)}.newsletter-btn{padding:16px 28px;font-size:1rem;font-weight:600;color:var(--primary);background:var(--white);border:none;border-radius:var(--border-radius);transition:all var(--transition);white-space:nowrap}.newsletter-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}/* ============================================ Footer ============================================ */ .footer{background:var(--gray-900);color:var(--gray-300);padding:80px 0 0}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}.footer-brand{max-width:320px}.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:20px}.footer-logo .logo-text{color:var(--white)}.footer-description{font-size:0.9375rem;line-height:1.7;color:var(--gray-400);margin-bottom:24px}.social-links{display:flex;gap:12px}.social-link{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.1);border-radius:10px;color:var(--gray-300);transition:all var(--transition)}.social-link:hover{background:var(--primary);color:var(--white)}.footer-column h4{font-size:1rem;font-weight:700;color:var(--white);margin-bottom:24px;text-transform:uppercase;letter-spacing:0.05em}.footer-links{display:flex;flex-direction:column;gap:14px}.footer-links a{font-size:0.9375rem;color:var(--gray-400);transition:color var(--transition)}.footer-links a:hover{color:var(--white)}.footer-contact-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;font-size:0.9375rem;color:var(--gray-400)}.footer-contact-item svg{flex-shrink:0;margin-top:2px;color:var(--primary)}.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding:24px 0;display:flex;justify-content:space-between;align-items:center}.footer-copyright{font-size:0.875rem;color:var(--gray-500)}.footer-legal{display:flex;gap:24px}.footer-legal a{font-size:0.875rem;color:var(--gray-500)}.footer-legal a:hover{color:var(--white)}/* ============================================ Job Detail Page ============================================ */ .job-detail{padding:calc(var(--header-height) + 40px) 0 80px}.job-detail-grid{display:grid;grid-template-columns:1fr 380px;gap:40px}.job-detail-header{margin-bottom:32px}.job-detail-top{display:flex;align-items:flex-start;gap:24px;margin-bottom:24px}.job-detail-logo{width:100px;height:100px;border-radius:var(--border-radius-lg);object-fit:cover;background:var(--gray-100)}.job-detail-logo-placeholder{width:100px;height:100px;border-radius:var(--border-radius-lg);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:2.5rem;color:var(--white)}.job-detail-info h1{font-size:2rem;font-weight:800;color:var(--text-primary);margin-bottom:8px;line-height:1.3}.job-detail-company{font-size:1.125rem;color:var(--text-secondary)}.job-detail-company a{color:var(--primary)}.job-detail-tags{display:flex;flex-wrap:wrap;gap:10px}.job-detail-tags .tag{padding:10px 16px;font-size:0.875rem}.job-content-section{background:var(--white);border-radius:var(--border-radius-lg);padding:40px;border:1px solid var(--border-color)}.job-content-title{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.job-content-body{font-size:1rem;color:var(--text-secondary);line-height:1.85}.job-content-body h3{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:32px 0 16px 0}.job-content-body h3:first-child{margin-top:0}.job-content-body p{margin-bottom:20px}.job-content-body p:last-child{margin-bottom:0}.job-sidebar{position:sticky;top:calc(var(--header-height) + 24px)}.sidebar-card{background:var(--white);border-radius:var(--border-radius-lg);padding:32px;border:1px solid var(--border-color);margin-bottom:24px}.sidebar-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:24px}.info-list{display:flex;flex-direction:column;gap:20px}.info-item{display:flex;align-items:flex-start;gap:16px}.info-icon{width:48px;height:48px;background:var(--gray-50);border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.info-content{flex:1}.info-label{font-size:0.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:4px}.info-value{font-size:0.9375rem;color:var(--text-primary);font-weight:500}.btn-apply{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:18px;font-size:1rem;font-weight:700;color:var(--white);background:var(--primary);border:none;border-radius:var(--border-radius);transition:all var(--transition);margin-top:24px}.btn-apply:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 25px rgba(37,99,235,0.3);color:var(--white)}.btn-company{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;font-size:0.9375rem;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius);margin-top:12px;transition:all var(--transition)}.btn-company:hover{border-color:var(--primary);color:var(--primary)}/* ============================================ Pagination ============================================ */ .pagination{display:flex;justify-content:center;gap:8px;margin-top:48px}.page-link{display:flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 16px;font-size:0.9375rem;font-weight:500;color:var(--text-secondary);background:var(--white);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:all var(--transition)}.page-link:hover{border-color:var(--primary);color:var(--primary)}.page-link.active{background:var(--primary);border-color:var(--primary);color:var(--white)}.page-link.disabled{opacity:0.5;cursor:not-allowed}/* ============================================ Load More ============================================ */ .load-more-container{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:48px;padding:24px 0}.btn-load-more{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 48px;font-size:1rem;font-weight:600;color:var(--white);background:var(--primary);border:none;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition);min-width:200px}.btn-load-more:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px rgba(37,99,235,0.3)}.btn-load-more:disabled{background:var(--gray-400);cursor:not-allowed;transform:none;box-shadow:none}.load-more-info{font-size:0.875rem;color:var(--text-muted);margin:0}.loading-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,0.3);border-top-color:white;border-radius:50%;animation:spin 0.8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}/* ============================================ Page Headers ============================================ */ .page-header{padding:calc(var(--header-height) + 60px) 0 60px;background:linear-gradient(135deg,var(--gray-50) 0%,var(--white) 100%);text-align:center}.page-title{font-size:2.75rem;font-weight:800;color:var(--text-primary);margin-bottom:12px}.page-subtitle{font-size:1.125rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.breadcrumb{display:flex;justify-content:center;gap:8px;margin-top:20px;font-size:0.9375rem}.breadcrumb a{color:var(--text-muted)}.breadcrumb span{color:var(--text-muted)}.breadcrumb-current{color:var(--text-primary)}/* ============================================ Forms ============================================ */ .form-group{margin-bottom:24px}.form-label{display:block;font-size:0.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.form-input,.form-textarea,.form-select{width:100%;padding:14px 18px;font-size:1rem;color:var(--text-primary);background:var(--white);border:2px solid var(--border-color);border-radius:var(--border-radius);transition:all var(--transition)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,0.1)}.form-textarea{min-height:150px;resize:vertical}.btn-submit{padding:16px 32px;font-size:1rem;font-weight:600;color:var(--white);background:var(--primary);border:none;border-radius:var(--border-radius);transition:all var(--transition)}.btn-submit:hover{background:var(--primary-dark)}/* ============================================ Alert Messages ============================================ */ .alert{padding:16px 20px;border-radius:var(--border-radius);margin-bottom:24px;font-size:0.9375rem}.alert-success{background:rgba(16,185,129,0.1);color:var(--success);border:1px solid rgba(16,185,129,0.2)}.alert-error{background:rgba(239,68,68,0.1);color:var(--danger);border:1px solid rgba(239,68,68,0.2)}/* ============================================ Empty State ============================================ */ .empty-state{text-align:center;padding:80px 20px}.empty-icon{width:100px;height:100px;margin:0 auto 24px;background:var(--gray-100);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem}.empty-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.empty-text{color:var(--text-muted)}/* ============================================ Responsive Design ============================================ */ @media (max-width:1024px){.footer-grid{grid-template-columns:repeat(2,1fr)}.job-detail-grid{grid-template-columns:1fr}.job-sidebar{position:static}}@media (max-width:768px){:root{--header-height:70px}.nav{display:none;position:fixed;top:var(--header-height);left:0;right:0;background:var(--white);padding:20px;flex-direction:column;border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-lg)}.nav.active{display:flex}.menu-toggle{display:flex}.lang-switcher{margin:16px 0 0}.hero{padding:calc(var(--header-height) + 40px) 0 60px}.hero-title{font-size:2rem}.filter-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.jobs-grid{grid-template-columns:1fr}.blog-grid{grid-template-columns:1fr}.newsletter-form{flex-direction:column}.footer-grid{grid-template-columns:1fr;gap:32px}.footer-bottom{flex-direction:column;gap:16px;text-align:center}.section{padding:60px 0}.section-title{font-size:1.75rem}.job-detail-top{flex-direction:column}.job-content-section{padding:24px}.page-title{font-size:2rem}}@media (max-width:480px){.container{padding:0 16px}.search-card{padding:20px}.job-card{padding:20px}.stat-card{padding:20px}.sidebar-card{padding:24px}}/* ============================================ Loading Spinner ============================================ */ .spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 0.8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;inset:0;background:rgba(255,255,255,0.9);display:flex;align-items:center;justify-content:center;z-index:9999}/* ============================================ Features Grid ============================================ */ .features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.feature-card{background:var(--bg-card);border-radius:var(--border-radius-lg);padding:32px 24px;text-align:center;border:1px solid var(--border-color);transition:all var(--transition)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.feature-icon{font-size:3rem;margin-bottom:20px}.feature-card h3{font-size:1.125rem;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.feature-card p{color:var(--text-secondary);font-size:0.9375rem;line-height:1.6}@media (max-width:1024px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.features-grid{grid-template-columns:1fr}}/* ============================================ Blog Slider ============================================ */ .blog-slider-container{position:relative;padding:0 60px}.blog-slider{overflow:hidden;border-radius:var(--border-radius-lg)}.blog-slider-track{display:flex;gap:24px;transition:transform 0.6s cubic-bezier(0.25,0.1,0.25,1)}.blog-slide{flex:0 0 calc(33.333% - 16px);min-width:calc(33.333% - 16px)}.blog-slider-btn{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;background:var(--white);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.3s ease;box-shadow:0 4px 20px rgba(0,0,0,0.15);z-index:10;opacity:0;visibility:hidden}.blog-slider-container:hover .blog-slider-btn{opacity:1;visibility:visible}.blog-slider-prev{left:0;transform:translateY(-50%) translateX(-10px)}.blog-slider-next{right:0;transform:translateY(-50%) translateX(10px)}.blog-slider-container:hover .blog-slider-prev{transform:translateY(-50%) translateX(0)}.blog-slider-container:hover .blog-slider-next{transform:translateY(-50%) translateX(0)}.blog-slider-btn:hover{background:var(--primary);color:var(--white);transform:translateY(-50%) scale(1.1);box-shadow:0 6px 25px rgba(37,99,235,0.4)}.blog-slider-btn:disabled{opacity:0.3 !important;cursor:not-allowed}.blog-slider-btn:disabled:hover{background:var(--white);color:var(--text-primary);transform:translateY(-50%) scale(1)}.blog-slider-btn svg{width:24px;height:24px;stroke-width:2.5}.blog-slider-dots{display:flex;justify-content:center;gap:10px;margin-top:32px}.blog-slider-dot{width:10px;height:10px;border-radius:50%;background:var(--gray-300);border:none;cursor:pointer;transition:all 0.3s ease;padding:0}.blog-slider-dot:hover{background:var(--gray-400)}.blog-slider-dot.active{background:var(--primary);width:32px;border-radius:5px}@media (max-width:1024px){.blog-slider-container{padding:0 50px}.blog-slide{flex:0 0 calc(50% - 12px);min-width:calc(50% - 12px)}}@media (max-width:768px){.blog-slider-container{padding:0}.blog-slider-btn{width:40px;height:40px}.blog-slider-prev{left:10px}.blog-slider-next{right:10px}.blog-slide{flex:0 0 100%;min-width:100%}.blog-slider-track{gap:0}}/* ============================================ Blog Image Link ============================================ */ .blog-image-link{display:block;text-decoration:none;overflow:hidden;border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.blog-image-link .blog-image{transition:transform var(--transition-slow)}.blog-image-link:hover .blog-image{transform:scale(1.05)}.blog-image-link:hover .blog-image img{transform:scale(1.05)}.blog-image-placeholder{display:flex;align-items:center;justify-content:center;font-size:4rem;color:var(--gray-400)}/* ============================================ Disclaimer Card (Job Page) ============================================ */ .disclaimer-card{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:1px solid #f59e0b}.disclaimer-icon{font-size:2rem;margin-bottom:12px}.disclaimer-title{font-size:1rem;font-weight:700;color:#92400e;margin-bottom:12px}.disclaimer-text{font-size:0.875rem;color:#78350f;line-height:1.6;margin-bottom:12px}.disclaimer-text:last-of-type{margin-bottom:16px}.disclaimer-footer{display:flex;align-items:center;gap:8px;padding-top:12px;border-top:1px solid rgba(245,158,11,0.3);font-size:0.8125rem;font-weight:600;color:#b45309}/* ============================================ Form Controls (Admin) ============================================ */ .form-control{width:100%;padding:12px 16px;font-size:0.9375rem;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--white);transition:all var(--transition)}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,0.1)}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:8px;color:var(--text-primary)}