﻿/* AAuJob - View-specific Styles (extracted from inline <style>) */

/* === Modern Pricing Page === */
.pricing-page-hero{background:linear-gradient(135deg,#8f161a 0%,#121827 58%,#163b34 100%);color:#fff;padding:64px 0 92px;text-align:center;position:relative;overflow:hidden;}
.pricing-page-hero:after{content:"";position:absolute;inset:auto -10% -45% -10%;height:280px;background:rgba(255,255,255,.08);transform:rotate(-3deg);}
.pricing-page-hero .container{position:relative;z-index:1;}
.pricing-eyebrow{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.10);border-radius:999px;padding:8px 14px;font-size:.82rem;font-weight:700;margin-bottom:18px;}
.pricing-page-hero h1{color:#fff;font-size:clamp(2rem,4vw,3.4rem);font-weight:900;letter-spacing:0;margin:0 auto 14px;max-width:880px;line-height:1.06;}
.pricing-page-hero p{max-width:720px;margin:0 auto;color:rgba(255,255,255,.78);font-size:1rem;line-height:1.7;}
.pricing-hero-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:26px;}
.pricing-page{background:#f6f7fb;padding:0 0 56px;}
.pricing-switch-wrap{display:flex;justify-content:center;margin-top:-34px;margin-bottom:28px;position:relative;z-index:4;}
.pricing-switch{display:inline-flex;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 14px 36px rgba(15,23,42,.12);padding:6px;gap:4px;}
.pricing-switch-btn{border:0;background:transparent;color:#475569;border-radius:8px;padding:11px 18px;font-weight:800;font-size:.92rem;display:inline-flex;align-items:center;gap:8px;transition:.18s ease;}
.pricing-switch-btn.active{background:#A11D21;color:#fff;box-shadow:0 8px 18px rgba(161,29,33,.22);}
.pricing-section-head{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:20px;}
.pricing-section-head span{display:block;color:#A11D21;font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;}
.pricing-section-head h2{font-size:1.45rem;font-weight:900;margin:0;color:#111827;}
.pricing-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:36px;}
.pricing-grid-candidate{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.pricing-card{--accent:#A11D21;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:24px 22px;box-shadow:0 8px 24px rgba(15,23,42,.06);position:relative;display:flex;flex-direction:column;min-height:100%;transition:.18s ease;}
.pricing-card:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(15,23,42,.11);border-color:#A11D21;}
.pricing-card.is-popular{border:2px solid var(--accent);box-shadow:0 18px 46px rgba(161,29,33,.13);}
.pricing-ribbon,.pricing-current{position:absolute;top:14px;right:14px;border-radius:999px;padding:5px 10px;font-size:.68rem;font-weight:900;text-transform:uppercase;}
.pricing-ribbon{background:var(--accent);color:#fff;}
.pricing-current{background:#dcfce7;color:#15803d;}
.pricing-card-icon{width:44px;height:44px;border-radius:10px;background:#fff0f0;color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:14px;}
.pricing-card h3{font-size:1.08rem;font-weight:900;color:#111827;margin:0 0 8px;}
.pricing-price{font-size:1.55rem;font-weight:950;color:var(--accent);line-height:1.1;}
.pricing-note{font-size:.82rem;color:#64748b;margin:5px 0 16px;}
.pricing-desc{font-size:.86rem;color:#64748b;line-height:1.55;margin:-4px 0 14px;}
.pricing-features{list-style:none;margin:0 0 20px;padding:0;display:grid;gap:10px;flex:1;}
.pricing-features li{display:flex;gap:9px;align-items:flex-start;color:#334155;font-size:.88rem;line-height:1.45;}
.pricing-features li i{color:var(--accent);font-size:.75rem;margin-top:4px;width:14px;text-align:center;flex:0 0 14px;}
.pricing-bottom-cta{display:flex;align-items:center;justify-content:space-between;gap:20px;border-radius:16px;background:linear-gradient(135deg,#A11D21,#111827);color:#fff;padding:30px 34px;margin-top:6px;}
.pricing-bottom-cta h2{color:#fff;margin:0 0 6px;font-size:1.4rem;font-weight:900;}
.pricing-bottom-cta p{margin:0;color:rgba(255,255,255,.72);max-width:680px;}
@media(max-width:1199px){.pricing-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:767px){.pricing-page-hero{padding:42px 0 76px;}.pricing-grid{grid-template-columns:1fr;}.pricing-section-head,.pricing-bottom-cta{align-items:flex-start;flex-direction:column;}.pricing-switch{width:100%;}.pricing-switch-btn{flex:1;justify-content:center;padding-inline:10px;}}

/* === Account/Profile === */
.profile-cover{height:88px;background:linear-gradient(135deg,#A11D21 0%,#0f172a 100%);border-radius:14px 14px 0 0;flex-shrink:0;}
.profile-avatar-pull{margin-top:-44px;padding:0 20px 16px;display:flex;align-items:flex-end;gap:14px;}
.avatar-img{width:88px;height:88px;object-fit:cover;border-radius:50%;border:4px solid #fff;box-shadow:0 4px 14px rgba(0,0,0,.15);flex-shrink:0;}
.avatar-initial{width:88px;height:88px;font-size:34px;border-radius:50%;border:4px solid #fff;box-shadow:0 4px 14px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#A11D21,#0f172a);color:#fff;flex-shrink:0;}
.profile-card{border:none;border-radius:14px;box-shadow:0 2px 12px rgba(0,0,0,.07);background:#fff;overflow:hidden;}
.profile-nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;font-size:13.5px;font-weight:500;color:#374151;text-decoration:none;transition:all .15s;margin-bottom:3px;}
.profile-nav-link:hover,.profile-nav-link.active{background:#fef2f2;color:#A11D21;text-decoration:none;}
.profile-nav-link i{width:16px;text-align:center;font-size:13px;}
.profile-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#94a3b8;padding:4px 12px 8px;margin-top:8px;}
.pf-form-label{font-size:12.5px;font-weight:600;color:#6b7280;margin-bottom:5px;}
.pf-section-head{display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:2px solid #f1f5f9;margin-bottom:20px;}
.pf-section-head i{width:32px;height:32px;border-radius:8px;background:#fef2f2;color:#A11D21;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
/* ChangePassword */
.cpw-card{border:none;border-radius:16px;box-shadow:0 4px 24px rgba(0,0,0,.08);background:#fff;overflow:hidden;}
.cpw-hero{background:linear-gradient(135deg,#A11D21 0%,#0f172a 100%);padding:28px 32px;color:#fff;}
.cpw-hero h5{font-weight:700;font-size:1.1rem;margin:0;}
.pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px 6px;font-size:14px;}
.pw-toggle:hover{color:#374151;}
/* FindCV hero */
.findcv-hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 100%);padding:36px 0 24px;}
.findcv-hero h1{font-size:1.6rem;font-weight:800;color:#fff;}
.findcv-hero p{color:rgba(255,255,255,.75);font-size:14px;}
.findcv-search-bar{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:16px 20px;margin-top:20px;}
.cv-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.06);padding:18px;transition:all .2s;height:100%;display:flex;flex-direction:column;}
.cv-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.1);}
.cv-avatar{width:54px;height:54px;border-radius:50%;object-fit:cover;border:2px solid #f1f5f9;flex-shrink:0;}
.cv-avatar-ph{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#A11D21,#0f172a);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;flex-shrink:0;}
.cv-skill-tag{display:inline-block;background:#f1f5f9;color:#475569;font-size:11.5px;padding:2px 9px;border-radius:12px;margin:2px 2px 0 0;}
.findcv-upgrade{border-radius:16px;border:2px dashed #fbbf24;background:#fffbeb;padding:40px;text-align:center;}

/* === Admin/Analytics === */
.text-purple { color: #8b5cf6 !important; }

/* === Admin/ArticleEdit === */
.note-editor.note-frame { border: none !important; border-radius: 0 !important; }
    .note-editor .note-toolbar { background: #f8fafc; border-bottom: 1px solid #e2e8f0; padding: 8px 12px; }
    .note-editor .note-editing-area .note-editable { 
        font-family: 'Inter', -apple-system, sans-serif; font-size: 15px; line-height: 1.8; padding: 20px; 
        min-height: 500px; max-width: 900px; margin: 0 auto;
    }
    .note-editor .note-editing-area .note-editable img { max-width: 100%; height: auto; border-radius: 8px; }
    .note-editor .note-editing-area .note-editable blockquote { border-left: 4px solid #A11D21; padding: 12px 20px; margin: 16px 0; background: #fff9f9; font-style: italic; }
    .note-editor .note-editing-area .note-editable pre { background: #1e293b; color: #e2e8f0; padding: 16px; border-radius: 8px; overflow-x: auto; }
    .note-editor .note-editing-area .note-editable code { background: #f1f5f9; padding: 2px 6px; border-radius: 4px; font-size: 0.9em; }
    .note-editor .note-editing-area .note-editable table { border-collapse: collapse; width: 100%; }
    .note-editor .note-editing-area .note-editable table td, .note-editor .note-editing-area .note-editable table th { border: 1px solid #e2e8f0; padding: 8px 12px; }
    .note-editor .note-editing-area .note-editable table th { background: #f8fafc; }
    .note-modal-backdrop { display: none !important; }

/* === Admin/Candidates === */
.plan-btn-hover {
        transition: all 0.2s ease-in-out;
    }
    .plan-btn-hover:hover {
        background-color: #f8f9fa !important;
        border-color: #198754 !important;
        transform: translateY(-2px);
        box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1);
    }

/* === Admin/Companies === */
.plan-btn-hover {
        transition: all 0.2s ease-in-out;
    }
    .plan-btn-hover:hover {
        background-color: #f8f9fa !important;
        border-color: #0d6efd !important;
        transform: translateY(-2px);
        box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1);
    }

/* === Admin/Jobs === */
.applicant-row { background: #f8fafc; }
    .applicant-panel { display: none; }
    .applicant-panel.show { display: table-row; }
    .app-status-badge { font-size: 11px; padding: 2px 8px; border-radius: 20px; font-weight: 600; }
    .cv-btn { font-size: 12px; padding: 3px 10px; border-radius: 6px; }
    .app-count-chip {
        display: inline-flex; align-items: center; gap: 4px;
        background: #fff0f0; color: #A11D21; border-radius: 20px;
        font-size: 12px; font-weight: 700; padding: 2px 10px; cursor: pointer;
        border: none; transition: background .15s;
    }
    .app-count-chip:hover { background: #fecaca; }
    .app-count-chip.has-new { background: #fef3c7; color: #d97706; }

/* === Communication/Chat === */
.chat-layout { height: calc(100vh - 200px); min-height: 500px; }
    .channel-list { max-height: 100%; overflow-y: auto; }
    .channel-item { cursor: pointer; border: none; border-radius: 0.5rem; transition: all 0.2s; }
    .channel-item:hover { background: #f0f4ff; }
    .channel-item.active { background: var(--bs-primary); color: #fff !important; }
    .channel-item.active .text-muted { color: rgba(255,255,255,0.7) !important; }
    .chat-messages { flex: 1; overflow-y: auto; padding: 1rem; }
    .chat-msg { display: flex; gap: 0.75rem; margin-bottom: 1rem; }
    .chat-msg .avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
    .chat-msg .avatar-placeholder { width: 36px; height: 36px; border-radius: 50%; background: #e9ecef; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-weight: 600; color: #6c757d; font-size: 0.8rem; }
    .chat-msg .msg-body { flex: 1; }
    .chat-msg .sender { font-weight: 600; font-size: 0.85rem; }
    .chat-msg .time { font-size: 0.7rem; color: #adb5bd; margin-left: 0.5rem; }
    .chat-msg .content { font-size: 0.9rem; background: #f8f9fa; padding: 0.5rem 0.75rem; border-radius: 0.5rem; display: inline-block; max-width: 100%; word-break: break-word; }
    .chat-input-area { border-top: 1px solid #e9ecef; padding: 0.75rem 1rem; }
    .no-channel { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; color: #adb5bd; }

/* === Company/CreateJob === */
.cj-hero {
        background: linear-gradient(135deg, #A11D21 0%, #0f172a 100%);
        padding: 2.5rem 0 2rem;
        margin-bottom: 2rem;
        color: #fff;
    }
    .cj-hero .breadcrumb-item a { color: rgba(255,255,255,.75); text-decoration: none; }
    .cj-hero .breadcrumb-item.active { color: #fff; }
    .cj-hero .breadcrumb-item+.breadcrumb-item::before { color: rgba(255,255,255,.5); }
    .cj-hero h1 { font-size: 1.8rem; font-weight: 700; margin-bottom: .25rem; }
    .cj-hero p { opacity: .85; margin: 0; font-size: .95rem; }
    .cj-body-wrap { background: #f5f5f5; min-height: 60vh; padding-bottom: 3rem; }
    .cj-card {
        background: #fff;
        border-radius: 14px;
        box-shadow: 0 2px 14px rgba(0,0,0,.06);
        padding: 1.75rem 2rem;
        margin-bottom: 1.5rem;
    }
    .cj-section-label {
        display: flex; align-items: center; gap: .6rem;
        font-size: 1.05rem; font-weight: 700; color: #0f172a;
        padding-bottom: .85rem; margin-bottom: 1.25rem;
        border-bottom: 2px solid #f3f4f6;
    }
    .cj-section-label .icon-circle {
        width: 34px; height: 34px; border-radius: 50%;
        background: #fff0f0; display: flex; align-items: center;
        justify-content: center; font-size: 1rem; color: #A11D21; flex-shrink: 0;
    }
    .cj-field label { font-size: .87rem; font-weight: 600; color: #374151; margin-bottom: .35rem; }
    .cj-field .form-control, .cj-field .form-select {
        border-radius: 9px; border: 1.5px solid #e5e7eb;
        font-size: .93rem; transition: border-color .18s, box-shadow .18s; padding: .55rem .9rem;
    }
    .cj-field .form-control:focus, .cj-field .form-select:focus {
        border-color: #A11D21; box-shadow: 0 0 0 3px rgba(161,29,33,.1);
    }
    .cj-field textarea.form-control { min-height: 130px; resize: vertical; }
    .required-star { color: #dc2626; margin-left: 3px; }
    .salary-options { display: flex; gap: .6rem; margin-bottom: 1rem; flex-wrap: wrap; }
    .salary-option {
        padding: .5rem 1.2rem; border: 2px solid #e5e7eb; border-radius: 30px;
        font-size: .88rem; font-weight: 600; color: #4b5563; cursor: pointer;
        transition: all .18s; background: #fff; user-select: none;
    }
    .salary-option.active { background: #A11D21; border-color: #A11D21; color: #fff; }
    .salary-option:hover:not(.active) { border-color: #A11D21; color: #A11D21; background: #fff0f0; }
    #skillTagsDisplay {
        display: flex; flex-wrap: wrap; gap: .4rem; min-height: 40px;
        padding: .5rem .75rem; border: 1.5px solid #e5e7eb; border-radius: 9px;
        background: #f9fafb; cursor: text; align-content: flex-start;
    }
    .skill-tag {
        background: #fff0f0; color: #A11D21; border-radius: 20px;
        padding: .22rem .75rem; font-size: .82rem; font-weight: 600;
        display: flex; align-items: center; gap: .4rem;
    }
    .skill-tag .rm { cursor: pointer; opacity: .7; font-size: .9rem; }
    .skill-tag .rm:hover { opacity: 1; color: #dc2626; }
    #skillInput {
        border: none; outline: none; background: transparent;
        font-size: .88rem; min-width: 120px; flex: 1; padding: .1rem .25rem;
    }
    .cj-sidebar { position: sticky; top: 80px; }
    .cj-preview-card {
        background: #fff; border-radius: 14px;
        box-shadow: 0 2px 14px rgba(30,50,120,.07);
        padding: 1.4rem 1.5rem; margin-bottom: 1.25rem;
    }
    .cj-preview-card .preview-title { font-weight: 700; font-size: 1rem; color: #111827; margin-bottom: .15rem; min-height: 22px; }
    .cj-preview-card .preview-meta span { font-size: .8rem; color: #6b7280; margin-right: .9rem; }
    .cj-preview-card .preview-salary { font-size: .92rem; font-weight: 700; color: #059669; margin: .5rem 0 .6rem; }
    .cj-preview-card .preview-badge { font-size: .76rem; padding: .22rem .65rem; border-radius: 20px; font-weight: 600; }
    .cj-checklist { list-style: none; padding: 0; margin: 0; }
    .cj-checklist li { display: flex; align-items: flex-start; gap: .55rem; font-size: .85rem; color: #374151; margin-bottom: .55rem; }
    .cj-checklist li .ck-icon {
        width: 19px; height: 19px; border-radius: 50%;
        display: flex; align-items: center; justify-content: center;
        font-size: .72rem; flex-shrink: 0; margin-top: 1px; transition: all .2s;
    }
    .cj-checklist li.done .ck-icon { background: #d1fae5; color: #059669; }
    .cj-checklist li:not(.done) .ck-icon { background: #f3f4f6; color: #d1d5db; border: 1.5px solid #e5e7eb; }
    .cj-tip-card { background: linear-gradient(135deg,#fff0f0,#fecaca22); border-radius: 12px; padding: 1.1rem 1.3rem; border-left: 4px solid #A11D21; }
    .cj-tip-card h6 { font-size: .87rem; font-weight: 700; color: #7f1417; margin-bottom: .65rem; }
    .cj-tip { display: flex; gap: .5rem; font-size: .82rem; color: #374151; margin-bottom: .45rem; }
    .cj-tip .tip-dot { width: 6px; height: 6px; border-radius: 50%; background: #A11D21; flex-shrink: 0; margin-top: 5px; }
    .cj-submit-row {
        background: #fff; border-radius: 14px; box-shadow: 0 2px 14px rgba(0,0,0,.06);
        padding: 1.25rem 2rem; display: flex; align-items: center;
        justify-content: space-between; gap: 1rem; flex-wrap: wrap;
    }
    .btn-publish {
        background: linear-gradient(135deg,#A11D21,#7f1417); border: none; border-radius: 9px;
        color: #fff; font-weight: 700; font-size: .97rem; padding: .65rem 2rem;
        transition: all .2s; box-shadow: 0 4px 14px rgba(161,29,33,.3);
    }
    .btn-publish:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(161,29,33,.45); color: #fff; }
    .btn-preview-open {
        border: 2px solid #A11D21; border-radius: 9px; color: #A11D21; background: #fff;
        font-weight: 600; font-size: .92rem; padding: .6rem 1.5rem; transition: all .18s;
    }
    .btn-preview-open:hover { background: #fff0f0; }
    .form-check-input.urgent-switch { width: 42px; height: 22px; cursor: pointer; }
    .modal-preview .modal-header { background: linear-gradient(135deg,#A11D21,#0f172a); color: #fff; border-radius: 12px 12px 0 0; }
    .modal-preview .modal-header .btn-close { filter: invert(1); }
    .badge-urgent { background: #fee2e2; color: #dc2626; font-size: .78rem; font-weight: 700; padding: .28rem .75rem; border-radius: 20px; }

/* === Company/Dashboard === */
.portal-sidebar { background: #fff; border-right: 1px solid var(--border-color, #e5e7eb); min-height: calc(100vh - 70px); padding: 1.5rem 0; }
.portal-sidebar .nav-link { color: #4B5563; padding: 0.75rem 1.5rem; border-radius: 0 2rem 2rem 0; margin-right: 1rem; font-size: 0.875rem; font-weight: 500; transition: all 0.2s ease; display: flex; align-items: center; gap: 0; }
.portal-sidebar .nav-link:hover { background: #fff0f0; color: #A11D21; padding-left: 1.75rem; }
.portal-sidebar .nav-link.active { background: #fff0f0; color: #A11D21; font-weight: 600; border-left: 4px solid #A11D21; padding-left: calc(1.5rem - 4px); }
.portal-sidebar .nav-link i { width: 24px; text-align: center; margin-right: 10px; font-size: 1rem; }
.portal-nav-section { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em; color: #9CA3AF; padding: 1.25rem 1.5rem 0.4rem; text-transform: uppercase; display: block; }
.stat-card { border-radius: var(--border-radius-xl, 1rem); border: 1px solid var(--border-color, #e5e7eb); background: #fff; box-shadow: var(--shadow-sm); transition: all 0.2s ease; overflow: hidden; position: relative; }
.stat-card::before { content: ''; position: absolute; top: 0; left: 0; width: 4px; height: 100%; background: var(--primary); opacity: 0; transition: opacity 0.2s ease; }
.stat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--primary-light); }
.stat-card:hover::before { opacity: 1; }
.pkg-card { border-radius: var(--border-radius-xl, 1rem); border: none; background: linear-gradient(135deg, var(--primary, #A11D21), var(--primary-dark, #7f1417)); color: #fff; box-shadow: var(--shadow-md); position: relative; overflow: hidden; }
.pkg-card::after { content: ''; position: absolute; top: -50px; right: -50px; width: 100px; height: 100px; background: rgba(255,255,255,0.1); border-radius: 50%; }
.dashboard-header-bg { background: linear-gradient(to right, #f9fafb, #fff0f0); border-radius: var(--border-radius-xl, 1rem); padding: 2rem; margin-bottom: 2rem; border: 1px solid rgba(161,29,33,.1); }
@media(max-width:991px) { .portal-sidebar { display:none!important; } }

/* === Company/Jobs === */
.jobs-action-btn {
        display: inline-flex; align-items: center; gap: .3rem;
        padding: .35rem .75rem; border-radius: 7px; font-size: .8rem;
        font-weight: 600; text-decoration: none; border: none; cursor: pointer;
        transition: all .15s;
    }
    .jobs-action-btn.edit { background: #fff0f0; color: #A11D21; }
    .jobs-action-btn.edit:hover { background: #fce7e7; color: #7f1417; }
    .jobs-action-btn.view { background: #f0fdf4; color: #15803d; }
    .jobs-action-btn.view:hover { background: #dcfce7; color: #166534; }
    .jobs-action-btn.delete { background: #fff1f2; color: #dc2626; }
    .jobs-action-btn.delete:hover { background: #fee2e2; color: #b91c1c; }
    .jobs-action-btn.pause { background: #fefce8; color: #a16207; }
    .jobs-action-btn.pause:hover { background: #fef9c3; color: #854d0e; }
    .jobs-action-btn.resume { background: #f0fdf4; color: #15803d; }
    .jobs-action-btn.resume:hover { background: #dcfce7; color: #166534; }
    .jobs-action-btn i { font-size: .82rem; }
    .job-actions { display: flex; gap: .4rem; flex-wrap: nowrap; align-items: center; }

/* === Company/Manage === */
.section-card { border: none; border-radius: 14px; box-shadow: 0 2px 12px rgba(0,0,0,.06); margin-bottom: 1.5rem; }
.section-card .card-header { background: transparent; border-bottom: 1px solid #f0f0f0; padding: 1rem 1.5rem .75rem; }
.section-card .card-body { padding: 1.5rem; }
.cover-preview-box { width:100%; height:150px; border-radius:10px; border:2px dashed #dee2e6; background:#f8f9fa; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.cover-preview-box img { width:100%; height:150px; object-fit:cover; }
.logo-preview-box { width:88px; height:88px; border-radius:10px; border:1px solid #dee2e6; background:#f8f9fa; overflow:hidden; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.logo-preview-box img { width:88px; height:88px; object-fit:contain; }

/* === Cv/Edit === */
/* NOTE: body & * rules removed — Cv/Edit uses Layout=null and loads its own inline styles */

        /* === LEFT SIDEBAR === */
        .cv-sidebar { position:fixed; left:0; top:0; width:90px; height:100vh; background:#1e1e2d; z-index:100; display:flex; flex-direction:column; align-items:center; padding-top:12px; }
        .cv-sidebar .sidebar-icon { width:60px; height:54px; display:flex; flex-direction:column; align-items:center; justify-content:center; color:#8b8fa7; cursor:pointer; border-radius:10px; margin-bottom:4px; font-size:0.65rem; transition:all 0.2s; text-decoration:none; }
        .cv-sidebar .sidebar-icon i { font-size:1.1rem; margin-bottom:3px; }
        .cv-sidebar .sidebar-icon:hover, .cv-sidebar .sidebar-icon.active { background:rgba(255,255,255,0.1); color:#fff; }
        .cv-sidebar .sidebar-logo { color:#fff; font-weight:700; font-size:1rem; margin-bottom:16px; text-decoration:none; }

        /* === LEFT PANEL (form inputs) === */
        .cv-panel { position:fixed; left:90px; top:0; width:380px; height:100vh; background:#fff; border-right:1px solid #e5e7eb; overflow-y:auto; z-index:90; }
        .cv-panel::-webkit-scrollbar { width:5px; }
        .cv-panel::-webkit-scrollbar-thumb { background:#ccc; border-radius:3px; }
        .panel-header { padding:16px 20px; border-bottom:1px solid #eee; background:#fafbfc; position:sticky; top:0; z-index:10; }
        .panel-section { padding:16px 20px; border-bottom:1px solid #f0f0f0; }
        .panel-section h6 { font-size:0.85rem; font-weight:700; color:#1e1e2d; margin-bottom:12px; }
        .panel-section .form-label { font-size:0.78rem; font-weight:600; color:#555; margin-bottom:3px; }
        .panel-section .form-control, .panel-section .form-select { font-size:0.82rem; border-radius:8px; }
        .panel-section .form-control:focus { border-color:#A11D21; box-shadow:0 0 0 3px rgba(161,29,33,0.1); }

        /* Section items */
        .section-item { background:#f8fafc; border:1px solid #eee; border-radius:10px; padding:12px; margin-bottom:10px; position:relative; }
        .section-item .remove-item { position:absolute; top:6px; right:8px; cursor:pointer; color:#dc3545; font-size:0.8rem; }
        .add-item-btn { border:2px dashed #ccc; border-radius:10px; padding:10px; text-align:center; cursor:pointer; color:#888; transition:all 0.2s; }
        .add-item-btn:hover { border-color:#A11D21; color:#A11D21; background:#fff5f5; }

        /* === RIGHT: CV PREVIEW === */
        .cv-preview-area { margin-left:470px; height:100vh; overflow-y:auto; padding:30px; display:flex; justify-content:center; }
        .cv-preview-area::-webkit-scrollbar { width:6px; }
        .cv-preview-area::-webkit-scrollbar-thumb { background:#bbb; border-radius:3px; }

        /* CV Paper */
        .cv-paper { width:794px; min-height:1123px; background:#fff; box-shadow:0 4px 20px rgba(0,0,0,0.12); position:relative; }

        /* === TOP BAR === */
        .cv-topbar { position:fixed; left:470px; top:0; right:0; height:52px; background:#fff; border-bottom:1px solid #eee; z-index:80; display:flex; align-items:center; padding:0 20px; gap:12px; }
        .cv-topbar .btn { font-size:0.82rem; }
        .cv-preview-area { padding-top:82px; }

        /* === CV TEMPLATE STYLES === */
        .cv-paper .cv-heading { text-transform:uppercase; letter-spacing:1px; font-weight:700; border-bottom:2px solid var(--cv-primary); padding-bottom:6px; margin-bottom:12px; font-size:0.95rem; color:var(--cv-primary); }
        .cv-paper .cv-entry { margin-bottom:10px; }
        .cv-paper .cv-entry-title { font-weight:600; font-size:0.85rem; }
        .cv-paper .cv-entry-sub { font-size:0.78rem; color:#666; }
        .cv-paper .cv-entry-date { font-size:0.75rem; color:#888; }
        .cv-paper .cv-entry-desc { font-size:0.8rem; color:#444; margin-top:4px; }

        /* Classic layout */
        .cv-layout-classic { padding:40px; }
        .cv-layout-classic .cv-header { text-align:center; margin-bottom:24px; padding-bottom:20px; border-bottom:3px solid var(--cv-primary); }
        .cv-layout-classic .cv-header .cv-name { font-size:1.8rem; font-weight:700; color:var(--cv-primary); margin-bottom:4px; }
        .cv-layout-classic .cv-header .cv-jobtitle { font-size:1rem; color:#555; }
        .cv-layout-classic .cv-contact { display:flex; flex-wrap:wrap; justify-content:center; gap:12px; font-size:0.78rem; color:#555; margin-top:10px; }
        .cv-layout-classic .cv-avatar { width:100px; height:100px; border-radius:50%; object-fit:cover; border:3px solid var(--cv-primary); margin:0 auto 10px; }

        /* Modern layout (sidebar) */
        .cv-layout-modern { display:flex; min-height:1123px; }
        .cv-layout-modern .cv-left { width:260px; background:var(--cv-primary); color:#fff; padding:30px 20px; }
        .cv-layout-modern .cv-right { flex:1; padding:30px; }
        .cv-layout-modern .cv-left .cv-name { font-size:1.3rem; font-weight:700; margin-bottom:4px; }
        .cv-layout-modern .cv-left .cv-jobtitle { font-size:0.85rem; opacity:0.85; margin-bottom:16px; }
        .cv-layout-modern .cv-left .cv-avatar { width:120px; height:120px; border-radius:50%; object-fit:cover; border:3px solid rgba(255,255,255,0.4); margin:0 auto 16px; display:block; }
        .cv-layout-modern .cv-left .cv-heading { color:#fff; border-bottom-color:rgba(255,255,255,0.3); font-size:0.85rem; }
        .cv-layout-modern .cv-left .cv-contact-item { font-size:0.75rem; margin-bottom:6px; display:flex; align-items:center; gap:8px; }
        .cv-layout-modern .cv-left .cv-contact-item i { width:16px; text-align:center; }

        /* Minimal layout */
        .cv-layout-minimal { padding:50px 40px; }
        .cv-layout-minimal .cv-header { margin-bottom:24px; }
        .cv-layout-minimal .cv-header .cv-name { font-size:2rem; font-weight:300; letter-spacing:2px; color:#222; }
        .cv-layout-minimal .cv-header .cv-jobtitle { font-size:0.9rem; color:#888; text-transform:uppercase; letter-spacing:3px; }
        .cv-layout-minimal .cv-heading { font-weight:600; font-size:0.8rem; text-transform:uppercase; letter-spacing:2px; color:var(--cv-primary); border-bottom:1px solid #ddd; }

        /* Creative layout */
        .cv-layout-creative { padding:0; }
        .cv-layout-creative .cv-header-banner { background:var(--cv-primary); color:#fff; padding:40px; position:relative; }
        .cv-layout-creative .cv-header-banner .cv-name { font-size:2rem; font-weight:700; }
        .cv-layout-creative .cv-header-banner .cv-jobtitle { font-size:1rem; opacity:0.9; }
        .cv-layout-creative .cv-avatar { width:110px; height:110px; border-radius:50%; object-fit:cover; border:4px solid #fff; position:absolute; right:40px; bottom:-55px; }
        .cv-layout-creative .cv-body { padding:30px 40px; padding-top:70px; }
        .cv-layout-creative .cv-heading { color:var(--cv-primary); }

        /* Corporate layout */
        .cv-layout-corporate { padding:40px; }
        .cv-layout-corporate .cv-header { display:flex; align-items:center; gap:20px; margin-bottom:24px; padding-bottom:20px; border-bottom:3px double var(--cv-primary); }
        .cv-layout-corporate .cv-avatar { width:90px; height:90px; border-radius:8px; object-fit:cover; }
        .cv-layout-corporate .cv-name { font-size:1.6rem; font-weight:700; color:var(--cv-primary); }
        .cv-layout-corporate .cv-jobtitle { font-size:0.9rem; color:#666; }

        /* Student layout */
        .cv-layout-student { padding:30px 35px; }
        .cv-layout-student .cv-header { text-align:center; margin-bottom:20px; }
        .cv-layout-student .cv-avatar { width:90px; height:90px; border-radius:50%; object-fit:cover; border:3px solid var(--cv-primary); margin:0 auto 8px; }
        .cv-layout-student .cv-name { font-size:1.5rem; font-weight:700; color:var(--cv-primary); }
        .cv-layout-student .cv-jobtitle { font-size:0.85rem; color:#666; }
        .cv-layout-student .cv-heading { background:var(--cv-primary); color:#fff; padding:5px 12px; border-radius:4px; border-bottom:none; font-size:0.82rem; }

        /* Skill bar */
        .skill-bar { height:6px; background:#e5e7eb; border-radius:3px; overflow:hidden; }
        .skill-bar-fill { height:100%; border-radius:3px; background:var(--cv-primary); transition:width 0.5s; }

        /* Design panel */
        .color-option { width:28px; height:28px; border-radius:50%; cursor:pointer; border:2px solid transparent; transition:all 0.2s; display:inline-block; }
        .color-option:hover, .color-option.active { border-color:#333; transform:scale(1.15); }

        @media print {
            .cv-sidebar, .cv-panel, .cv-topbar { display:none !important; }
            .cv-preview-area { margin:0 !important; padding:0 !important; }
            .cv-paper { box-shadow:none !important; margin:0 !important; }
        }

/* === Cv/Preview === */
/* NOTE: body rule removed — Cv/Preview uses Layout=null with its own inline styles */
        .preview-toolbar { position:fixed; top:0; left:0; right:0; height:52px; background:#fff; border-bottom:1px solid #eee; z-index:100; display:flex; align-items:center; justify-content:center; gap:12px; padding:0 20px; }
        .preview-toolbar .btn { font-size:0.85rem; }
        .preview-container { padding-top:72px; padding-bottom:40px; display:flex; justify-content:center; }
        .cv-paper { width:794px; min-height:1123px; background:#fff; box-shadow:0 4px 20px rgba(0,0,0,0.12); position:relative; }
        .cv-heading { text-transform:uppercase; letter-spacing:1px; font-weight:700; border-bottom:2px solid var(--cv-primary); padding-bottom:6px; margin-bottom:12px; font-size:0.95rem; color:var(--cv-primary); }
        .cv-entry { margin-bottom:10px; }
        .cv-entry-title { font-weight:600; font-size:0.85rem; }
        .cv-entry-sub { font-size:0.78rem; color:#666; }
        .cv-entry-date { font-size:0.75rem; color:#888; }
        .cv-entry-desc { font-size:0.8rem; color:#444; margin-top:4px; }
        .skill-bar { height:6px; background:#e5e7eb; border-radius:3px; overflow:hidden; }
        .skill-bar-fill { height:100%; border-radius:3px; background:var(--cv-primary); }

        /* Reuse same layout CSS from editor */
        .cv-layout-classic { padding:40px; }
        .cv-layout-classic .cv-header { text-align:center; margin-bottom:24px; padding-bottom:20px; border-bottom:3px solid var(--cv-primary); }
        .cv-layout-classic .cv-header .cv-name { font-size:1.8rem; font-weight:700; color:var(--cv-primary); margin-bottom:4px; }
        .cv-layout-classic .cv-header .cv-jobtitle { font-size:1rem; color:#555; }
        .cv-layout-classic .cv-contact { display:flex; flex-wrap:wrap; justify-content:center; gap:12px; font-size:0.78rem; color:#555; margin-top:10px; }
        .cv-layout-classic .cv-avatar { width:100px; height:100px; border-radius:50%; object-fit:cover; border:3px solid var(--cv-primary); margin:0 auto 10px; display:block; }

        .cv-layout-modern { display:flex; min-height:1123px; }
        .cv-layout-modern .cv-left { width:260px; background:var(--cv-primary); color:#fff; padding:30px 20px; }
        .cv-layout-modern .cv-right { flex:1; padding:30px; }
        .cv-layout-modern .cv-left .cv-name { font-size:1.3rem; font-weight:700; margin-bottom:4px; }
        .cv-layout-modern .cv-left .cv-jobtitle { font-size:0.85rem; opacity:0.85; margin-bottom:16px; }
        .cv-layout-modern .cv-left .cv-avatar { width:120px; height:120px; border-radius:50%; object-fit:cover; border:3px solid rgba(255,255,255,0.4); margin:0 auto 16px; display:block; }
        .cv-layout-modern .cv-left .cv-heading { color:#fff; border-bottom-color:rgba(255,255,255,0.3); font-size:0.85rem; }
        .cv-layout-modern .cv-left .cv-contact-item { font-size:0.75rem; margin-bottom:6px; display:flex; align-items:center; gap:8px; }

        .cv-layout-minimal { padding:50px 40px; }
        .cv-layout-minimal .cv-header .cv-name { font-size:2rem; font-weight:300; letter-spacing:2px; color:#222; }
        .cv-layout-minimal .cv-header .cv-jobtitle { font-size:0.9rem; color:#888; text-transform:uppercase; letter-spacing:3px; }
        .cv-layout-minimal .cv-heading { font-weight:600; font-size:0.8rem; text-transform:uppercase; letter-spacing:2px; color:var(--cv-primary); border-bottom:1px solid #ddd; }

        .cv-layout-creative { padding:0; }
        .cv-layout-creative .cv-header-banner { background:var(--cv-primary); color:#fff; padding:40px; position:relative; }
        .cv-layout-creative .cv-header-banner .cv-name { font-size:2rem; font-weight:700; }
        .cv-layout-creative .cv-header-banner .cv-jobtitle { font-size:1rem; opacity:0.9; }
        .cv-layout-creative .cv-avatar { width:110px; height:110px; border-radius:50%; object-fit:cover; border:4px solid #fff; position:absolute; right:40px; bottom:-55px; }
        .cv-layout-creative .cv-body { padding:30px 40px; padding-top:70px; }

        .cv-layout-corporate { padding:40px; }
        .cv-layout-corporate .cv-header { display:flex; align-items:center; gap:20px; margin-bottom:24px; padding-bottom:20px; border-bottom:3px double var(--cv-primary); }
        .cv-layout-corporate .cv-avatar { width:90px; height:90px; border-radius:8px; object-fit:cover; }
        .cv-layout-corporate .cv-name { font-size:1.6rem; font-weight:700; color:var(--cv-primary); }
        .cv-layout-corporate .cv-jobtitle { font-size:0.9rem; color:#666; }

        .cv-layout-student { padding:30px 35px; }
        .cv-layout-student .cv-header { text-align:center; margin-bottom:20px; }
        .cv-layout-student .cv-avatar { width:90px; height:90px; border-radius:50%; object-fit:cover; border:3px solid var(--cv-primary); margin:0 auto 8px; display:block; }
        .cv-layout-student .cv-name { font-size:1.5rem; font-weight:700; color:var(--cv-primary); }
        .cv-layout-student .cv-jobtitle { font-size:0.85rem; color:#666; }
        .cv-layout-student .cv-heading { background:var(--cv-primary); color:#fff; padding:5px 12px; border-radius:4px; border-bottom:none; font-size:0.82rem; }

        @media print {
            .preview-toolbar { display:none !important; }
            .preview-container { padding-top:0 !important; }
            .cv-paper { box-shadow:none !important; }
            /* body { background:#fff; } — removed, Cv/Preview uses Layout=null */
        }

/* === Cv/Templates === */
.template-card:hover { transform: translateY(-6px); box-shadow: 0 12px 40px rgba(0,0,0,0.12) !important; }

/* === Feed/Index === */
/* ── Facebook-style Feed ── */
.fb-feed { max-width:680px; margin:0 auto; padding:20px 0; }
/* ── Stories bar ── */
.fb-stories { display:flex; gap:10px; overflow-x:auto; padding:0 4px 12px; scrollbar-width:none; }
.fb-stories::-webkit-scrollbar { display:none; }
.fb-story-card { min-width:110px; height:180px; border-radius:14px; position:relative; overflow:hidden;
    background:linear-gradient(135deg,#A11D21 0%,#0f172a 100%); cursor:pointer; flex-shrink:0;
    box-shadow:0 2px 8px rgba(0,0,0,.12); transition:transform .2s; }
.fb-story-card:hover { transform:scale(1.03); }
.fb-story-card img { width:100%; height:100%; object-fit:cover; }
.fb-story-label { position:absolute; bottom:0; left:0; right:0; padding:8px 10px;
    background:linear-gradient(transparent, rgba(0,0,0,.7)); color:#fff; font-size:12px; font-weight:600; }
.fb-story-avatar { position:absolute; top:10px; left:10px; width:36px; height:36px; border-radius:50%;
    border:3px solid #A11D21; object-fit:cover; }
/* ── Create post box ── */
.fb-create { background:#fff; border-radius:12px; box-shadow:0 1px 3px rgba(0,0,0,.1); padding:16px; margin-bottom:16px; }
.fb-create-top { display:flex; gap:12px; align-items:center; }
.fb-create-avatar { width:44px; height:44px; border-radius:50%; object-fit:cover; flex-shrink:0; }
.fb-create-input { flex:1; background:#f0f2f5; border:none; border-radius:22px; padding:10px 16px;
    font-size:15px; color:#65676b; cursor:pointer; transition:background .2s; outline:none; }
.fb-create-input:hover { background:#e4e6eb; }
.fb-create-input:focus { background:#e4e6eb; color:#050505; }
.fb-create-divider { height:1px; background:#e4e6eb; margin:12px 0; }
.fb-create-actions { display:flex; justify-content:space-around; }
.fb-create-actions button { display:flex; align-items:center; gap:8px; padding:8px 16px;
    border:none; background:transparent; border-radius:8px; font-size:14px; font-weight:600;
    color:#65676b; cursor:pointer; transition:background .2s; }
.fb-create-actions button:hover { background:#f0f2f5; }
.fb-create-actions .fa-image { color:#45bd62; font-size:20px; }
.fb-create-actions .fa-smile { color:#f7b928; font-size:20px; }
.fb-create-actions .fa-map-marker-alt { color:#f5533d; font-size:20px; }
/* ── Post compose modal overlay ── */
.fb-compose-overlay { display:none; position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(255,255,255,.7); z-index:1060; align-items:center; justify-content:center; backdrop-filter:blur(2px); }
.fb-compose-overlay.open { display:flex; }
.fb-compose-box { background:#fff; border-radius:12px; box-shadow:0 12px 28px rgba(0,0,0,.25);
    width:95%; max-width:520px; overflow:hidden; animation:fbSlideUp .25s ease; }
@keyframes fbSlideUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:none} }
.fb-compose-header { display:flex; align-items:center; justify-content:center; position:relative;
    padding:16px; border-bottom:1px solid #e4e6eb; }
.fb-compose-header h5 { margin:0; font-size:20px; font-weight:700; }
.fb-compose-close { position:absolute; right:16px; top:50%; transform:translateY(-50%);
    width:36px; height:36px; border-radius:50%; background:#e4e6eb; border:none;
    display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:18px; color:#65676b; }
.fb-compose-close:hover { background:#d8dadf; }
.fb-compose-user { display:flex; gap:10px; align-items:center; padding:16px 16px 0; }
.fb-compose-body { padding:8px 16px; }
.fb-compose-body textarea { width:100%; border:none; outline:none; resize:none; min-height:130px;
    font-size:16px; line-height:1.5; color:#050505; }
.fb-compose-body textarea::placeholder { color:#65676b; }
.fb-compose-img-preview { padding:0 16px; max-height:220px; overflow:hidden; border-radius:12px; margin:0 16px 12px; position:relative; }
.fb-compose-img-preview img { width:100%; border-radius:12px; object-fit:cover; max-height:220px; }
.fb-compose-img-remove { position:absolute; top:8px; right:24px; width:30px; height:30px;
    border-radius:50%; background:rgba(0,0,0,.6); border:none; color:#fff; cursor:pointer;
    display:flex; align-items:center; justify-content:center; font-size:14px; }
.fb-compose-toolbar { display:flex; align-items:center; justify-content:space-between; padding:12px 16px;
    margin:0 16px; border:1px solid #e4e6eb; border-radius:10px; }
.fb-compose-toolbar span { font-size:14px; font-weight:600; color:#050505; }
.fb-compose-toolbar-icons { display:flex; gap:8px; }
.fb-compose-toolbar-icons button { width:36px; height:36px; border-radius:50%; border:none;
    background:transparent; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:18px; }
.fb-compose-toolbar-icons button:hover { background:#f0f2f5; }
.fb-compose-submit { display:block; width:calc(100% - 32px); margin:12px 16px 16px; padding:10px;
    border:none; border-radius:8px; font-size:15px; font-weight:600; cursor:pointer;
    background:linear-gradient(135deg,#A11D21,#7f1417); color:#fff; transition:opacity .2s; }
.fb-compose-submit:disabled { opacity:.5; cursor:default; }
.fb-compose-submit:hover:not(:disabled) { opacity:.9; }
/* ── Filter tabs Facebook-style ── */
.fb-tabs { display:flex; background:#fff; border-radius:12px; box-shadow:0 1px 3px rgba(0,0,0,.1);
    margin-bottom:16px; overflow:hidden; }
.fb-tab { flex:1; text-align:center; padding:14px 8px; font-size:14px; font-weight:600;
    color:#65676b; text-decoration:none; border-bottom:3px solid transparent; transition:all .2s; }
.fb-tab:hover { background:#fff0f0; color:#A11D21; }
.fb-tab.active { color:#A11D21; border-bottom-color:#A11D21; background:transparent; }
.fb-tab i { margin-right:6px; }
/* ── Loading skeleton ── */
.fb-skeleton { background:#fff; border-radius:12px; padding:16px; margin-bottom:16px; box-shadow:0 1px 3px rgba(0,0,0,.1); }
.fb-skeleton-line { height:14px; background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);
    background-size:200% 100%; animation:fbShimmer 1.5s infinite; border-radius:6px; margin-bottom:10px; }
@keyframes fbShimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.fb-skeleton-avatar { width:44px; height:44px; border-radius:50%; background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);
    background-size:200% 100%; animation:fbShimmer 1.5s infinite; }
/* ── Toast ── */
.fb-toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%); background:#050505;
    color:#fff; padding:10px 20px; border-radius:8px; font-size:14px; z-index:9999;
    box-shadow:0 4px 16px rgba(0,0,0,.3); animation:fbToastIn .3s ease; }
@keyframes fbToastIn { from{opacity:0;transform:translateX(-50%) translateY(20px)} to{opacity:1;transform:translateX(-50%)} }
/* ── Lightbox ── */
.fb-lightbox { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(0,0,0,.92);
    z-index:1070; align-items:center; justify-content:center; cursor:zoom-out; }
.fb-lightbox.open { display:flex; }
.fb-lightbox img { max-width:92vw; max-height:92vh; object-fit:contain; border-radius:6px; }

/* === Pricing/Upgrade === */
.upgrade-hero { background: linear-gradient(135deg, #A11D21 0%, #0f172a 100%); padding: 48px 0 64px; color: #fff; }
    .plan-card { border-radius: 16px; border: 2px solid #e5e7eb; padding: 28px 20px; text-align: center; position: relative; transition: all .25s; cursor: pointer; }
    .plan-card:hover { border-color: #A11D21; transform: translateY(-4px); box-shadow: 0 12px 32px rgba(161,29,33,.12); }
    .plan-card.popular { border-color: #A11D21; box-shadow: 0 8px 28px rgba(161,29,33,.18); }
    .plan-card.current { border-color: #059669; background: #f0fdf4; }
    .plan-card.selected { border-color: #A11D21; box-shadow: 0 8px 28px rgba(161,29,33,.18); }
    .popular-badge { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: linear-gradient(90deg,#A11D21,#0f172a); color: #fff; padding: 3px 18px; border-radius: 20px; font-size: 11px; font-weight: 700; white-space: nowrap; }
    .plan-price { font-size: 28px; font-weight: 800; }
    .vip-badge { display: inline-flex; align-items: center; gap: 5px; padding: 3px 10px; border-radius: 20px; font-size: 12px; font-weight: 700; }
    .feature-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1px solid #f3f4f6; font-size: 13px; }
    .feature-row:last-child { border-bottom: none; }
    .boost-card { background: linear-gradient(135deg, #fff0f0, #f0fdf4); border: 1px solid rgba(161,29,33,.15); border-radius: 14px; padding: 24px; }

/* === Tools/GrossNet === */
:root { --red:#c41e2a; --darkred:#8b0000; }

/* Hero banner */
.tool-hero {
    background: linear-gradient(135deg, var(--darkred) 0%, var(--red) 100%);
    color: #fff;
    padding: 44px 0 0;
    margin-bottom: 0;
}
.tool-hero h1 { font-size: 2rem; font-weight: 800; }
.tool-hero p  { opacity: .88; font-size: 1rem; max-width: 580px; }

/* Mode toggle pills */
.mode-pills { display:flex; gap:8px; margin-bottom:24px; }
.mode-pill {
    flex:1; padding:11px; border-radius:10px; border:2px solid #e5e7eb;
    background:#fff; cursor:pointer; text-align:center; font-weight:600;
    transition:all .2s; font-size:14px; color:#374151;
}
.mode-pill.active   { border-color:var(--red); background:#fff5f5; color:var(--red); }
.mode-pill:hover    { border-color:var(--red); }

/* Input card */
.calc-card  { background:#fff; border-radius:16px; box-shadow:0 4px 24px rgba(0,0,0,.08); padding:28px; }

/* Result card */
.result-card { background:#fff; border-radius:16px; box-shadow:0 4px 24px rgba(0,0,0,.08); padding:28px; }
.result-net  {
    background: linear-gradient(135deg, var(--darkred), var(--red));
    border-radius:12px; padding:24px; text-align:center; color:#fff;
    margin-bottom:20px;
}
.result-net .label  { font-size:13px; opacity:.85; margin-bottom:6px; }
.result-net .amount { font-size:2.2rem; font-weight:800; letter-spacing:-1px; }
.result-net .gross-label { font-size:13px; opacity:.75; margin-top:8px; }

/* Breakdown rows */
.breakdown-row {
    display:flex; justify-content:space-between; align-items:center;
    padding:9px 0; border-bottom:1px solid #f3f4f6; font-size:14px;
}
.breakdown-row:last-child { border-bottom:none; }
.breakdown-row .lbl { color:#6b7280; }
.breakdown-row .val { font-weight:600; color:#111827; }
.breakdown-row .val.red  { color:var(--red); }
.breakdown-row .val.green{ color:#059669; }

/* Tax bracket table */
.tax-table { width:100%; border-collapse:collapse; font-size:13px; margin-top:8px; }
.tax-table th { background:#f9fafb; padding:8px 12px; text-align:left; color:#374151; font-weight:600; border-bottom:2px solid #e5e7eb; }
.tax-table td { padding:7px 12px; border-bottom:1px solid #f3f4f6; color:#374151; }
.tax-table tr:last-child td { border-bottom:none; }

/* Employer section */
.emp-box { background:#f8faff; border:1px solid #dbeafe; border-radius:12px; padding:16px; }

/* SEO section */
.seo-section h2 { font-size:1.25rem; font-weight:700; color:#1a1a1a; margin-bottom:10px; }
.seo-section p  { font-size:14px; color:#374151; line-height:1.8; }


/* === Account/Register === */
/* (Styles moved inline to Register.cshtml @section Head) */
/* === AAuBot Chat Widget === */
/* FAB */
#cb-fab{position:fixed;bottom:24px;right:20px;z-index:9999;display:none;flex-direction:column;align-items:center;gap:4px;}
#cb-fab-btn{width:54px;height:54px;border-radius:50%;background:#A11D21;border:none;color:#fff;cursor:pointer;box-shadow:0 4px 18px rgba(161,29,33,.45);display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;}
#cb-fab-btn:hover,#cb-fab-btn.active{transform:scale(1.06);box-shadow:0 6px 24px rgba(161,29,33,.55);}
#cb-fab-logo{width:32px;height:32px;object-fit:contain;transition:opacity .2s;}
#cb-fab-close{position:absolute;font-size:18px;}
#cb-fab-badge{position:absolute;top:0;right:0;width:16px;height:16px;border-radius:50%;background:#ef4444;border:2px solid #fff;font-size:9px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;}
#cb-fab-label{font-size:10px;font-weight:700;color:#A11D21;letter-spacing:.02em;text-shadow:0 1px 3px rgba(255,255,255,.8);}
#cb-fab-tooltip{position:absolute;bottom:62px;right:0;background:#0f172a;color:#fff;font-size:11px;padding:7px 12px;border-radius:10px;white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.22);opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity .25s,transform .25s;}
#cb-fab-tooltip.show{opacity:1;transform:translateY(0);}
#cb-fab-tooltip::after{content:'';position:absolute;bottom:-5px;right:18px;border:5px solid transparent;border-top-color:#0f172a;border-bottom:none;}

/* Chat window */
#cb-window{position:fixed;bottom:88px;right:20px;width:368px;height:540px;background:#fff;border-radius:16px;box-shadow:0 12px 48px rgba(0,0,0,.2);z-index:9998;display:none;flex-direction:column;overflow:hidden;border:1px solid rgba(0,0,0,.07);transform-origin:bottom right;}
#cb-window.open{display:flex;animation:cb-slidein .22s cubic-bezier(.34,1.56,.64,1);}

/* Header */
.cb-header{background:#fff;border-bottom:1px solid #f1f5f9;padding:12px 14px;display:flex;align-items:center;gap:10px;flex-shrink:0;position:relative;}
.cb-header::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#A11D21,#ef4444,#A11D21);background-size:200%;animation:cb-shimmer 3s linear infinite;}
.cb-avatar-wrap{position:relative;flex-shrink:0;}
.cb-avatar{width:38px;height:38px;border-radius:50%;background:#fff0f0;border:2px solid #fecaca;display:flex;align-items:center;justify-content:center;font-size:18px;overflow:hidden;}
.cb-avatar img{width:100%;height:100%;object-fit:contain;}
.cb-status-dot{position:absolute;bottom:1px;right:1px;width:9px;height:9px;border-radius:50%;background:#22c55e;border:2px solid #fff;}
.cb-header-info{flex:1;}
.cb-header-name{font-weight:800;font-size:.9rem;color:#0f172a;display:flex;align-items:center;gap:5px;}
.cb-ai-badge{background:#A11D21;color:#fff;font-size:.5rem;font-weight:800;padding:1px 5px;border-radius:4px;letter-spacing:.05em;}
.cb-header-sub{font-size:.68rem;color:#64748b;margin-top:1px;}
.cb-header-actions{display:flex;gap:4px;}
.cb-hdr-btn{background:#f8fafc;border:1px solid #e2e8f0;color:#64748b;width:28px;height:28px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.72rem;transition:all .15s;}
.cb-hdr-btn:hover{background:#fff0f0;border-color:#fecaca;color:#A11D21;}

/* Body */
.cb-body{flex:1;overflow-y:auto;padding:12px 10px;display:flex;flex-direction:column;gap:10px;background:#f8f9fb;scroll-behavior:smooth;}
.cb-body::-webkit-scrollbar{width:3px;}
.cb-body::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:3px;}
.cb-msg{display:flex;gap:7px;max-width:90%;}
.cb-msg.bot{align-self:flex-start;}
.cb-msg.user{align-self:flex-end;flex-direction:row-reverse;}
.cb-msg-avatar{width:26px;height:26px;border-radius:50%;flex-shrink:0;margin-top:auto;background:#fff0f0;border:1.5px solid #fecaca;display:flex;align-items:center;justify-content:center;font-size:13px;}
.cb-bubble{padding:9px 13px;border-radius:18px;font-size:.82rem;line-height:1.55;word-break:break-word;box-shadow:0 1px 2px rgba(0,0,0,.06);}
.cb-bubble.bot{background:#fff;color:#1e293b;border-bottom-left-radius:4px;border:1px solid #f1f5f9;}
.cb-bubble.user{background:#A11D21;color:#fff;border-bottom-right-radius:4px;}
.cb-time{font-size:.6rem;color:#cbd5e1;margin-top:3px;padding:0 4px;}

/* Job/article cards */
.cb-section-label{font-size:.68rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;margin:8px 0 5px;padding:0 2px;}
.cb-cards{display:flex;flex-direction:column;gap:6px;}
.cb-job-card{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid #f1f5f9;border-radius:10px;padding:9px 11px;text-decoration:none;color:inherit;transition:.15s;box-shadow:0 1px 3px rgba(0,0,0,.05);}
.cb-job-card:hover{border-color:#A11D21;box-shadow:0 3px 12px rgba(161,29,33,.12);transform:translateY(-1px);}
.cb-job-logo{width:34px;height:34px;border-radius:7px;object-fit:contain;border:1px solid #f1f5f9;background:#f8fafc;flex-shrink:0;}
.cb-job-logo-ph{width:34px;height:34px;border-radius:7px;background:#A11D21;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;}
.cb-job-info{flex:1;min-width:0;}
.cb-job-title{font-size:.78rem;font-weight:700;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cb-job-meta{font-size:.68rem;color:#64748b;margin-top:1px;}
.cb-badges{display:flex;flex-wrap:wrap;gap:3px;margin-top:3px;}
.cb-badge{padding:1px 7px;border-radius:16px;font-size:.6rem;font-weight:600;}
.cb-badge-sal{background:#dcfce7;color:#15803d;}
.cb-badge-loc{background:#fff0f0;color:#A11D21;}
.cb-badge-type{background:#f3f4f6;color:#374151;}
.cb-job-arrow{color:#d1d5db;font-size:.7rem;flex-shrink:0;}
.cb-article-card{display:block;background:#fff;border:1px solid #f1f5f9;border-radius:10px;padding:8px 11px;text-decoration:none;color:inherit;transition:.15s;}
.cb-article-card:hover{border-color:#A11D21;}
.cb-article-title{font-size:.78rem;font-weight:600;color:#0f172a;}
.cb-article-cat{font-size:.65rem;color:#A11D21;margin-top:2px;font-weight:700;}
.cb-followups{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px;}
.cb-chip{padding:5px 11px;border-radius:999px;font-size:.72rem;font-weight:600;background:#fff;color:#A11D21;border:1.5px solid #fecaca;cursor:pointer;transition:.15s;}
.cb-chip:hover{background:#A11D21;color:#fff;border-color:#A11D21;}

/* Typing */
.cb-typing{align-self:flex-start;display:flex;gap:7px;}
.cb-typing-dots{display:flex;gap:4px;padding:10px 14px;background:#fff;border-radius:18px;border-bottom-left-radius:4px;border:1px solid #f1f5f9;box-shadow:0 1px 2px rgba(0,0,0,.05);}
.cb-typing-dots span{width:7px;height:7px;border-radius:50%;background:#A11D21;animation:cb-bounce .9s infinite;}
.cb-typing-dots span:nth-child(2){animation-delay:.18s;}
.cb-typing-dots span:nth-child(3){animation-delay:.36s;}

/* Quick suggestions */
#cb-quick-area{padding:10px 10px 6px;background:#fff;border-top:1px solid #f1f5f9;flex-shrink:0;}
.cb-quick-label{font-size:.65rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;}
.cb-quick-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;}
.cb-qbtn{padding:8px 6px;border-radius:10px;border:1.5px solid #f1f5f9;background:#f8f9fb;font-size:.72rem;font-weight:600;color:#374151;cursor:pointer;text-align:center;transition:.15s;line-height:1.3;display:flex;flex-direction:column;align-items:center;gap:3px;}
.cb-qbtn:hover{background:#fff0f0;border-color:#fecaca;color:#A11D21;}
.cb-qbtn-icon{font-size:18px;line-height:1;}
.cb-qbtn span:last-child{font-size:.68rem;}

/* Footer / Input */
.cb-footer{padding:8px 10px 10px;background:#fff;border-top:1px solid #f1f5f9;flex-shrink:0;}
.cb-input-wrap{display:flex;gap:7px;align-items:flex-end;background:#f8f9fb;border-radius:22px;padding:5px 5px 5px 13px;border:1.5px solid #e2e8f0;transition:.2s;}
.cb-input-wrap:focus-within{border-color:#fca5a5;background:#fff;box-shadow:0 0 0 3px rgba(161,29,33,.08);}
.cb-input{flex:1;border:none;background:transparent;font-size:.82rem;outline:none;color:#1e293b;min-width:0;max-height:80px;resize:none;line-height:1.45;padding:2px 0;}
.cb-input::placeholder{color:#cbd5e1;}
.cb-send{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:#A11D21;border:none;color:#fff;cursor:pointer;font-size:.78rem;display:flex;align-items:center;justify-content:center;transition:.15s;}
.cb-send:hover{background:#8b181c;transform:scale(1.08);}
.cb-send:disabled{opacity:.3;cursor:default;transform:none;}
.cb-footer-brand{display:flex;align-items:center;justify-content:center;gap:5px;margin-top:6px;opacity:.55;}
.cb-footer-brand img{height:12px;object-fit:contain;}
.cb-footer-brand span{font-size:.58rem;color:#94a3b8;font-weight:600;}

/* Animations */
@keyframes cb-slidein{from{opacity:0;transform:scale(.92) translateY(12px);}to{opacity:1;transform:none;}}
@keyframes cb-bounce{0%,80%,100%{transform:translateY(0);}40%{transform:translateY(-6px);}}
@keyframes cb-shimmer{0%{background-position:0%;}100%{background-position:200%;}}

/* Mobile */
@media(max-width:480px){
  #cb-window{width:calc(100vw - 12px);right:6px;bottom:76px;height:calc(100svh - 90px);border-radius:20px 20px 16px 16px;}
  .cb-quick-grid{grid-template-columns:1fr 1fr 1fr;}
}
/* === Views\Feed\_FeedPosts.cshtml === */
/* ── Facebook-style post card ── */
.fb-post-card { background:#fff; border-radius:12px; box-shadow:0 1px 3px rgba(0,0,0,.1); margin-bottom:16px; overflow:hidden; }
.fb-post-header { display:flex; align-items:center; gap:10px; padding:14px 16px 0; }
.fb-post-avatar { width:44px; height:44px; border-radius:50%; object-fit:cover; flex-shrink:0; border:2px solid #e4e6eb; }
.fb-post-meta { flex:1; min-width:0; }
.fb-post-author { font-weight:700; font-size:15px; color:#050505; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.fb-post-role { font-size:11px; font-weight:600; padding:2px 8px; border-radius:12px; }
.fb-post-role.employer { background:#fff0f0; color:#A11D21; }
.fb-post-role.admin { background:#fce8e8; color:#dc2626; }
.fb-post-role.candidate { background:#e8fce8; color:#16a34a; }
.fb-post-time { font-size:13px; color:#65676b; display:flex; align-items:center; gap:4px; }
.fb-post-time i { font-size:10px; }
.fb-post-menu { position:relative; }
.fb-post-menu-btn { width:36px; height:36px; border-radius:50%; border:none; background:transparent;
    cursor:pointer; font-size:18px; color:#65676b; display:flex; align-items:center; justify-content:center; }
.fb-post-menu-btn:hover { background:#f0f2f5; }
.fb-post-menu-drop { display:none; position:absolute; right:0; top:100%; background:#fff;
    border-radius:10px; box-shadow:0 4px 16px rgba(0,0,0,.2); min-width:220px; z-index:10; padding:8px 0; }
.fb-post-menu-drop.open { display:block; }
.fb-post-menu-item { display:flex; align-items:center; gap:10px; padding:8px 16px; cursor:pointer;
    font-size:14px; color:#050505; }
.fb-post-menu-item:hover { background:#f0f2f5; }
.fb-post-menu-item i { width:20px; text-align:center; color:#65676b; }
.fb-post-hot { display:inline-flex; align-items:center; gap:4px; background:linear-gradient(135deg,#ef4444,#f97316);
    color:#fff; font-size:11px; font-weight:700; padding:3px 10px; border-radius:20px; margin:10px 16px 0; }
.fb-post-content { padding:10px 16px 14px; font-size:15px; line-height:1.55; color:#050505; white-space:pre-wrap; word-break:break-word; }
.fb-post-image-wrap { position:relative; cursor:pointer; overflow:hidden; background:#f0f2f5; }
.fb-post-image { width:100%; max-height:520px; object-fit:cover; display:block; transition:transform .3s; }
.fb-post-image:hover { transform:scale(1.01); }
/* ── Reactions bar ── */
.fb-post-stats { display:flex; justify-content:space-between; padding:10px 16px; font-size:14px; color:#65676b; }
.fb-post-stats-left { display:flex; align-items:center; gap:4px; }
.fb-post-stats-left .reaction-icons-mini { display:inline-flex; }
.fb-post-stats-left .reaction-icons-mini span { width:22px; height:22px; border-radius:50%;
    display:inline-flex; align-items:center; justify-content:center; overflow:hidden;
    margin-right:-5px; border:2px solid #fff; position:relative; background:#f0f2f5; }
.fb-post-stats-left .reaction-icons-mini span img { width:20px; height:20px; object-fit:contain; }
.fb-post-divider { height:1px; background:#e4e6eb; margin:0 16px; }
.fb-post-actions { display:flex; padding:4px 16px; position:relative; }
.fb-action-btn { flex:1; display:flex; align-items:center; justify-content:center; gap:6px;
    padding:8px 0; border:none; background:transparent; border-radius:8px;
    font-size:14px; font-weight:600; color:#65676b; cursor:pointer; transition:background .15s; position:relative; }
.fb-action-btn:hover { background:#f0f2f5; }
.fb-action-btn.liked { color:#A11D21; }
.fb-action-btn.reacted-love { color:#e74c3c; }
.fb-action-btn.reacted-haha { color:#f7b928; }
.fb-action-btn.reacted-wow { color:#f7b928; }
.fb-action-btn.reacted-sad { color:#f7b928; }
.fb-action-btn.reacted-angry { color:#e67e22; }
.fb-action-btn i { font-size:18px; transition:transform .2s; }
/* Feed share button should not be overridden by article .share-btn */
.fb-post-actions .fb-action-btn.share-btn { width:auto; height:auto; border-radius:8px; border:none;
    display:flex; align-items:center; justify-content:center; gap:6px; }
/* ── Reaction picker popup — Facebook style ── */
.fb-reaction-picker {
    display: flex;
    position: absolute;
    bottom: calc(100% + 10px);
    left: -8px;
    background: #fff;
    border-radius: 40px;
    box-shadow: 0 2px 16px rgba(0,0,0,.18), 0 0 0 1px rgba(0,0,0,.07);
    padding: 6px 10px;
    gap: 2px;
    z-index: 200;
    white-space: nowrap;
    /* hidden state */
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: scale(.8) translateY(8px);
    transform-origin: bottom left;
    transition: opacity .18s ease, transform .18s ease, visibility 0s linear .18s;
}
/* Bridge gap so mouse can move from button to picker without losing hover */
.fb-reaction-picker::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    height: 14px;
}
/* Show on hover with 380ms delay */
.fb-action-btn:hover .fb-reaction-picker,
.fb-reaction-picker:hover {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
    transition: opacity .18s ease .38s, transform .2s cubic-bezier(.34,1.56,.64,1) .38s, visibility 0s linear .38s;
}

/* Individual reaction item */
.fb-reaction-emoji {
    position: relative;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 4px 3px 2px;
    border-radius: 50%;
}
.fb-reaction-emoji img {
    width: 44px;
    height: 44px;
    display: block;
    transition: transform .22s cubic-bezier(.175,.885,.32,1.275), filter .2s;
    will-change: transform;
}
.fb-reaction-emoji:hover img {
    transform: scale(1.42) translateY(-8px);
    filter: drop-shadow(0 3px 6px rgba(0,0,0,.22));
}
/* Tooltip label above the floating emoji */
.fb-reaction-emoji .rlabel {
    position: absolute;
    bottom: calc(100% + 2px);
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,.72);
    color: #fff;
    font-size: 10px;
    font-weight: 600;
    padding: 3px 9px;
    border-radius: 12px;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity .14s ease .05s;
    z-index: 1;
}
.fb-reaction-emoji:hover .rlabel { opacity: 1; }

/* Button: SVG image when user has reacted (must match mini icon size/style) */
.like-reaction-img { width: 22px; height: 22px; object-fit: contain; display:block; }

/* Mini reaction icons next to like count — circular badge */
.ri { display:inline-flex; align-items:center; justify-content:center;
    width:22px; height:22px; border-radius:50%; border:2px solid #fff;
    overflow:hidden; background:#f0f2f5; flex-shrink:0; }
.ri img { width:20px; height:20px; object-fit:contain; display:block; }
/* ── Comments section ── */
.fb-comments-section { padding:4px 16px 12px; }
.fb-comments-list { }
.fb-comment { display:flex; gap:8px; margin-bottom:8px; align-items:flex-start; }
.fb-comment-avatar { width:32px; height:32px; border-radius:50%; object-fit:cover; flex-shrink:0; }
.fb-comment-bubble { background:#f0f2f5; padding:8px 12px; border-radius:18px; flex:1; min-width:0; }
.fb-comment-bubble strong { font-size:13px; color:#050505; }
.fb-comment-bubble div { font-size:14px; color:#050505; word-break:break-word; }
.fb-comment-meta { display:flex; gap:12px; padding-left:40px; margin-top:2px; margin-bottom:4px; }
.fb-comment-meta span { font-size:12px; color:#65676b; cursor:pointer; font-weight:600; }
.fb-comment-meta span:hover { text-decoration:underline; }
.fb-comment-form { display:flex; gap:8px; align-items:center; margin-top:4px; }
.fb-comment-form img { width:32px; height:32px; border-radius:50%; object-fit:cover; flex-shrink:0; }
.fb-comment-input-wrap { flex:1; display:flex; align-items:center; background:#f0f2f5; border-radius:22px;
    padding:6px 12px; gap:6px; }
.fb-comment-input-wrap input { flex:1; border:none; background:transparent; outline:none; font-size:14px; }
.fb-comment-input-wrap input::placeholder { color:#65676b; }
.fb-comment-input-wrap button { border:none; background:transparent; color:#A11D21; cursor:pointer;
    font-size:16px; padding:2px; opacity:.7; }
.fb-comment-input-wrap button:hover { opacity:1; }
/* ── View more comments ── */
.fb-view-comments { font-size:14px; font-weight:600; color:#65676b; cursor:pointer;
    padding:4px 0; border:none; background:transparent; }
.fb-view-comments:hover { text-decoration:underline; }
/* === Views\Article\Detail.cshtml === */
.article-header { background: linear-gradient(135deg, #A11D21 0%, #0f172a 100%); padding: 40px 0 32px; }
    .article-breadcrumb a { color: rgba(255,255,255,0.7); text-decoration: none; font-size: 13px; }
    .article-breadcrumb a:hover { color: #fff; }
    .article-breadcrumb span { color: rgba(255,255,255,0.5); }

    .article-content { font-size: 16px; line-height: 1.9; color: #334155; }
    .article-content h2 { font-size: 1.5rem; font-weight: 700; margin-top: 32px; margin-bottom: 16px; color: #1e293b; }
    .article-content h3 { font-size: 1.25rem; font-weight: 700; margin-top: 24px; margin-bottom: 12px; color: #1e293b; }
    .article-content p { margin-bottom: 16px; }
    .article-content img { max-width: 100%; height: auto; border-radius: 12px; margin: 16px 0; }
    .article-content blockquote { border-left: 4px solid #A11D21; padding: 16px 24px; margin: 20px 0; background: #fff0f0; border-radius: 0 8px 8px 0; font-style: italic; color: #475569; }
    .article-content pre { background: #1e293b; color: #e2e8f0; padding: 20px; border-radius: 12px; overflow-x: auto; margin: 16px 0; }
    .article-content code { background: #f1f5f9; padding: 2px 6px; border-radius: 4px; font-size: 0.9em; color: #e11d48; }
    .article-content pre code { background: transparent; color: inherit; padding: 0; }
    .article-content ul, .article-content ol { padding-left: 24px; margin-bottom: 16px; }
    .article-content li { margin-bottom: 8px; }
    .article-content table { width: 100%; border-collapse: collapse; margin: 16px 0; border-radius: 8px; overflow: hidden; }
    .article-content table th { background: #f8fafc; font-weight: 600; }
    .article-content table td, .article-content table th { padding: 10px 14px; border: 1px solid #e2e8f0; }
    .article-content a { color: #A11D21; text-decoration: underline; }

    .article-meta { font-size: 13px; color: #94a3b8; }
    .article-tag { display: inline-block; padding: 4px 12px; border-radius: 16px; font-size: 12px; background: #f1f5f9; color: #475569; text-decoration: none; margin: 2px; }
    .article-tag:hover { background: #A11D21; color: #fff; }

    .related-card { border: none; border-radius: 12px; overflow: hidden; transition: all .3s; }
    .related-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,0.1) !important; }
    .related-card img { height: 150px; object-fit: cover; }
    .related-card .card-title { font-size: 14px; font-weight: 600; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
    .related-card .card-title a { color: #1e293b; text-decoration: none; }

    .share-btn { width: 36px; height: 36px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; border: 1px solid #e2e8f0; color: #64748b; text-decoration: none; transition: all .2s; }
    .share-btn:hover { color: #fff; }
    .share-btn.fb:hover { background: #1877f2; border-color: #1877f2; }
    .share-btn.tw:hover { background: #1da1f2; border-color: #1da1f2; }
    .share-btn.ln:hover { background: #0a66c2; border-color: #0a66c2; }
    .share-btn.cp:hover { background: #475569; border-color: #475569; }
/* === Views\Article\Index.cshtml === */
.news-hero { background: linear-gradient(135deg,#A11D21 0%,#1a0608 55%,#0f172a 100%); padding: 52px 0 36px; position:relative; overflow:hidden; }
    .news-hero::after { content:''; position:absolute; right:-60px; top:-60px; width:240px; height:240px; border-radius:50%; background:rgba(255,255,255,.04); }
    .news-hero .container { position:relative; z-index:1; }
    .news-hero h1 { font-size: 2.1rem; font-weight: 900; color: #fff; line-height:1.2; margin-bottom:.5rem; }
    .news-hero h1 i { opacity:.7; font-size:1.6rem; }
    .news-hero p { color: rgba(255,255,255,0.72); font-size: .93rem; margin-bottom:1.25rem; }
    .news-hero .input-group { border-radius:12px; overflow:hidden; box-shadow:0 4px 20px rgba(0,0,0,.25); }
    .news-hero .input-group .form-control { border:none; padding:.75rem 1rem; font-size:.9rem; }
    .news-hero .input-group .btn-light { border:none; padding:.75rem 1.25rem; font-weight:600; }

    .article-card { border: none; border-radius: 12px; overflow: hidden; transition: all .3s; background: #fff; height: 100%; }
    .article-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,0.12) !important; }
    .article-card .card-img-top { height: 200px; object-fit: cover; }
    .article-card .card-body { padding: 20px; }
    .article-card .card-title { font-weight: 700; font-size: 1rem; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
    .article-card .card-title a { color: #1e293b; text-decoration: none; }
    .article-card .card-title a:hover { color: #A11D21; }
    .article-card .card-text { font-size: 13px; color: #64748b; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
    .article-card .card-meta { font-size: 12px; color: #94a3b8; }

    .featured-card { border-radius: 16px; overflow: hidden; position: relative; height: 100%; min-height: 300px; }
    .featured-card img { width: 100%; height: 100%; object-fit: cover; }
    .featured-card .featured-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px; background: linear-gradient(transparent, rgba(0,0,0,0.85)); }
    .featured-card .featured-title { color: #fff; font-weight: 700; font-size: 1.3rem; margin-bottom: 8px; }
    .featured-card .featured-title a { color: #fff; text-decoration: none; }
    .featured-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,0.2) !important; }

    .cat-pill { display: inline-block; padding: 6px 16px; border-radius: 20px; font-size: 13px; font-weight: 500; text-decoration: none; border: 1px solid #e2e8f0; color: #475569; background: #fff; transition: all .2s; }
    .cat-pill:hover, .cat-pill.active { background: #A11D21; color: #fff; border-color: #A11D21; }

    .sidebar-widget { background: #fff; border-radius: 12px; padding: 20px; margin-bottom: 20px; }
    .sidebar-widget h6 { font-weight: 700; font-size: 14px; margin-bottom: 16px; padding-bottom: 8px; border-bottom: 2px solid #e2e8f0; }
/* === Views\Company\Index.cshtml === */
.co-hero{background:linear-gradient(135deg,#A11D21 0%,#1a0608 55%,#0f172a 100%);padding:52px 0 36px;position:relative;overflow:hidden;}
.co-hero::before{content:'';position:absolute;left:-60px;bottom:-60px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.04);}
.co-hero h1{font-size:2.1rem;font-weight:900;color:#fff;margin-bottom:.5rem;line-height:1.2;}
.co-hero h1 i{opacity:.7;font-size:1.6rem;}
.co-hero p{color:rgba(255,255,255,.75);font-size:.93rem;margin-bottom:1.5rem;}
.co-filter-bar{display:flex;gap:10px;flex-wrap:wrap;}
.co-filter-bar input,.co-filter-bar .form-select{flex:1;min-width:160px;border-radius:12px;border:none;padding:11px 16px;font-size:.875rem;background:#fff;color:#1e293b;box-shadow:none;}
.co-filter-bar input:focus,.co-filter-bar .form-select:focus{outline:2px solid rgba(255,255,255,.5);box-shadow:none;}
.co-filter-bar .co-search-btn{padding:11px 28px;border-radius:12px;background:rgba(255,255,255,.2);color:#fff;font-weight:700;font-size:.875rem;border:2px solid rgba(255,255,255,.4);transition:all .2s;white-space:nowrap;}
.co-filter-bar .co-search-btn:hover{background:rgba(255,255,255,.32);}
.co-results-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;font-size:14px;color:#64748b;}
.co-results-bar strong{color:#1e293b;}
/* Company card */
.co-card{border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.07);transition:all .25s cubic-bezier(.4,0,.2,1);height:100%;display:flex;flex-direction:column;text-decoration:none;color:inherit;border:1px solid #f1f5f9;}
.co-card:hover{transform:translateY(-5px);box-shadow:0 14px 36px rgba(0,0,0,.13);text-decoration:none;color:inherit;border-color:#fca5a5;}
.co-card-cover{height:80px;position:relative;flex-shrink:0;}
.co-logo-wrap{width:64px;height:64px;border-radius:12px;overflow:hidden;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.12);position:absolute;bottom:-28px;left:18px;background:#fff;}
.co-logo-wrap img{width:100%;height:100%;object-fit:contain;}
.co-logo-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;font-weight:800;color:#fff;}
.co-card-body{padding:36px 18px 18px;flex:1;display:flex;flex-direction:column;}
.co-card-name{font-weight:700;font-size:.95rem;color:#1e293b;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;}
.co-card-name:hover{color:#A11D21;}
.co-card-meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#64748b;flex:1;margin-bottom:12px;}
.co-card-meta span{display:flex;align-items:center;gap:5px;}
.co-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid #f1f5f9;}
.co-badge-jobs{background:#fef2f2;color:#A11D21;font-size:11.5px;font-weight:600;border-radius:20px;padding:3px 10px;}
.co-badge-followers{font-size:11px;color:#94a3b8;display:flex;align-items:center;gap:3px;}
/* cover gradients — cycle by card index */
.co-cover-0{background:linear-gradient(135deg,#667eea,#764ba2);}
.co-cover-1{background:linear-gradient(135deg,#f093fb,#f5576c);}
.co-cover-2{background:linear-gradient(135deg,#4facfe,#00f2fe);}
.co-cover-3{background:linear-gradient(135deg,#43e97b,#38f9d7);}
.co-cover-4{background:linear-gradient(135deg,#fa709a,#fee140);}
.co-cover-5{background:linear-gradient(135deg,#a18cd1,#fbc2eb);}
/* === Views\Pricing\Index.cshtml === */
.pricing-hero { background: linear-gradient(135deg, #A11D21 0%, #0f172a 100%); color: #fff; padding: 60px 0 80px; text-align: center; }
    .pricing-tabs { background: #fff; border-bottom: 2px solid #e5e7eb; }
    .pricing-tab-btn { padding: 14px 32px; border: none; background: none; font-weight: 600; font-size: 15px; color: #6b7280; cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -2px; transition: all .2s; }
    .pricing-tab-btn.active { color: #A11D21; border-bottom-color: #A11D21; }
    .plan-card { border-radius: 16px; border: 2px solid #e5e7eb; padding: 28px 24px; padding-top: 36px; position: relative; transition: all .25s; height: 100%; }
    .plan-card.has-badge { margin-top: 18px; }
    .plan-card:hover { border-color: #A11D21; transform: translateY(-4px); box-shadow: 0 12px 32px rgba(161,29,33,.12); }
    .plan-card.popular { border-color: #A11D21; box-shadow: 0 8px 32px rgba(161,29,33,.15); }
    .popular-badge { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: linear-gradient(90deg, #A11D21, #0f172a); color: #fff; padding: 4px 20px; border-radius: 20px; font-size: 12px; font-weight: 700; white-space: nowrap; z-index: 2; }
    .current-badge { position: absolute; top: -14px; right: 16px; background: #059669; color: #fff; padding: 4px 12px; border-radius: 20px; font-size: 11px; font-weight: 700; white-space: nowrap; z-index: 2; }
    .label-badge { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); color: #fff; padding: 4px 14px; border-radius: 20px; font-size: 11px; font-weight: 700; white-space: nowrap; z-index: 2; }
    .plan-name { font-size: 20px; font-weight: 800; }
    .plan-price { font-size: 32px; font-weight: 800; color: #0f172a; line-height: 1; }
    .plan-price-note { font-size: 13px; color: #6b7280; }
    .plan-feature { display: flex; align-items: flex-start; gap: 8px; font-size: 14px; padding: 5px 0; }
    .plan-feature .check { color: #059669; flex-shrink: 0; margin-top: 2px; }
    .plan-feature .dash { color: #d1d5db; flex-shrink: 0; }
    .feature-val { font-size: 14px; }
    .feature-val.green { color: #059669; font-weight: 600; }
    .btn-plan { width: 100%; padding: 12px; border-radius: 10px; font-weight: 700; font-size: 15px; margin-top: 20px; transition: all .2s; }
    .btn-plan-primary { background: linear-gradient(135deg,#A11D21,#7f1417); color: #fff; border: none; box-shadow: 0 3px 10px rgba(161,29,33,.25); }
    .btn-plan-primary:hover { background: linear-gradient(135deg,#8a1519,#6b1012); color: #fff; transform: translateY(-1px); }
    .btn-plan-outline { background: #fff; color: #A11D21; border: 2px solid #A11D21; }
    .btn-plan-outline:hover { background: #fff0f0; }
    .btn-plan-current { background: #f3f4f6; color: #6b7280; border: 2px solid #e5e7eb; cursor: default; }
    .comparison-table th { background: #f8fafc; font-weight: 700; text-align: center; padding: 12px; font-size: 13px; }
    .comparison-table td { text-align: center; padding: 10px 12px; vertical-align: middle; font-size: 13px; border-bottom: 1px solid #f3f4f6; }
    .comparison-table td:first-child { text-align: left; color: #374151; }
    .employer-card { border-radius: 16px; padding: 28px; padding-top: 36px; border: 2px solid #e5e7eb; height: 100%; transition: all .25s; position: relative; }
    .employer-card.has-badge { margin-top: 18px; }
    .employer-card:hover { border-color: var(--plan-color); box-shadow: 0 8px 32px rgba(0,0,0,.1); transform: translateY(-3px); }
    .employer-card.popular { border-color: var(--plan-color); }
    .employer-icon { width: 52px; height: 52px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 22px; color: #fff; margin-bottom: 16px; }
    .highlight-chip { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: 12px; font-weight: 600; margin: 2px; }
    .faq-item { border: 1px solid #e5e7eb; border-radius: 10px; margin-bottom: 10px; overflow: hidden; }
    .faq-q { padding: 16px 20px; font-weight: 600; cursor: pointer; display: flex; justify-content: space-between; align-items: center; background: #fafafa; }
    .faq-a { padding: 14px 20px; font-size: 14px; color: #4b5563; line-height: 1.7; border-top: 1px solid #e5e7eb; display: none; }
    .faq-item.open .faq-a { display: block; }
    .faq-item.open .faq-q { background: #fff0f0; color: #A11D21; }
/* ================================================ */
/* === UTILITY CLASSES (replace inline styles) === */
/* ================================================ */

/* Font sizes */
.fs-10 { font-size: 10px !important; }
.fs-11 { font-size: 11px !important; }
.fs-12 { font-size: 12px !important; }
.fs-13 { font-size: 13px !important; }
.fs-14 { font-size: 14px !important; }
.fs-85 { font-size: 0.85rem !important; }
.fs-80 { font-size: 0.80rem !important; }

/* Border radius */
.rounded-4 { border-radius: 1rem !important; }
.rounded-3x { border-radius: 0.75rem !important; }
.rounded-14 { border-radius: 14px !important; }
.rounded-top-4 { border-radius: 1rem 1rem 0 0 !important; }
.rounded-top-14 { border-radius: 14px 14px 0 0 !important; }

/* Sizing */
.sz-32 { width: 32px !important; height: 32px !important; }
.sz-36 { width: 36px !important; height: 36px !important; }
.sz-40 { width: 40px !important; height: 40px !important; }
.sz-44 { width: 44px !important; height: 44px !important; }
.sz-48 { width: 48px !important; height: 48px !important; }
.sz-56 { width: 56px !important; height: 56px !important; }
.sz-64 { width: 64px !important; height: 64px !important; }
.sz-100 { width: 100px !important; height: 100px !important; }
.sz-140 { width: 140px !important; height: 140px !important; }

/* Brand color */
.text-brand { color: #A11D21 !important; }
.bg-brand { background-color: #A11D21 !important; }
.bg-brand-gradient { background: linear-gradient(135deg, #A11D21, #c0392b) !important; }
.border-brand { border-color: #A11D21 !important; }

/* Max width utility */
.mw-150 { max-width: 150px !important; }
.mw-200 { max-width: 200px !important; }

/* Object fit */
.obj-cover { object-fit: cover !important; }
.obj-contain { object-fit: contain !important; }

/* Card shadow modern */
.card-modern {
    border: none !important;
    border-radius: 1rem !important;
    box-shadow: 0 2px 10px rgba(0,0,0,.06) !important;
    transition: box-shadow 0.3s ease, transform 0.2s ease;
}
.card-modern:hover {
    box-shadow: 0 8px 25px rgba(0,0,0,.1) !important;
    transform: translateY(-2px);
}

/* ============================================================
   Job/Index — search hero + sidebar filters + job list
   ============================================================ */
.search-hero{background:linear-gradient(135deg,#A11D21 0%,#1a0203 60%,#0f172a 100%);padding:2.5rem 0 1.75rem;position:relative;overflow:hidden;}
.search-hero::after{content:'';position:absolute;right:-80px;top:-80px;width:320px;height:320px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none;}
.search-hero h1{color:#fff;font-size:1.65rem;font-weight:900;margin-bottom:.4rem;line-height:1.2;}
.search-hero p{color:rgba(255,255,255,.72);font-size:.9rem;margin-bottom:1.25rem;}
.hero-bar{background:#fff;border-radius:14px;display:flex;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.25),0 1px 0 rgba(255,255,255,.15) inset;}
.hero-bar input[type=text]{flex:1;border:none;outline:none;padding:.78rem 1rem;font-size:.92rem;min-width:0;color:#111827;}
.hero-bar .hero-sep{display:none;}
.hero-bar select{display:none;}
.hero-bar .hero-btn{background:linear-gradient(135deg,#A11D21,#c92428);color:#fff;border:none;padding:.78rem 1.5rem;font-weight:700;font-size:.9rem;cursor:pointer;white-space:nowrap;transition:opacity .15s;flex-shrink:0;display:flex;align-items:center;gap:6px;}
.hero-bar .hero-btn:hover{opacity:.88;}
.hero-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.8rem;align-items:center;}
.hero-tag-label{color:rgba(255,255,255,.55);font-size:.76rem;}
.hero-tag{background:rgba(255,255,255,.13);color:#fff;border:1px solid rgba(255,255,255,.22);border-radius:20px;padding:.18rem .7rem;font-size:.76rem;text-decoration:none;transition:background .15s;}
.hero-tag:hover{background:rgba(255,255,255,.26);color:#fff;}
/* ══ Job Filter Bar ══ */
.jf-filter-bar{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:64px;z-index:200;transition:box-shadow .2s;}
.jf-filter-bar.scrolled{box-shadow:0 2px 12px rgba(0,0,0,.09);}
.jf-fb-inner{display:flex;align-items:center;gap:6px;padding:8px 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.jf-fb-inner::-webkit-scrollbar{display:none;}
.jf-fb-divider{width:1px;background:#e5e7eb;height:22px;flex-shrink:0;margin:0 4px;}
.jf-fb-clear{display:inline-flex;align-items:center;gap:5px;padding:.3rem .8rem;border-radius:20px;font-size:.78rem;font-weight:600;color:#6b7280;background:#f3f4f6;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:all .15s;}
.jf-fb-clear:hover{background:#fee2e2;color:#A11D21;}
.jf-fb-clear-badge{background:#A11D21;color:#fff;border-radius:10px;padding:.05rem .4rem;font-size:.68rem;font-weight:700;}
/* Quick chip toggles */
.jf-chip{display:inline-flex;align-items:center;gap:5px;padding:.3rem .85rem;border-radius:20px;border:1.5px solid #e5e7eb;background:#fff;font-size:.8rem;font-weight:600;color:#374151;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .15s;}
.jf-chip:hover{border-color:#A11D21;color:#A11D21;}
.jf-chip.active{border-color:#A11D21;background:#A11D21;color:#fff;}
.jf-chip--near{border-color:#2563eb;color:#2563eb;}
.jf-chip--near:hover{background:#eff6ff;border-color:#1d4ed8;}
.jf-chip--near.active{background:#2563eb;border-color:#2563eb;color:#fff;}
.jf-chip--near:disabled{opacity:.65;cursor:not-allowed;}
/* Dropdown wrapper */
.jf-dd{position:relative;flex-shrink:0;}
.jf-dd-btn{display:inline-flex;align-items:center;gap:6px;padding:.3rem .85rem;border-radius:20px;border:1.5px solid #e5e7eb;background:#fff;font-size:.8rem;font-weight:600;color:#374151;cursor:pointer;white-space:nowrap;transition:all .15s;}
.jf-dd-btn:hover{border-color:#9ca3af;}
.jf-dd-btn.active{border-color:#A11D21;color:#A11D21;background:#fff0f0;}
.jf-dd-badge{background:#A11D21;color:#fff;border-radius:10px;padding:.04rem .38rem;font-size:.68rem;font-weight:700;}
.jf-dd-arrow{font-size:.62rem;color:#9ca3af;transition:transform .2s;flex-shrink:0;}
.jf-dd.open .jf-dd-arrow{transform:rotate(180deg);}
/* Dropdown panel — fixed to escape overflow-x:auto clipping */
.jf-dd-panel{display:none;position:fixed;min-width:220px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,.13);z-index:9100;overflow:hidden;}
.jf-dd.open .jf-dd-panel{display:block;animation:ddSlide .15s ease;}
@keyframes ddSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.jf-dd-search{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid #f3f4f6;}
.jf-dd-search i{color:#9ca3af;font-size:.75rem;flex-shrink:0;}
.jf-dd-search input{border:none;outline:none;font-size:.82rem;width:100%;color:#374151;}
.jf-dd-list{max-height:220px;overflow-y:auto;padding:4px 0;}
.jf-dd-list::-webkit-scrollbar{width:3px;}.jf-dd-list::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:3px;}
.jf-dd-item{display:flex;align-items:center;gap:8px;padding:.35rem .9rem;cursor:pointer;font-size:.835rem;color:#374151;transition:background .1s;}
.jf-dd-item:hover{background:#f9fafb;}
.jf-dd-item.checked{background:#fff5f5;color:#A11D21;font-weight:600;}
.jf-dd-item input[type=checkbox],.jf-dd-item input[type=radio]{width:14px;height:14px;accent-color:#A11D21;cursor:pointer;flex-shrink:0;margin:0;}
.jf-dd-footer{display:flex;gap:6px;padding:8px 10px;border-top:1px solid #f3f4f6;}
.jf-dd-footer button{flex:1;padding:.32rem .5rem;border-radius:7px;border:1.5px solid #e5e7eb;background:#fff;font-size:.78rem;font-weight:600;cursor:pointer;color:#374151;transition:all .15s;}
.jf-dd-footer button:hover{border-color:#9ca3af;}
.jf-dd-footer button.apply{border-color:#A11D21;background:#A11D21;color:#fff;}
.jf-dd-footer button.apply:hover{background:#8b1619;}
/* ── Location 2-panel ── */
.jf-loc-panel{min-width:500px !important;}
.jf-loc-panels{display:flex;border-bottom:1px solid #f3f4f6;}
.jf-loc-left{width:210px;flex-shrink:0;border-right:1px solid #f3f4f6;display:flex;flex-direction:column;}
.jf-loc-right{flex:1;display:flex;flex-direction:column;}
.jf-loc-search{display:flex;align-items:center;gap:7px;padding:8px 10px;border-bottom:1px solid #f3f4f6;}
.jf-loc-search i{color:#9ca3af;font-size:.72rem;flex-shrink:0;}
.jf-loc-search input{border:none;outline:none;font-size:.82rem;width:100%;color:#374151;}
.jf-loc-prov-list{flex:1;overflow-y:auto;max-height:240px;}
.jf-loc-prov-list::-webkit-scrollbar{width:3px;}.jf-loc-prov-list::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:3px;}
.jf-prov-item{display:flex;align-items:center;justify-content:space-between;padding:.38rem .85rem;cursor:pointer;font-size:.835rem;color:#374151;transition:background .1s;}
.jf-prov-item:hover{background:#f9fafb;}
.jf-prov-item.active{background:#fff5f5;color:#A11D21;font-weight:700;}
.jf-prov-arrow{font-size:.62rem;color:#d1d5db;}
.jf-prov-item.active .jf-prov-arrow{color:#A11D21;}
.jf-loc-ward-list{flex:1;overflow-y:auto;max-height:240px;padding:4px 0;}
.jf-loc-ward-list::-webkit-scrollbar{width:3px;}.jf-loc-ward-list::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:3px;}
.jf-ward-item{display:flex;align-items:center;gap:8px;padding:.32rem .9rem;cursor:pointer;font-size:.835rem;color:#374151;}
.jf-ward-item:hover{background:#f9fafb;}
.jf-ward-item input[type=checkbox]{width:14px;height:14px;accent-color:#A11D21;cursor:pointer;flex-shrink:0;margin:0;}
.jf-loc-footer{display:flex;gap:8px;padding:8px 10px;}
.jf-loc-footer button{flex:1;padding:.34rem .5rem;border-radius:8px;border:1.5px solid #e5e7eb;background:#fff;font-size:.79rem;font-weight:600;cursor:pointer;color:#374151;transition:all .15s;}
.jf-loc-footer button:hover{border-color:#9ca3af;}
.jf-loc-footer button.apply{border-color:#A11D21;background:#A11D21;color:#fff;}
.jf-loc-footer button.apply:hover{background:#8b1619;}
@media(max-width:600px){.jf-loc-panel{min-width:calc(100vw - 16px) !important;}.jf-loc-left{width:160px;}}
/* Salary grid inside dropdown */
/* Mobile bottom-sheet drag handle */
@media(max-width:767px){
  .jf-dd-panel::before{content:'';display:block;width:36px;height:4px;border-radius:2px;background:#e2e8f0;margin:10px auto 4px;flex-shrink:0;}
  .jf-dd-panel{animation:jf-sheet-up .22s ease!important;}
  @keyframes jf-sheet-up{from{transform:translateY(60px);opacity:.6;}to{transform:none;opacity:1;}}
  .jf-loc-panel{min-width:100%!important;}
  .jf-loc-left{width:140px!important;}
}

.jf-dd-salary-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;padding:8px;}
.jf-salary-btn{border:1.5px solid #e5e7eb;background:#fff;border-radius:8px;padding:.3rem .4rem;font-size:.775rem;cursor:pointer;text-align:center;transition:all .15s;font-weight:500;color:#374151;}
.jf-salary-btn:hover,.jf-salary-btn.active{border-color:#A11D21;background:#fff5f5;color:#A11D21;font-weight:700;}
/* Results area */
.jf-results{padding:1rem 0 2.5rem;}
.jf-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-bottom:.7rem;flex-wrap:wrap;}
.jf-count{font-size:.875rem;color:#6b7280;}
.jf-count strong{color:#111827;}
.sort-tabs{display:flex;gap:.25rem;flex-wrap:wrap;}
.sort-tab{border:1.5px solid #e5e7eb;background:#fff;border-radius:8px;padding:.3rem .75rem;font-size:.79rem;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none;color:#374151;}
.sort-tab:hover,.sort-tab.active{border-color:#A11D21;background:#A11D21;color:#fff;}
.af-bar{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.6rem;}
.af-tag{display:inline-flex;align-items:center;gap:.3rem;background:#fff0f0;color:#A11D21;border:1px solid #fecaca;border-radius:20px;padding:.18rem .6rem;font-size:.76rem;font-weight:600;}
.af-tag a{color:#A11D21;text-decoration:none;display:flex;align-items:center;line-height:1;}
.af-tag a:hover{color:#7f1518;}
.jf-pagination{display:flex;justify-content:center;gap:.3rem;flex-wrap:wrap;margin-top:1.1rem;}
.jf-pagination .jf-page{border:1.5px solid #e5e7eb;background:#fff;border-radius:8px;padding:.38rem .7rem;font-size:.83rem;font-weight:600;text-decoration:none;color:#374151;transition:all .15s;min-width:34px;text-align:center;display:inline-flex;align-items:center;justify-content:center;}
.jf-pagination .jf-page:hover,.jf-pagination .jf-page.active{border-color:#A11D21;background:#A11D21;color:#fff;}
@media(max-width:991px){
  .jf-filter-bar{top:58px;}
  .jf-dd-panel{min-width:200px;}
  /* Bigger touch targets on mobile */
  .jf-chip,.jf-dd-btn{padding:.45rem 1rem;font-size:.82rem;}
}

/* ============================================================
   Account/Register — two-column registration form
   ============================================================ */
.rp{min-height:calc(100vh - 72px);display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#f4f5f7;}
.rc{width:100%;max-width:960px;display:grid;grid-template-columns:1fr 380px;border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 8px 40px rgba(0,0,0,.07);animation:rUp .45s cubic-bezier(.4,0,.2,1) both;}
@keyframes rUp{from{opacity:0;transform:translateY(16px)}}
.rl{background:linear-gradient(160deg,#0f172a 0%,#1a0608 60%,#A11D21 100%);color:#fff;padding:2.5rem 2rem;display:flex;flex-direction:column;position:relative;overflow:hidden;}
.rl::before{content:'';position:absolute;bottom:-60px;left:-60px;width:200px;height:200px;border-radius:50%;background:rgba(161,29,33,.3);filter:blur(50px);}
.rl::after{content:'';position:absolute;top:30%;right:-20px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.03);filter:blur(30px);}
.rl-logo{width:auto;height:auto;background:none;border:none;border-radius:0;display:block;margin-bottom:2rem;position:relative;z-index:1;}
.rl-logo img{height:38px;filter:brightness(0) invert(1);opacity:.92;max-width:180px;object-fit:contain;}
.rl h2{font-size:1.7rem;font-weight:800;line-height:1.25;margin:0 0 1rem;position:relative;z-index:1;color:#fff;letter-spacing:-.3px;}
.rl h2 span{color:#fca5a5;display:block;}
.rl-sub{font-size:.8rem;color:rgba(255,255,255,.6);line-height:1.6;margin-bottom:2rem;position:relative;z-index:1;}
.rl-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem;position:relative;z-index:1;}
.rl-list li{display:flex;align-items:center;gap:.7rem;font-size:.78rem;color:rgba(255,255,255,.8);}
.rl-list i{font-size:.55rem;color:#4ade80;flex-shrink:0;width:16px;height:16px;background:rgba(74,222,128,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.rl-footer{margin-top:auto;padding-top:1.5rem;position:relative;z-index:1;font-size:.62rem;color:rgba(255,255,255,.3);}
.rr{padding:2.5rem 2.75rem;display:flex;flex-direction:column;justify-content:center;}
.rr-inner{max-width:420px;width:100%;margin:0 auto;}
.rr-h{text-align:left;margin-bottom:1.4rem;}
.rr-h h3{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 .3rem;line-height:1.3;}
.rr-h h3 span{color:#A11D21;}
.rr-h p{font-size:.82rem;color:#9ca3af;margin:0;line-height:1.5;}
.at-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:1.2rem;}
.at-card{cursor:pointer;border:1px solid #e5e7eb;border-radius:8px;padding:.55rem .45rem;display:flex;align-items:center;gap:.5rem;transition:all .18s;background:#fafbfc;user-select:none;}
.at-card:hover{border-color:#fca5a5;background:#fff;}
.at-ico{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.82rem;flex-shrink:0;transition:all .18s;}
.at-ico.c{background:#eff6ff;color:#3b82f6;}
.at-ico.e{background:#f0fdf4;color:#16a34a;}
.at-txt b{font-size:.78rem;display:block;color:#1f2937;font-weight:700;line-height:1.2;}
.at-txt small{font-size:.62rem;color:#9ca3af;}
.btn-check:checked+.at-card{border-color:#A11D21;box-shadow:0 0 0 2px rgba(161,29,33,.1);background:#fff;}
.btn-check:checked+.at-card .at-ico{background:#A11D21;color:#fff;}
.btn-check:checked+.at-card .at-txt b{color:#A11D21;}
.rf{margin-bottom:.8rem;position:relative;}
.rf label:not(.at-card){font-size:.8rem;font-weight:500;color:#374151;margin-bottom:5px;display:block;}
.rf label .req{color:#ef4444;}
.rf-wrap{position:relative;}
.rf-wrap .fi{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#b0b5bf;font-size:.78rem;pointer-events:none;transition:color .2s;z-index:2;}
.rf-wrap .form-control{padding:.65rem .75rem .65rem 2.15rem;border:1px solid #dde1e7;border-radius:6px;font-size:.875rem;font-weight:400;background:#fff;color:#111827;transition:border-color .15s,box-shadow .15s;}
.rf-wrap .form-control::placeholder{color:#c0c5cd;}
.rf-wrap .form-control:focus{border-color:#A11D21;background:#fff;box-shadow:0 0 0 3px rgba(161,29,33,.06);outline:none;}
.rf-wrap:focus-within .fi{color:#A11D21;}
.pw-t{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:#b0b5bf;cursor:pointer;padding:4px 6px;border-radius:6px;transition:all .15s;z-index:2;font-size:.82rem;}
.pw-t:hover{color:#A11D21;background:#fff0f0;}
.rf-wrap .form-control.pw-in{padding-right:2.4rem;}
.pw-str{height:2.5px;border-radius:2px;background:#e5e7eb;margin-top:4px;overflow:hidden;}
.pw-str-fill{height:100%;border-radius:2px;width:0;transition:all .35s;}
.pw-str-fill.w{width:25%;background:#ef4444;}
.pw-str-fill.m{width:60%;background:#f59e0b;}
.pw-str-fill.s{width:100%;background:#22c55e;}
.rt{display:flex;align-items:flex-start;gap:7px;margin-bottom:1rem;}
.rt input{accent-color:#A11D21;width:15px;height:15px;margin-top:1px;flex-shrink:0;cursor:pointer;}
.rt label{font-size:.72rem;color:#6b7280;line-height:1.5;cursor:pointer;}
.rt a{color:#A11D21;font-weight:600;text-decoration:none;}
.rt a:hover{text-decoration:underline;}
.btn-rg{width:100%;border:none;color:#fff;font-weight:600;font-size:.9rem;padding:.75rem;border-radius:6px;background:#A11D21;transition:background .15s,box-shadow .15s;letter-spacing:.2px;}
.btn-rg:hover{background:#8f1519;box-shadow:0 4px 12px rgba(161,29,33,.3);color:#fff;}
.r-div{position:relative;text-align:center;margin:.9rem 0;}
.r-div::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:#e5e7eb;}
.r-div span{position:relative;background:#fff;padding:0 .85rem;font-size:.78rem;color:#adb5bd;font-weight:400;}
.r-social{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:.85rem;}
.r-social a{display:flex;align-items:center;justify-content:center;gap:7px;padding:.58rem;border-radius:9px;border:1.5px solid #e5e7eb;background:#fff;text-decoration:none;transition:all .2s;font-size:.8rem;font-weight:600;color:#374151;}
.r-social a:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.1);}
.g-btn{background:#DB4437 !important;border-color:#DB4437 !important;color:#fff !important;}
.f-btn{background:#1877F2 !important;border-color:#1877F2 !important;color:#fff !important;}
.r-link{text-align:center;font-size:.82rem;color:#6b7280;margin-top:.65rem;}
.r-link a{color:#A11D21;font-weight:700;text-decoration:none;margin-left:3px;}
.r-help{text-align:center;margin-top:1.1rem;padding-top:1rem;border-top:1px solid #f3f4f6;}
.r-help p{font-size:.72rem;color:#9ca3af;margin:0 0 2px;font-weight:600;}
.r-help span{font-size:.72rem;color:#6b7280;}
.r-help a{color:#A11D21;font-weight:700;text-decoration:none;}
.r-trust{display:flex;align-items:center;justify-content:center;gap:1.25rem;margin-top:1rem;padding-top:.85rem;border-top:1px solid #f3f4f6;}
.r-trust span{font-size:.65rem;color:#b0b5bf;display:flex;align-items:center;gap:4px;}
.r-trust i{color:#22c55e;font-size:.62rem;}
.rl-mob{display:none;background:linear-gradient(135deg,#0f172a,#A11D21);padding:.85rem 1.15rem;align-items:center;gap:.65rem;border-radius:18px 18px 0 0;}
.rl-mob-ico{width:34px;height:34px;background:rgba(255,255,255,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.rl-mob-ico img{height:17px;filter:brightness(0) invert(1);}
@media(max-width:991.98px){.rp{padding:.75rem;align-items:flex-start;padding-top:1rem;}.rc{grid-template-columns:1fr;max-width:480px;}.rl{display:none;}.rl-mob{display:flex;}.rr{padding:1.25rem 1.15rem 1.5rem;}}

/* ============================================================
   Job/Detail — job detail page sections
   ============================================================ */
.jd-section-title{font-size:1rem;font-weight:700;margin-bottom:1rem;display:flex;align-items:center;gap:8px;}
.jd-section-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:0.8rem;flex-shrink:0;}
.jd-info-row{display:flex;justify-content:space-between;align-items:baseline;padding:5px 0;font-size:0.875rem;}
.jd-info-row+.jd-info-row{border-top:1px solid #f3f4f6;}
.jd-info-label{color:#6b7280;flex-shrink:0;margin-right:8px;}
.jd-info-val{font-weight:600;text-align:right;}
.jd-benefit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:10px;}
.jd-benefit-badge{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;background:#f0f4ff;border:1px solid #c7d7fd;font-size:0.84rem;font-weight:600;color:#1e40af;}
.jd-benefit-badge .bi{font-size:1rem;}
.jd-video-wrap{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:10px;}
.jd-video-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;}
.jd-tag-badge{background:#e0e7ff;color:#3730a3;border-radius:4px;padding:3px 10px;font-size:0.78rem;font-weight:600;}
.jd-lang-badge{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0;border-radius:6px;padding:3px 10px;font-size:0.82rem;}
.jd-cover-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;font-size:0.82rem;font-weight:600;}
.jd-cover-required{background:#fff1f2;color:#be123c;border:1px solid #fecdd3;}
.jd-cover-optional{background:#fefce8;color:#854d0e;border:1px solid #fef08a;}
.jd-cover-hidden{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;}

/* ============================================================
   Job/Saved — saved jobs list
   ============================================================ */
.saved-page{background:#f1f5f9;min-height:calc(100vh - 70px);padding-bottom:60px;}
.saved-topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:14px 0;margin-bottom:24px;}
.saved-topbar h1{font-size:1.3rem;font-weight:800;color:#0f172a;margin:0;}
.saved-count-pill{display:inline-flex;align-items:center;gap:7px;background:#fff0f0;border:1.5px solid #fca5a5;color:#A11D21;border-radius:20px;padding:5px 14px;font-size:.8rem;font-weight:700;margin-bottom:18px;}
.saved-empty{text-align:center;padding:5rem 2rem;background:#fff;border-radius:16px;border:1px solid #e2e8f0;}
.saved-empty-icon{width:80px;height:80px;border-radius:50%;background:#fff0f0;color:#fca5a5;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;font-size:1.75rem;}

/* ============================================================
   Job/MyApplications — application tracker
   ============================================================ */
.app-page{background:#f1f5f9;min-height:calc(100vh - 70px);padding-bottom:60px;}
.app-topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:14px 0;margin-bottom:24px;}
.app-topbar h1{font-size:1.3rem;font-weight:800;color:#0f172a;margin:0;}
.app-stats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;}
.app-stat{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;padding:6px 16px;font-size:.8rem;font-weight:600;color:#374151;white-space:nowrap;}
.app-stat .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.app-list{display:flex;flex-direction:column;gap:10px;}
.app-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:1.1rem 1.375rem;display:flex;align-items:center;gap:1rem;transition:box-shadow .18s,border-color .18s;position:relative;overflow:hidden;}
.app-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--ac-color,#e2e8f0);border-radius:0 2px 2px 0;}
.app-card:hover{box-shadow:0 4px 18px rgba(0,0,0,.08);border-color:#cbd5e1;}
.app-logo{width:52px;height:52px;border-radius:12px;background:#f1f5f9;border:1px solid #e2e8f0;display:flex;align-items:center;justify-content:center;color:#94a3b8;flex-shrink:0;overflow:hidden;}
.app-logo img{width:100%;height:100%;object-fit:contain;}
.app-content{flex:1;min-width:0;}
.app-job-title{font-size:.92rem;font-weight:700;color:#0f172a;text-decoration:none;}
.app-job-title:hover{color:#A11D21;}
.app-company{font-size:.78rem;color:#64748b;margin-top:2px;}
.app-meta{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-top:8px;}
.app-meta-item{font-size:.73rem;color:#94a3b8;display:flex;align-items:center;gap:5px;}
.app-meta-item.viewed{color:#059669;}
.app-status{flex-shrink:0;text-align:right;}
.app-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:20px;font-size:.72rem;font-weight:700;border:1.5px solid transparent;}
.app-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0;}
.app-card.expired{opacity:.75;}
.app-expired-tag{font-size:.65rem;font-weight:700;background:#f1f5f9;color:#94a3b8;border-radius:20px;padding:2px 9px;margin-top:3px;display:inline-block;}
.app-empty{text-align:center;padding:5rem 2rem;background:#fff;border-radius:16px;border:1px solid #e2e8f0;}
.app-empty-icon{width:80px;height:80px;border-radius:50%;background:#f1f5f9;color:#94a3b8;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;font-size:1.75rem;}
@media(max-width:640px){.app-card{flex-wrap:wrap;}.app-actions{flex-direction:row;align-items:center;width:100%;justify-content:flex-end;}}

/* ============================================================
   Notifications/Index
   ============================================================ */
.notif-page{background:#f8fafc;min-height:calc(100vh - 70px);padding-bottom:60px;}
.notif-topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:14px 0;margin-bottom:24px;}
.notif-topbar h1{font-size:1.35rem;font-weight:700;color:#0f172a;margin:0;}
.notif-summary{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;}
.notif-pill{display:flex;align-items:center;gap:7px;padding:7px 16px;border-radius:20px;font-size:.82rem;font-weight:600;border:1.5px solid transparent;}
.notif-pill.all{background:#fff;border-color:#e2e8f0;color:#374151;}
.notif-pill.unread{background:#fff0f0;border-color:#fca5a5;color:#A11D21;}
.notif-pill .dot{width:8px;height:8px;border-radius:50%;background:currentColor;}
.notif-list{background:#fff;border-radius:14px;border:1px solid #e2e8f0;overflow:hidden;}
.notif-list-header{padding:14px 20px;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between;}
.notif-list-header h6{font-size:.9rem;font-weight:700;color:#0f172a;margin:0;}
.notif-item{display:flex;align-items:flex-start;gap:14px;padding:14px 20px;border-bottom:1px solid #f1f5f9;text-decoration:none!important;color:inherit!important;transition:background .15s;position:relative;}
.notif-item:last-child{border-bottom:none;}
.notif-item:hover{background:#fafbff;}
.notif-item.unread{background:#fffbfb;}
.notif-item.unread:hover{background:#fff5f5;}
.notif-item.unread::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:#A11D21;border-radius:0 2px 2px 0;}
.notif-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;}
.notif-body{flex:1;min-width:0;}
.notif-title{font-size:.875rem;color:#0f172a;line-height:1.45;margin-bottom:2px;}
.notif-item.unread .notif-title{font-weight:700;}
.notif-sub{font-size:.8rem;color:#64748b;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.notif-time{font-size:.72rem;color:#94a3b8;margin-top:4px;white-space:nowrap;}
.notif-dot{width:9px;height:9px;border-radius:50%;background:#A11D21;flex-shrink:0;margin-top:6px;}
.notif-empty{text-align:center;padding:4rem 2rem;}
.notif-empty-icon{width:80px;height:80px;border-radius:50%;background:#fde8e9;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;font-size:1.75rem;color:#A11D21;}

/* ============================================================
   Company/Dashboard — employer dashboard
   ============================================================ */
.db *,.db *::before,.db *::after{box-sizing:border-box;}
.db{display:flex;min-height:calc(100vh - 70px);background:#f0f2f5;font-family:inherit;}
.db-side{width:228px;flex-shrink:0;background:#fff;border-right:1px solid #e8ecf0;display:flex;flex-direction:column;position:sticky;top:70px;height:calc(100vh - 70px);overflow-y:auto;overflow-x:hidden;}
.db-side::-webkit-scrollbar{width:3px;}
.db-side::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:4px;}
.sb-co{padding:1.1rem 1rem .9rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;gap:10px;}
.sb-co-logo{width:42px;height:42px;border-radius:10px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;color:#94a3b8;flex-shrink:0;overflow:hidden;border:1px solid #e2e8f0;}
.sb-co-logo img{width:100%;height:100%;object-fit:contain;}
.sb-co-name{font-size:.8rem;font-weight:700;color:#1e293b;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:130px;}
.sb-co-status{font-size:.6rem;font-weight:700;padding:2px 7px;border-radius:20px;display:inline-block;margin-top:3px;}
.sb-status-ok{background:#dcfce7;color:#16a34a;}
.sb-status-pend{background:#fef9c3;color:#a16207;}
.sb-grp{font-size:.6rem;font-weight:800;color:#94a3b8;text-transform:uppercase;letter-spacing:1.5px;padding:.9rem 1rem .3rem;}
.sb-a{display:flex;align-items:center;gap:9px;padding:.52rem 1rem;font-size:.8rem;font-weight:500;color:#64748b;text-decoration:none;border-left:3px solid transparent;transition:all .15s;}
.sb-a i{width:16px;text-align:center;font-size:.8rem;flex-shrink:0;}
.sb-a:hover{color:#1e293b;background:#f8fafc;}
.sb-a.on{color:#A11D21;background:#fff5f5;border-left-color:#A11D21;font-weight:700;}
.db-main{flex:1;min-width:0;padding:1.5rem 1.75rem 3rem;}
.db-welcome{background:linear-gradient(120deg,#111827 0%,#1e3a6e 50%,#7f1d1d 100%);border-radius:14px;padding:1.375rem 1.75rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;position:relative;overflow:hidden;}
.db-welcome::after{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.04);top:-70px;right:40%;pointer-events:none;}
.db-welcome-hi{font-size:1.2rem;font-weight:800;color:#fff;margin:0 0 .25rem;position:relative;z-index:1;}
.db-welcome-sub{font-size:.78rem;color:rgba(255,255,255,.6);margin:0;position:relative;z-index:1;}
.db-welcome-btns{display:flex;gap:8px;flex-wrap:wrap;position:relative;z-index:1;}
.btn-red{background:#A11D21;color:#fff!important;border:none;border-radius:8px;padding:.45rem 1.1rem;font-size:.78rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:background .18s;}
.btn-red:hover{background:#8b181c;}
.btn-ghost{background:rgba(255,255,255,.1);color:rgba(255,255,255,.9)!important;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:.45rem 1.1rem;font-size:.78rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:background .18s;}
.btn-ghost:hover{background:rgba(255,255,255,.18);}
.db-alert{border-radius:10px;font-size:.83rem;padding:.55rem 1rem;margin-bottom:1.1rem;}
.db-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem;margin-bottom:1.25rem;}
.sc{background:#fff;border-radius:12px;padding:1.1rem 1.25rem;border:1px solid #e8ecf0;text-decoration:none;display:block;transition:box-shadow .18s,transform .18s;border-top:3px solid transparent;}
.sc:hover{box-shadow:0 6px 20px rgba(0,0,0,.08);transform:translateY(-2px);}
.sc.c-red{border-top-color:#A11D21;}
.sc.c-grn{border-top-color:#10b981;}
.sc.c-amb{border-top-color:#f59e0b;}
.sc.c-blu{border-top-color:#3b82f6;}
.sc-ico{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.9rem;margin-bottom:.75rem;}
.sc.c-red .sc-ico{background:#fff0f0;color:#A11D21;}
.sc.c-grn .sc-ico{background:#ecfdf5;color:#10b981;}
.sc.c-amb .sc-ico{background:#fffbeb;color:#f59e0b;}
.sc.c-blu .sc-ico{background:#eff6ff;color:#3b82f6;}
.sc-num{font-size:1.75rem;font-weight:900;color:#0f172a;line-height:1;}
.sc-lbl{font-size:.73rem;color:#64748b;font-weight:500;margin-top:4px;}
.sc.c-grn .sc-num{color:#059669;}
.sc.c-amb .sc-num{color:#d97706;}
.sc.c-blu .sc-num{color:#2563eb;}
.db-row2{display:grid;grid-template-columns:1fr 280px;gap:.875rem;margin-bottom:1.25rem;}
.pkg{background:linear-gradient(130deg,#111827 0%,#1e3764 55%,#A11D21 100%);border-radius:14px;padding:1.375rem 1.5rem;color:#fff;position:relative;overflow:hidden;}
.pkg::before{content:'';position:absolute;top:-55px;right:-55px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.05);pointer-events:none;}
.pkg-tag{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.45);margin-bottom:3px;}
.pkg-name{font-size:1.1rem;font-weight:800;margin:0 0 1rem;position:relative;z-index:1;}
.pkg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.625rem;position:relative;z-index:1;}
.pkg-cell .pl{font-size:.65rem;color:rgba(255,255,255,.5);}
.pkg-cell .pv{font-size:.9rem;font-weight:700;margin-top:2px;}
.pkg-hr{border:none;border-top:1px solid rgba(255,255,255,.1);margin:.875rem 0;}
.pkg-acts{display:flex;gap:7px;position:relative;z-index:1;}
.pkg-btn{padding:.38rem .95rem;border-radius:7px;font-size:.74rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:5px;}
.pkg-btn.wh{background:rgba(255,255,255,.95);color:#111827;}
.pkg-btn.wh:hover{background:#fff;color:#111827;}
.pkg-btn.ol{background:transparent;color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.2);}
.pkg-btn.ol:hover{background:rgba(255,255,255,.1);color:#fff;}
.pkg-empty-wrap{border:2px dashed #e2e8f0;border-radius:14px;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem 1.25rem;}
.pkg-empty-ico{width:52px;height:52px;background:#fef3c7;color:#d97706;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:.875rem;font-size:1.2rem;}
.qa-card{background:#fff;border-radius:14px;border:1px solid #e8ecf0;overflow:hidden;}
.qa-head{padding:.7rem 1rem;border-bottom:1px solid #f1f5f9;font-size:.82rem;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:7px;}
.qa-body{padding:.75rem;display:grid;grid-template-columns:1fr 1fr;gap:.5rem;}
.qa{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:.7rem .5rem;background:#f8fafc;border:1.5px solid #eef0f3;border-radius:10px;text-decoration:none;color:#475569;font-size:.72rem;font-weight:600;text-align:center;transition:all .15s;}
.qa-ico{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.85rem;}
.qa:hover{border-color:#fca5a5;background:#fff8f8;color:#A11D21;}
.qa:hover .qa-ico{background:#fde8e9!important;color:#A11D21!important;}
.db-card{background:#fff;border-radius:14px;border:1px solid #e8ecf0;overflow:hidden;margin-bottom:1.25rem;}
.db-ch{padding:.8rem 1.25rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between;gap:.75rem;}
.db-ch h6{font-size:.85rem;font-weight:700;color:#1e293b;margin:0;}
.db-cb{padding:0;}
.jt{width:100%;border-collapse:collapse;font-size:.82rem;}
.jt th{padding:.6rem 1rem;font-size:.68rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;background:#f8fafc;border-bottom:1px solid #e8ecf0;}
.jt td{padding:.8rem 1rem;border-bottom:1px solid #f8fafc;vertical-align:middle;}
.jt tbody tr:last-child td{border-bottom:none;}
.jt tbody tr:hover{background:#fafbff;}
.jt-title{font-weight:700;color:#1e293b;text-decoration:none;font-size:.83rem;}
.jt-title:hover{color:#A11D21;}
.db-charts{display:grid;grid-template-columns:1.5fr 1fr;gap:.875rem;margin-bottom:1.25rem;}
.cand-item{display:flex;align-items:center;gap:10px;padding:.65rem .875rem;border-bottom:1px solid #f8fafc;transition:background .15s;}
.cand-item:last-child{border-bottom:none;}
.cand-item:hover{background:#fafbff;}
.cand-item img{width:38px;height:38px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid #f1f5f9;}
.cand-info{flex:1;min-width:0;}
.cand-nm{font-size:.8rem;font-weight:700;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cand-jt{font-size:.71rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
@media(max-width:1280px){.db-stats{grid-template-columns:repeat(2,1fr);}.db-row2{grid-template-columns:1fr;}.pkg-grid{grid-template-columns:repeat(2,1fr);}.db-charts{grid-template-columns:1fr 1fr;}}
@media(max-width:991px){.db-side{display:none!important;}.db-main{padding:1rem;}}
@media(max-width:640px){.db-charts{grid-template-columns:1fr;}.db-stats{grid-template-columns:repeat(2,1fr);}.db-welcome{padding:1.1rem 1.25rem;}.db-welcome-hi{font-size:1.05rem;}}

/* ============================================================
   Company/MyPackage
   ============================================================ */
.pkg-page{background:#f8fafc;min-height:calc(100vh - 70px);padding-bottom:60px;}
.pkg-topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:14px 0;margin-bottom:24px;}
.pkg-topbar h1{font-size:1.35rem;font-weight:700;color:#0f172a;margin:0;}
.pkg-hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a6e 60%,#A11D21 100%);border-radius:16px;padding:2rem 2.5rem;color:#fff;position:relative;overflow:hidden;margin-bottom:24px;}
.pkg-hero::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.05);}
.pkg-hero::after{content:'';position:absolute;bottom:-40px;left:-40px;width:140px;height:140px;border-radius:50%;background:rgba(161,29,33,.2);}
.pkg-hero-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.55);margin-bottom:4px;}
.pkg-hero h2{font-size:1.6rem;font-weight:800;margin:0 0 .5rem;}
.pkg-hero-desc{font-size:.88rem;color:rgba(255,255,255,.75);margin-bottom:1.5rem;}
.pkg-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
.pkg-stat-box{background:rgba(255,255,255,.1);border-radius:10px;padding:.875rem 1rem;backdrop-filter:blur(4px);}
.pkg-stat-box .num{font-size:1.4rem;font-weight:800;}
.pkg-stat-box .lbl{font-size:.72rem;color:rgba(255,255,255,.6);margin-top:2px;}
.pkg-hero-actions{display:flex;gap:10px;margin-top:1.5rem;position:relative;z-index:1;}
.pkg-features{display:flex;flex-wrap:wrap;gap:8px;margin:1rem 0 0;}
.pkg-feat{background:rgba(255,255,255,.12);border-radius:20px;padding:4px 14px;font-size:.78rem;display:flex;align-items:center;gap:6px;}
.pkg-feat i{font-size:.7rem;}
.pkg-empty{border:2px dashed #e2e8f0;border-radius:16px;padding:3rem 2rem;text-align:center;background:#fff;margin-bottom:24px;}
.pkg-empty-icon{width:72px;height:72px;border-radius:50%;background:#fef3c7;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.5rem;color:#d97706;}
.pkg-card{background:#fff;border-radius:14px;border:1px solid #e2e8f0;overflow:hidden;}
.pkg-card-header{padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;gap:10px;}
.pkg-card-header h6{font-size:.92rem;font-weight:700;color:#0f172a;margin:0;flex:1;}
.pkg-table{width:100%;border-collapse:collapse;font-size:.86rem;}
.pkg-table th{padding:10px 16px;font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.04em;background:#f8fafc;border-bottom:1px solid #e2e8f0;}
.pkg-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;color:#374151;vertical-align:middle;}
.pkg-table tbody tr:last-child td{border-bottom:none;}
.pkg-table tbody tr:hover{background:#fafbff;}
.badge-active{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0;border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:700;}
.badge-expired{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0;border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:700;}
@media(max-width:768px){.pkg-stats{grid-template-columns:repeat(2,1fr);}.pkg-hero{padding:1.5rem;}}

/* ============================================================
   Company/CreateJob
   ============================================================ */
.jf-page{background:#f4f6f9;min-height:100vh;padding-bottom:60px;}
.jf-topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:14px 0;margin-bottom:0;}
.jf-topbar h1{font-size:1.5rem;font-weight:700;color:#1a202c;margin:0;text-transform:uppercase;letter-spacing:.03em;}
.jf-body{max-width:1200px;margin:0 auto;padding:24px 16px;}
.jf-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.08);margin-bottom:20px;overflow:hidden;}
.jf-section-header{background:#1e3a6e;color:#fff;padding:13px 20px;font-weight:700;font-size:.92rem;letter-spacing:.06em;text-transform:uppercase;}
.jf-section-body{padding:24px 20px;}
.jf-label{font-size:.85rem;font-weight:600;color:#374151;margin-bottom:5px;display:block;}
.jf-label .req{color:#e53e3e;margin-left:2px;}
.jf-hint{font-size:.78rem;color:#9ca3af;margin-top:3px;}
.jf-richtext{border:1px solid #d1d5db;border-radius:6px;overflow:hidden;}
.jf-richtext .toolbar{border-bottom:1px solid #e5e7eb;padding:6px 10px;background:#fafafa;display:flex;gap:4px;}
.jf-richtext .toolbar button{border:none;background:none;color:#374151;padding:3px 7px;border-radius:4px;font-size:.82rem;cursor:pointer;}
.jf-richtext .toolbar button:hover{background:#e5e7eb;}
.jf-richtext textarea{border:none;resize:vertical;min-height:160px;width:100%;padding:12px;font-size:.88rem;outline:none;}
.jf-salary-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.jf-salary-toggle{display:flex;border:1px solid #d1d5db;border-radius:6px;overflow:hidden;}
.jf-salary-toggle button{border:none;background:#f9fafb;color:#6b7280;padding:7px 18px;font-size:.85rem;cursor:pointer;transition:.15s;}
.jf-salary-toggle button.active{background:#1e3a6e;color:#fff;}
.jf-check-row{display:flex;flex-wrap:wrap;gap:12px 24px;}
.jf-check-item{display:flex;align-items:center;gap:7px;cursor:pointer;font-size:.88rem;}
.jf-check-item input[type=checkbox],.jf-check-item input[type=radio]{width:16px;height:16px;accent-color:#1e3a6e;cursor:pointer;}
.jf-benefits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;}
.jf-benefit-item{display:flex;align-items:center;gap:8px;font-size:.88rem;cursor:pointer;padding:8px 10px;border:1px solid #e5e7eb;border-radius:6px;transition:.15s;}
.jf-benefit-item:hover{border-color:#1e3a6e;background:#f0f4ff;}
.jf-benefit-item.checked{border-color:#1e3a6e;background:#eef2ff;}
.jf-benefit-item input[type=checkbox]{width:16px;height:16px;accent-color:#1e3a6e;}
.jf-benefit-icon{font-size:1.1rem;width:22px;text-align:center;}
.jf-tag-wrap{border:1px solid #d1d5db;border-radius:6px;padding:6px 8px;display:flex;flex-wrap:wrap;gap:6px;min-height:40px;cursor:text;}
.jf-tag-wrap input{border:none;outline:none;font-size:.85rem;flex:1;min-width:120px;}
.jf-tag{background:#e0e7ff;color:#3730a3;border-radius:4px;padding:2px 8px;font-size:.8rem;display:flex;align-items:center;gap:4px;}
.jf-tag .rm{cursor:pointer;font-size:.9rem;line-height:1;color:#6366f1;}
.btn-add-tag{background:#1e3a6e;color:#fff;border:none;border-radius:6px;padding:6px 16px;font-size:.82rem;cursor:pointer;}
/* ── Score bar ── */
.jf-score-total{display:flex;align-items:center;gap:12px;}
.jf-score-bar-wrap{flex:1;height:10px;background:#e5e7eb;border-radius:999px;overflow:hidden;}
.jf-score-bar{height:100%;background:#1e3a6e;border-radius:999px;transition:width .3s;}
.jf-score-badge{min-width:52px;text-align:center;font-size:.82rem;font-weight:700;color:#fff;background:#1e3a6e;border-radius:20px;padding:2px 10px;}
/* ── Score table ── */
.jf-score-table{width:100%;border-collapse:collapse;font-size:.86rem;}
.jf-score-table th{padding:8px 12px;background:#f1f5f9;color:#374151;font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid #e2e8f0;}
.jf-score-table td{padding:8px 12px;border-bottom:1px solid #f1f5f9;color:#374151;vertical-align:middle;}
.jf-score-table tbody tr:last-child td{border-bottom:none;}
.jf-score-input{width:72px;border:1px solid #d1d5db;border-radius:6px;padding:5px 8px;font-size:.85rem;text-align:center;color:#1e3a6e;font-weight:600;background:#f8fafc;}
.jf-score-input:focus{outline:none;border-color:#1e3a6e;background:#fff;}
.btn-reset-score{background:#f1f5f9;color:#374151;border:1px solid #d1d5db;border-radius:6px;padding:7px 22px;font-size:.84rem;font-weight:600;cursor:pointer;transition:.15s;}
.btn-reset-score:hover{background:#e2e8f0;border-color:#94a3b8;}
/* ── Notify email row ── */
.jf-notify-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px;}
.jf-notify-item{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fafbfc;font-size:.84rem;cursor:pointer;transition:.15s;}
.jf-notify-item:has(input:checked){background:#eef2ff;border-color:#1e3a6e;}
.jf-notify-item label{cursor:pointer;line-height:1.35;}
/* ── WFH toggle ── */
.jf-wfh-toggle{display:inline-flex;border:1.5px solid #d1d5db;border-radius:8px;overflow:hidden;margin-top:4px;}
.jf-wfh-toggle button{border:none;background:#f9fafb;color:#6b7280;padding:9px 22px;font-size:.875rem;font-weight:500;cursor:pointer;transition:.2s;display:flex;align-items:center;gap:7px;}
.jf-wfh-toggle button:first-child{border-right:1.5px solid #d1d5db;}
.jf-wfh-toggle button.active{background:#1e3a6e;color:#fff;font-weight:600;}
.jf-wfh-toggle button:not(.active):hover{background:#f1f5f9;color:#374151;}
/* ── Video & misc ── */
.jf-video-wrap{display:flex;gap:8px;align-items:center;}
.jf-video-wrap .form-control{flex:1;}
.btn-preview-yt{background:#f1f5f9;color:#374151;border:1px solid #d1d5db;border-radius:6px;padding:7px 14px;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:.15s;}
.btn-preview-yt:hover{background:#e2e8f0;}
.jf-char-hint{font-size:.75rem;color:#9ca3af;margin-top:4px;}
.jf-actions{background:#fff;border-top:1px solid #e5e7eb;padding:16px 0;position:sticky;bottom:0;z-index:10;}
.jf-actions .inner{max-width:1200px;margin:0 auto;padding:0 16px;display:flex;align-items:center;justify-content:center;gap:12px;}
.btn-cancel{background:#e5e7eb;color:#374151;border:none;border-radius:6px;padding:10px 28px;font-size:.9rem;font-weight:600;cursor:pointer;}
.btn-preview-job{background:#1e3a6e;color:#fff;border:none;border-radius:6px;padding:10px 28px;font-size:.9rem;font-weight:600;cursor:pointer;}
.btn-submit-job{background:#e11d48;color:#fff;border:none;border-radius:6px;padding:10px 28px;font-size:.9rem;font-weight:600;cursor:pointer;}
.btn-save-draft{background:#fff;color:#374151;border:1.5px solid #d1d5db;border-radius:6px;padding:10px 28px;font-size:.9rem;font-weight:600;cursor:pointer;}
.btn-publish-job{background:#16a34a;color:#fff;border:none;border-radius:6px;padding:10px 28px;font-size:.9rem;font-weight:600;cursor:pointer;}
.jf-draft-banner{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:12px 18px;margin-bottom:20px;display:flex;align-items:center;gap:10px;}
.jf-draft-banner i{color:#d97706;font-size:1.1rem;}
.jf-draft-banner span{font-size:.88rem;color:#92400e;font-weight:500;}
.jp-modal .modal-content{border-radius:16px;border:none;}
.jp-modal .modal-header{background:linear-gradient(135deg,#A11D21,#0f172a);color:#fff;border-radius:16px 16px 0 0;padding:1rem 1.5rem;}
.jp-modal .modal-header .btn-close{filter:invert(1);}
.jp-header{background:#f8fafc;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1rem;border:1px solid #e2e8f0;}
.jp-title{font-size:1.3rem;font-weight:700;color:#0f172a;margin-bottom:.5rem;}
.jp-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:.75rem;}
.jp-chip{display:inline-flex;align-items:center;gap:5px;background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:4px 12px;font-size:.78rem;color:#374151;}
.jp-salary{font-size:1rem;font-weight:700;color:#A11D21;}
.jp-section-title{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#A11D21;margin:1.25rem 0 .5rem;padding-bottom:.35rem;border-bottom:2px solid #fde8e9;}
.jp-content{font-size:.88rem;color:#374151;line-height:1.7;white-space:pre-wrap;}
.jp-benefit-list{display:flex;flex-wrap:wrap;gap:8px;}
.jp-benefit{background:#fde8e9;color:#A11D21;border-radius:20px;padding:4px 14px;font-size:.78rem;font-weight:600;}

/* ============================================================
   Home/Index — homepage hero, categories, jobs
   ============================================================ */
.hp-hero{position:relative;overflow:hidden;min-height:580px;}
.hp-hero-bg{position:absolute;inset:0;z-index:0;}
.hp-hero-bg-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.58) 0%,rgba(10,10,10,.4) 55%,rgba(161,29,33,.28) 100%);}
.hp-hero-content{position:relative;z-index:2;padding:70px 0 60px;text-align:center;}
.hp-hero-title{font-size:2.8rem;font-weight:900;color:#fff;line-height:1.15;margin-bottom:.75rem;text-shadow:0 2px 16px rgba(0,0,0,.4);}
.hp-hero-title em{color:#fca5a5;font-style:normal;}
.hp-hero-subtitle{color:rgba(255,255,255,.78);font-size:1rem;margin-bottom:1.6rem;line-height:1.5;}
.hp-hero-stats{display:flex;gap:40px;justify-content:center;margin-bottom:1.8rem;}
.hp-hero-stat-num{font-size:1.7rem;font-weight:900;color:#fff;line-height:1;text-shadow:0 1px 6px rgba(0,0,0,.2);}
.hp-hero-stat-lbl{font-size:0.72rem;color:rgba(255,255,255,.6);margin-top:3px;}
.hp-search-card{position:relative;background:rgba(255,255,255,.96);backdrop-filter:blur(16px) saturate(1.6);-webkit-backdrop-filter:blur(16px) saturate(1.6);border-radius:16px;padding:20px 22px 16px;box-shadow:0 8px 40px rgba(0,0,0,.22);}
.hp-search-row{display:flex;gap:8px;align-items:center;}
.hp-field{position:relative;}
.hp-field-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:0.8rem;pointer-events:none;z-index:2;}
.hp-field-grow{flex:1 1 0;min-width:0;}
/* "Địa điểm" button in search row */
.hp-city-btn{display:flex;align-items:center;gap:8px;height:44px;padding:0 13px;border:1.5px solid #e5e7eb;border-radius:10px;background:#fff;font-size:.875rem;color:#374151;cursor:pointer;white-space:nowrap;min-width:148px;flex-shrink:0;transition:border-color .2s,box-shadow .2s;}
.hp-city-btn:hover,.hp-city-btn:focus{border-color:#A11D21;outline:none;box-shadow:0 0 0 3px rgba(161,29,33,.08);}
.hp-city-btn i:first-child{color:#9ca3af;font-size:.82rem;flex-shrink:0;}
.hp-city-btn span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.hp-city-arrow{color:#9ca3af;font-size:.62rem;flex-shrink:0;transition:transform .2s;}
/* 2-panel dropdown — positioned below the card */
.hp-loc-dropdown{display:none;position:fixed;background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;box-shadow:0 14px 48px rgba(0,0,0,.16);z-index:9200;overflow:hidden;}
.hp-loc-dropdown.open{display:block;animation:locDropIn .18s ease;}
@keyframes locDropIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.hp-loc-panels{display:flex;height:300px;}
.hp-loc-left{width:220px;border-right:1px solid #f3f4f6;display:flex;flex-direction:column;flex-shrink:0;}
.hp-loc-right{flex:1;display:flex;flex-direction:column;}
.hp-loc-prov-list{flex:1;overflow-y:auto;padding:4px 0;}
.hp-loc-ward-list{flex:1;overflow-y:auto;padding:4px 0;}
.hp-city-search-wrap{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid #f3f4f6;flex-shrink:0;}
.hp-city-search-wrap i{color:#9ca3af;font-size:.78rem;flex-shrink:0;}
.hp-city-search-wrap input{flex:1;border:none;outline:none;font-size:.83rem;color:#374151;background:none;}
.hp-prov-item{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;cursor:pointer;font-size:.84rem;color:#374151;transition:background .12s;gap:6px;}
.hp-prov-item:hover{background:#f9fafb;}
.hp-prov-item.active{background:#fff5f5;color:#A11D21;font-weight:600;}
.hp-prov-item.active .hp-prov-arrow{color:#A11D21;}
.hp-prov-arrow{font-size:.6rem;color:#d1d5db;flex-shrink:0;}
.hp-ward-item{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;font-size:.83rem;color:#374151;transition:background .12s;}
.hp-ward-item:hover{background:#f9fafb;}
.hp-ward-item input[type=checkbox]{accent-color:#A11D21;width:15px;height:15px;flex-shrink:0;cursor:pointer;}
.hp-ward-loading{padding:24px;text-align:center;color:#9ca3af;font-size:.8rem;}
.hp-city-footer{display:flex;gap:8px;padding:10px 14px;border-top:1px solid #f3f4f6;background:#fff;}
.hp-city-footer button{flex:1;border:1.5px solid #e5e7eb;border-radius:8px;padding:8px 0;font-size:.82rem;font-weight:600;cursor:pointer;background:#fff;color:#6b7280;transition:all .15s;}
.hp-city-footer button:hover{border-color:#d1d5db;background:#f9fafb;}
.hp-city-footer button.apply{background:#A11D21;color:#fff;border-color:#A11D21;}
.hp-city-footer button.apply:hover{background:#7f1417;}
@media(max-width:767px){.hp-city-btn{min-width:0;flex:1 1 0;}.hp-loc-panels{height:340px;}.hp-loc-left{width:140px;}}
.hp-search-input{width:100%;border:1.5px solid #e5e7eb;border-radius:10px;padding:11px 14px 11px 36px;font-size:0.875rem;color:#111827;background:#fff;transition:border-color 0.2s,box-shadow 0.2s;appearance:none;-webkit-appearance:none;}
.hp-search-input:focus{outline:none;border-color:#A11D21;box-shadow:0 0 0 3px rgba(161,29,33,.1);}
.hp-search-input::placeholder{color:#9ca3af;}
.hp-search-btn{background:linear-gradient(135deg,#A11D21 0%,#c92428 100%);color:#fff;border:none;border-radius:10px;padding:11px 22px;font-weight:700;font-size:0.9rem;white-space:nowrap;flex-shrink:0;transition:all 0.25s;box-shadow:0 4px 16px rgba(161,29,33,.35);cursor:pointer;display:flex;align-items:center;gap:7px;}
.hp-search-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(161,29,33,.45);}
.hp-hot-kw{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(0,0,0,.06);}
.hp-hot-kw .hp-hot-label{font-size:0.7rem;font-weight:700;color:#ef4444;white-space:nowrap;flex-shrink:0;}
.hp-hot-kw a{font-size:0.72rem;font-weight:500;color:#4b5563;padding:4px 11px;background:rgba(243,244,246,.85);border-radius:20px;border:1px solid #e5e7eb;text-decoration:none;transition:all 0.15s;white-space:nowrap;}
.hp-hot-kw a:hover{background:#fff0f0;color:#A11D21;border-color:#fecaca;}
.hp-register-link{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-size:0.72rem;font-weight:600;color:#A11D21!important;background:rgba(161,29,33,.07)!important;border-color:rgba(161,29,33,.2)!important;}
.hp-register-link:hover{background:#fff0f0!important;border-color:#fecaca!important;}
/* ── Province quick-nav ── */
.hp-prov-nav{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:6px;padding-top:12px;margin-top:10px;border-top:1px solid rgba(0,0,0,.07);scrollbar-width:none;-ms-overflow-style:none;}
.hp-prov-nav::-webkit-scrollbar{display:none;}
.hp-pnav-pill{flex-shrink:0;padding:5px 14px;border-radius:20px;border:1.5px solid #e5e7eb;background:#f9fafb;color:#4b5563;font-size:12.5px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;line-height:1.6;}
.hp-pnav-pill:hover{border-color:#fca5a5;background:#fff5f5;color:#A11D21;}
.hp-pnav-pill.hp-pnav-active{background:#A11D21;border-color:#A11D21;color:#fff;font-weight:700;box-shadow:0 2px 8px rgba(161,29,33,.3);}
@media(max-width:767px){.hp-pnav-pill{font-size:12px;padding:4px 11px;}}
.hp-hero-kw{display:flex;flex-wrap:wrap;gap:8px;margin-top:1.4rem;justify-content:center;}
.hp-kw-tag{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:20px;color:rgba(255,255,255,.88);font-size:0.78rem;font-weight:500;text-decoration:none;transition:all 0.2s;backdrop-filter:blur(4px);}
.hp-kw-tag:hover{background:rgba(255,255,255,.22);color:#fff;border-color:rgba(255,255,255,.3);}
@media(max-width:991px){.hp-hero{min-height:500px;}.hp-hero-content{padding:50px 0 44px;}.hp-hero-title{font-size:2.1rem;}.hp-field-city{flex:0 0 180px;}}
@media(max-width:767px){.hp-hero{min-height:auto;}.hp-hero-content{padding:36px 0 32px;}.hp-hero-title{font-size:1.7rem;}.hp-hero-stats{gap:24px;}.hp-search-row{flex-wrap:wrap;}.hp-field-city{flex:1 1 0;}.hp-search-btn{width:100%;justify-content:center;}}
.hp-stats-strip{background:#fff;border-bottom:1px solid #f3f4f6;box-shadow:0 1px 8px rgba(0,0,0,.04);}
.hp-stat-item{padding:18px 12px;text-align:center;}
.hp-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin:0 auto 8px;font-size:1.1rem;}
.hp-stat-icon-1{background:#fff0f0;color:#A11D21;}
.hp-stat-icon-2{background:#eff6ff;color:#2563eb;}
.hp-stat-icon-3{background:#f0fdf4;color:#16a34a;}
.hp-stat-num{font-size:1.6rem;font-weight:900;color:#A11D21;line-height:1.1;}
.hp-stat-lbl{font-size:0.75rem;color:#9ca3af;font-weight:500;margin-top:2px;}
.hp-section-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}
.hp-section-hd .section-title{font-size:1.25rem;}
.hp-section-hd .view-all{font-size:0.8rem;font-weight:600;color:#A11D21;text-decoration:none;display:flex;align-items:center;gap:4px;white-space:nowrap;}
.hp-cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
@media(max-width:768px){.hp-cat-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:480px){.hp-cat-grid{grid-template-columns:repeat(2,1fr);}}
.hp-jobs-grid{display:flex;flex-direction:column;gap:8px;}
/* === Featured Companies === */
.hp-fc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
@media(max-width:992px){.hp-fc-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:640px){.hp-fc-grid{grid-template-columns:repeat(2,1fr);}}
.hp-fc-card{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #f0f0f0;border-radius:12px;padding:14px;text-decoration:none;color:inherit;transition:.18s ease;box-shadow:0 2px 8px rgba(0,0,0,.04);}
.hp-fc-card:hover{border-color:#A11D21;box-shadow:0 6px 20px rgba(161,29,33,.10);transform:translateY(-2px);}
.hp-fc-logo{width:52px;height:52px;border-radius:10px;overflow:hidden;flex-shrink:0;border:1px solid #f0f0f0;background:#f9fafb;display:flex;align-items:center;justify-content:center;}
.hp-fc-logo img{width:100%;height:100%;object-fit:contain;}
.hp-fc-logo-placeholder{font-size:1.4rem;color:#9ca3af;}
.hp-fc-info{min-width:0;}
.hp-fc-name{font-size:.82rem;font-weight:700;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.hp-fc-industry{font-size:.72rem;color:#6b7280;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.hp-fc-jobs{font-size:.72rem;color:#A11D21;font-weight:600;margin-top:4px;}
.hp-fc-jobs i{font-size:.65rem;margin-right:2px;}

/* === Partner Companies — Infinite Marquee === */
.hp-partners-section{background:#f9fafb;padding:28px 0 32px;border-top:1px solid #f0f0f0;}
.hp-marquee-wrap{overflow:hidden;position:relative;width:100%;}
.hp-marquee-wrap::before,.hp-marquee-wrap::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;}
.hp-marquee-wrap::before{left:0;background:linear-gradient(to right,#f9fafb,transparent);}
.hp-marquee-wrap::after{right:0;background:linear-gradient(to left,#f9fafb,transparent);}
.hp-marquee-track{display:flex;gap:16px;width:max-content;animation:hp-marquee 28s linear infinite;}
.hp-marquee-track:hover{animation-play-state:paused;}
@keyframes hp-marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
.hp-partner-card{display:flex;flex-direction:column;align-items:center;justify-content:center;width:170px;height:120px;background:#fff;border:1px solid #e9ecef;border-radius:14px;text-decoration:none;position:relative;flex-shrink:0;transition:.2s ease;box-shadow:0 2px 8px rgba(0,0,0,.05);}
.hp-partner-card:hover{border-color:#A11D21;box-shadow:0 6px 20px rgba(161,29,33,.12);transform:translateY(-3px);}
.hp-partner-top-badge{position:absolute;top:10px;left:10px;background:#16a34a;color:#fff;font-size:.56rem;font-weight:800;letter-spacing:.06em;padding:2px 7px;border-radius:20px;line-height:1.6;}
.hp-partner-logo-wrap{display:flex;align-items:center;justify-content:center;width:120px;height:72px;}
.hp-partner-logo-wrap img{max-width:110px;max-height:64px;object-fit:contain;transition:.2s ease;}
.hp-partner-card:hover .hp-partner-logo-wrap img{transform:scale(1.05);}
.hp-partner-logo-placeholder{width:80px;height:60px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border-radius:10px;}
.hp-partner-logo-placeholder span{font-size:1.4rem;font-weight:800;color:#94a3b8;}
.hp-partner-name{font-size:.72rem;font-weight:600;color:#374151;margin-top:6px;text-align:center;padding:0 8px;}

.hp-cta{background:linear-gradient(135deg,#0f172a 0%,#1a0608 50%,#A11D21 100%);border-radius:16px;padding:3rem 2.5rem;position:relative;overflow:hidden;color:#fff;}
.hp-cta::after{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:rgba(161,29,33,.25);filter:blur(40px);}
/* How it works */
.hiw-step{text-align:center;position:relative;}
.hiw-step::after{content:'';position:absolute;top:24px;left:calc(50% + 40px);width:calc(100% - 80px);height:2px;background:linear-gradient(90deg,#fecaca,#f3f4f6);z-index:0;}
.hiw-step:last-child::after{display:none;}
.hiw-num{width:48px;height:48px;border-radius:50%;background:#A11D21;color:#fff;font-size:1.1rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;position:relative;z-index:1;box-shadow:0 4px 14px rgba(161,29,33,.3);}
.hiw-title{font-weight:700;font-size:.9rem;color:#111827;margin-bottom:6px;}
.hiw-desc{font-size:.78rem;color:#6b7280;line-height:1.5;}

/* ============================================================
   Company/Transactions
   ============================================================ */
.tx-page{background:#f4f6f9;min-height:100vh;padding-bottom:60px;}
.tx-topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:14px 0 0;}
.tx-topbar h1{font-size:1.3rem;font-weight:700;color:#1a202c;margin:0 0 12px;display:flex;align-items:center;gap:10px;}
.tx-summary{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:20px;}
.tx-card{background:#fff;border-radius:10px;padding:18px 20px;box-shadow:0 1px 4px rgba(0,0,0,.07);display:flex;align-items:center;gap:14px;}
.tx-card-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.tx-card-label{font-size:.78rem;color:#6b7280;margin-bottom:3px;}
.tx-card-value{font-size:1.05rem;font-weight:700;}
.tx-filter{background:#fff;border-radius:10px;padding:14px 20px;margin-bottom:16px;box-shadow:0 1px 3px rgba(0,0,0,.07);display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;}
.tx-filter label{font-size:.78rem;font-weight:600;color:#374151;margin-bottom:3px;display:block;}
.btn-tx-search{background:#1e3a6e;color:#fff;border:none;border-radius:6px;padding:6px 18px;font-size:.83rem;font-weight:600;cursor:pointer;height:34px;}
.btn-tx-reset{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:6px;padding:6px 14px;font-size:.83rem;cursor:pointer;height:34px;}
.tx-table-wrap{background:#fff;border-radius:10px;box-shadow:0 1px 3px rgba(0,0,0,.07);overflow:hidden;}
.tx-table-header{padding:14px 20px;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;}
.tx-table-header .title{font-size:.9rem;font-weight:700;color:#1a202c;}
.tx-table{width:100%;border-collapse:collapse;}
.tx-table th{padding:10px 16px;font-size:.75rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid #e5e7eb;white-space:nowrap;}
.tx-table td{padding:13px 16px;font-size:.86rem;color:#374151;border-bottom:1px solid #f3f4f6;vertical-align:middle;}
.tx-table tbody tr:last-child td{border-bottom:none;}
.tx-table tbody tr:hover{background:#fafbff;}
.tx-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.76rem;font-weight:700;white-space:nowrap;}
.tx-credit{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0;}
.tx-debit{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa;}
.tx-completed{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;}
.tx-pending{background:#fefce8;color:#854d0e;border:1px solid #fef08a;}
.tx-failed{background:#fff1f2;color:#be123c;border:1px solid #fecdd3;}
.tx-amount-credit{color:#15803d;font-weight:700;}
.tx-amount-debit{color:#dc2626;font-weight:700;}
.tx-code{font-family:monospace;font-size:.8rem;background:#f3f4f6;padding:2px 7px;border-radius:4px;color:#374151;}
.tx-empty{text-align:center;padding:60px 20px;color:#9ca3af;}
.tx-empty i{font-size:2.8rem;margin-bottom:10px;display:block;}
.tx-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid #f0f0f0;flex-wrap:wrap;gap:8px;}
.tx-page-btn{width:30px;height:30px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#374151;cursor:pointer;text-decoration:none;}
.tx-page-btn.active{background:#1e3a6e;color:#fff;border-color:#1e3a6e;}

/* ============================================================
   Company/Jobs — job management table
   ============================================================ */
.jm-page{background:#f4f6f9;min-height:100vh;padding-bottom:60px;}
.jm-topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:14px 0;}
.jm-topbar h1{font-size:1.35rem;font-weight:700;color:#1a202c;margin:0;}
.jm-body{max-width:1300px;margin:0 auto;padding:20px 16px;}
.jm-filter{background:#fff;border-radius:8px;padding:16px 20px;margin-bottom:16px;box-shadow:0 1px 3px rgba(0,0,0,.07);}
.jm-filter label{font-size:.8rem;font-weight:600;color:#374151;margin-bottom:4px;display:block;}
.btn-search{background:#1e3a6e;color:#fff;border:none;border-radius:6px;padding:7px 20px;font-size:.85rem;font-weight:600;cursor:pointer;height:36px;}
.jm-tabs{display:flex;gap:0;border-bottom:2px solid #e5e7eb;margin-bottom:0;}
.jm-tab{padding:10px 22px;font-size:.85rem;font-weight:600;color:#6b7280;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;text-decoration:none;white-space:nowrap;transition:.15s;}
.jm-tab:hover{color:#1e3a6e;}
.jm-tab.active{color:#1e3a6e;border-bottom-color:#1e3a6e;}
.jm-tab .cnt{background:#e5e7eb;color:#374151;border-radius:10px;padding:1px 7px;font-size:.72rem;margin-left:5px;}
.jm-tab.active .cnt{background:#1e3a6e;color:#fff;}
.jm-card{background:#fff;border-radius:0 0 8px 8px;box-shadow:0 1px 3px rgba(0,0,0,.07);overflow:hidden;}
.jm-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #f0f0f0;flex-wrap:wrap;gap:8px;}
.btn-export{background:#1e3a6e;color:#fff;border:none;border-radius:6px;padding:6px 16px;font-size:.82rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;}
.jm-table{width:100%;border-collapse:collapse;}
.jm-table th{padding:10px 12px;font-size:.78rem;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid #e5e7eb;white-space:nowrap;background:#f8fafc;}
.jm-table td{padding:11px 12px;font-size:.85rem;color:#374151;border-bottom:1px solid #f3f4f6;vertical-align:middle;}
.jm-table tbody tr:hover{background:#fafbff;}
.job-title-link{color:#1e3a6e;font-weight:600;text-decoration:none;font-size:.88rem;line-height:1.35;}
.apps-link{text-decoration:none;color:#6b7280;}
.apps-link.has-apps{color:#1e3a6e;font-weight:600;}
.apps-link.has-apps:hover{color:#A11D21;text-decoration:underline;}
.apps-link.no-apps{pointer-events:none;cursor:default;}
.jm-actions{display:flex;flex-wrap:wrap;align-items:center;gap:4px;}
.jm-actions form{margin:0;display:contents;}
.jm-act{width:30px;height:30px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;display:flex;align-items:center;justify-content:center;color:#6b7280;cursor:pointer;text-decoration:none;font-size:.85rem;transition:.15s;}
.jm-act:hover{border-color:#1e3a6e;color:#1e3a6e;background:#eef2ff;}
.jm-act.danger:hover{border-color:#e11d48;color:#e11d48;background:#fff1f2;}
.jm-empty{text-align:center;padding:60px 20px;color:#9ca3af;}
.jm-empty i{font-size:3rem;margin-bottom:12px;display:block;}
.jm-pagination{display:flex;align-items:center;justify-content:flex-end;gap:4px;padding:12px 16px;border-top:1px solid #f0f0f0;}
.jm-page-btn{width:30px;height:30px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#374151;cursor:pointer;}
.jm-page-btn.active{background:#1e3a6e;color:#fff;border-color:#1e3a6e;}

/* ============================================================
   Cv/Templates
   ============================================================ */
.tmpl-hero{background:linear-gradient(135deg,#0f172a 0%,#A11D21 100%);padding:48px 0;}
.tmpl-card{border-radius:16px;overflow:hidden;border:none;box-shadow:0 2px 12px rgba(0,0,0,0.08);transition:all 0.25s;cursor:pointer;}
.tmpl-card:hover{transform:translateY(-6px);box-shadow:0 12px 36px rgba(0,0,0,0.18);}
.tmpl-thumb{height:300px;position:relative;overflow:hidden;}
.tmpl-badge{position:absolute;top:12px;right:12px;padding:4px 12px;border-radius:20px;font-size:0.72rem;font-weight:700;}
.tmpl-info{padding:16px 20px 20px;background:#fff;}
.tmpl-info h5{font-size:1rem;font-weight:700;margin-bottom:4px;color:#0f172a;}
.tmpl-info p{font-size:0.82rem;color:#6b7280;margin-bottom:12px;}
.tmpl-use-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 20px;background:#A11D21;color:#fff;border-radius:8px;font-size:0.85rem;font-weight:600;text-decoration:none;transition:background 0.15s;}
.tmpl-use-btn:hover{background:#7f1417;color:#fff;}
.mini-cv{background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,0.1);width:150px;margin:auto;}
.mini-classic .mc-head{padding:10px;text-align:center;border-bottom:2px solid var(--tc);}
.mini-classic .mc-name{font-size:7px;font-weight:700;color:#111;margin:0;}
.mini-classic .mc-title{font-size:5px;color:var(--tc);margin:2px 0 0;}
.mini-classic .mc-body{padding:6px 10px;}
.mini-classic .mc-section{margin-bottom:5px;}
.mini-classic .mc-section-title{font-size:5px;font-weight:800;text-transform:uppercase;color:var(--tc);border-bottom:1px solid var(--tc);padding-bottom:1px;margin-bottom:2px;}
.mini-classic .mc-line{height:3px;background:#e5e7eb;border-radius:1px;margin-bottom:2px;}
.mini-modern{display:flex;}
.mini-modern .mc-left{width:40%;background:var(--tc);padding:10px 8px;}
.mini-modern .mc-right{flex:1;padding:10px 8px;}
.mini-modern .mc-avatar{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,0.3);margin:0 auto 4px;display:block;}
.mini-modern .mc-name{font-size:5.5px;font-weight:700;text-align:center;color:#fff;}
.mini-modern .mc-section-title{font-size:4.5px;font-weight:800;color:rgba(255,255,255,0.6);text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,0.2);margin-bottom:2px;margin-top:5px;}
.mini-modern .mc-right .mc-section-title{color:var(--tc);border-color:var(--tc);}
.mini-modern .mc-line{height:3px;background:rgba(255,255,255,0.2);border-radius:1px;margin-bottom:2px;}
.mini-modern .mc-right .mc-line{background:#e5e7eb;}
.mini-minimal .mc-head{padding:12px 10px 6px;border-bottom:1px solid #111;}
.mini-minimal .mc-name{font-size:9px;font-weight:300;color:#111;letter-spacing:-0.3px;}
.mini-minimal .mc-body{padding:6px 10px;}
.mini-minimal .mc-section-title{font-size:4.5px;font-weight:800;text-transform:uppercase;letter-spacing:1px;border-top:2px solid #111;padding-top:2px;margin-bottom:2px;margin-top:5px;}
.mini-creative .mc-banner{background:var(--tc);padding:10px 10px 8px;position:relative;}
.mini-creative .mc-name{font-size:7px;font-weight:700;color:#fff;}
.mini-creative .mc-body{padding:6px 10px;}
.mini-creative .mc-section-title{font-size:4.5px;font-weight:800;text-transform:uppercase;color:var(--tc);border-left:2px solid var(--tc);padding-left:3px;margin-bottom:2px;margin-top:5px;}
.mini-corporate .mc-header{background:var(--tc);padding:8px 10px;display:flex;align-items:center;gap:6px;}
.mini-corporate .mc-avatar{width:24px;height:24px;border-radius:4px;background:rgba(255,255,255,0.3);flex-shrink:0;}
.mini-corporate .mc-name{font-size:6px;font-weight:700;color:#fff;}
.mini-corporate .mc-body{padding:6px 10px;}
.mini-corporate .mc-section-title{font-size:4.5px;font-weight:800;text-transform:uppercase;color:var(--tc);background:#f8fafc;padding:2px 5px;border-radius:2px;margin-bottom:2px;margin-top:5px;}
.mini-student .mc-header{background:linear-gradient(135deg,var(--tc),#0f172a);padding:10px;display:flex;flex-direction:column;align-items:center;}
.mini-student .mc-avatar{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,0.3);border:2px solid rgba(255,255,255,0.4);margin-bottom:4px;}
.mini-student .mc-name{font-size:6px;font-weight:700;color:#fff;text-align:center;}
.mini-student .mc-body{padding:6px 10px;}
.mini-student .mc-section-title{font-size:4.5px;font-weight:800;text-transform:uppercase;color:#fff;background:var(--tc);padding:2px 6px;border-radius:10px;display:inline-block;margin-bottom:2px;margin-top:5px;}
.tmpl-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:12px;}
.tmpl-tag{font-size:0.7rem;padding:2px 8px;border-radius:10px;background:#f3f4f6;color:#6b7280;}

/* ============================================================
   Account/PublicProfile
   ============================================================ */
.pp-hero{background:linear-gradient(135deg,#0f172a 0%,#A11D21 100%);padding:48px 0 80px;position:relative;overflow:hidden;}
.pp-hero::after{content:'';position:absolute;right:-60px;top:-60px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,0.04);pointer-events:none;}
.pp-avatar-wrap{position:relative;display:inline-block;}
.pp-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid rgba(255,255,255,0.2);box-shadow:0 8px 24px rgba(0,0,0,0.3);}
.pp-avatar-ph{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.05));border:4px solid rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:#fff;box-shadow:0 8px 24px rgba(0,0,0,0.3);}
.pp-card{background:#fff;border-radius:16px;border:1px solid #f1f5f9;box-shadow:0 2px 12px rgba(0,0,0,0.06);margin-bottom:1.25rem;overflow:hidden;}
.pp-card-header{padding:16px 20px 12px;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;gap:10px;}
.pp-card-header-icon{width:34px;height:34px;border-radius:8px;background:#fff0f0;display:flex;align-items:center;justify-content:center;color:#A11D21;font-size:0.85rem;flex-shrink:0;}
.pp-card-header h5{margin:0;font-size:0.95rem;font-weight:700;color:#0f172a;}
.pp-card-body{padding:20px;}
.pp-skill-chip{display:inline-block;padding:5px 14px;background:#fff0f0;color:#A11D21;border:1px solid rgba(161,29,33,.15);border-radius:20px;font-size:0.78rem;font-weight:600;margin:3px 4px 3px 0;}
.pp-timeline-item{position:relative;padding-left:24px;margin-bottom:20px;}
.pp-timeline-item::before{content:'';position:absolute;left:0;top:6px;width:10px;height:10px;background:#A11D21;border-radius:50%;}
.pp-timeline-item::after{content:'';position:absolute;left:4px;top:18px;bottom:-8px;width:2px;background:#f1f5f9;}
.pp-timeline-item:last-child::after{display:none;}
.pp-exp-title{font-weight:700;color:#0f172a;font-size:0.95rem;margin-bottom:2px;}
.pp-exp-company{color:#A11D21;font-size:0.85rem;font-weight:600;margin-bottom:2px;}
.pp-exp-date{font-size:0.78rem;color:#94a3b8;margin-bottom:6px;}
.pp-exp-desc{font-size:0.85rem;color:#64748b;line-height:1.6;}
.pp-contact-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;background:#A11D21;color:#fff;border-radius:8px;font-weight:600;font-size:0.9rem;text-decoration:none;transition:background 0.2s;border:none;cursor:pointer;}
.pp-contact-btn:hover{background:#7f1417;color:#fff;}
.pp-cv-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;background:#fff;color:#A11D21;border:1.5px solid #A11D21;border-radius:8px;font-weight:600;font-size:0.9rem;text-decoration:none;transition:all 0.2s;}
.pp-cv-btn:hover{background:#fff0f0;color:#A11D21;}

/* ── Push notification permission prompt (bottom-right toast) ── */
.notif-prompt{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.18);padding:20px 20px 16px;width:320px;max-width:calc(100vw - 2rem);animation:notifSlideIn .35s ease;}
@keyframes notifSlideIn{from{opacity:0;transform:translateY(20px) scale(.97);}to{opacity:1;transform:translateY(0) scale(1);}}
.notif-prompt-close{position:absolute;top:10px;right:12px;background:none;border:none;color:#9ca3af;font-size:1rem;cursor:pointer;line-height:1;padding:2px;}
.notif-prompt-close:hover{color:#374151;}
.notif-prompt-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.notif-prompt-head i{color:#A11D21;font-size:1.25rem;}
.notif-prompt-head span{font-weight:700;font-size:.95rem;color:#1e293b;}
.notif-prompt p{font-size:.82rem;color:#64748b;line-height:1.5;margin:0 0 14px;}
.notif-prompt-btns{display:flex;gap:8px;justify-content:flex-end;}
.np-deny{background:#f1f5f9;color:#64748b;border:none;border-radius:6px;padding:7px 16px;font-size:.83rem;font-weight:600;cursor:pointer;}
.np-deny:hover{background:#e2e8f0;}
.np-allow{background:#A11D21;color:#fff;border:none;border-radius:6px;padding:7px 16px;font-size:.83rem;font-weight:600;cursor:pointer;}
.np-allow:hover{background:#7f1417;}

/* ============================================================
   Pricing page (/bao-gia) — TopCV-style redesign
   ============================================================ */
.pg-hero{background:linear-gradient(135deg,#0f172a 0%,#A11D21 100%);padding:56px 0 48px;text-align:center;position:relative;overflow:hidden;}
.pg-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");}
.pg-hero-eyebrow{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);font-size:.8rem;font-weight:600;padding:5px 14px;border-radius:20px;margin-bottom:16px;letter-spacing:.04em;text-transform:uppercase;}
.pg-hero-title{font-size:2.4rem;font-weight:900;color:#fff;line-height:1.2;margin-bottom:12px;}
.pg-hero-sub{color:rgba(255,255,255,.72);font-size:1rem;max-width:560px;margin:0 auto;}

.pg-tabs-wrap{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.06);}
.pg-tabs{display:flex;justify-content:center;gap:0;padding:0;}
.pg-tab-btn{display:flex;align-items:center;gap:8px;padding:14px 32px;background:none;border:none;border-bottom:3px solid transparent;font-size:.95rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s;margin-bottom:-1px;}
.pg-tab-btn:hover{color:#A11D21;}
.pg-tab-btn.active{color:#A11D21;border-bottom-color:#A11D21;}

.pg-main{padding:40px 0 60px;background:#f8fafc;}
.pg-tab-panel{}

.pg-section{background:#fff;border-radius:16px;box-shadow:0 2px 12px rgba(0,0,0,.06);padding:36px 40px;margin-bottom:28px;}
.pg-section-hd{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:12px;}
.pg-section-hd h2{font-size:1.45rem;font-weight:800;color:#0f172a;margin:0 0 4px;}
.pg-section-hd p{color:#6b7280;font-size:.9rem;margin:0;}

/* Duration selector */
.pg-dur-wrap{text-align:center;margin-bottom:28px;}
.pg-dur-tabs{display:inline-flex;background:#f1f5f9;border-radius:10px;padding:4px;gap:2px;}
.pg-dur-btn{padding:8px 22px;border:none;background:transparent;border-radius:7px;font-size:.88rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s;}
.pg-dur-btn.active{background:#fff;color:#A11D21;box-shadow:0 2px 8px rgba(0,0,0,.1);}

/* 3-column card grid */
.pg-cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media(max-width:900px){.pg-cards-3{grid-template-columns:1fr;max-width:440px;margin:0 auto;}}

.pg-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;padding:28px 24px 24px;display:flex;flex-direction:column;position:relative;transition:box-shadow .2s,transform .2s;}
.pg-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.1);transform:translateY(-2px);}
.pg-card-popular{border-color:#A11D21;box-shadow:0 4px 24px rgba(161,29,33,.14);}
.pg-card-popular:hover{box-shadow:0 12px 40px rgba(161,29,33,.2);}

.pg-ribbon{position:absolute;top:-1px;right:20px;background:#A11D21;color:#fff;font-size:.72rem;font-weight:700;padding:4px 12px;border-radius:0 0 8px 8px;letter-spacing:.04em;text-transform:uppercase;}

.pg-card-hd{margin-bottom:20px;}
.pg-card-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;margin-bottom:14px;}
.pg-icon-new{background:#eff6ff;color:#3b82f6;}
.pg-icon-hot{background:#fff0f0;color:#A11D21;}
.pg-icon-vip{background:#fefce8;color:#ca8a04;}
.pg-icon-basic{background:#f0fdf4;color:#16a34a;}
.pg-icon-gold{background:#fefce8;color:#ca8a04;}
.pg-icon-diamond{background:#faf5ff;color:#7c3aed;}

.pg-card-hd h3{font-size:1.15rem;font-weight:800;color:#0f172a;margin:0 0 5px;}
.pg-card-desc{font-size:.82rem;color:#94a3b8;margin:0;line-height:1.4;}

.pg-price-wrap{margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid #f1f5f9;}
.pg-price{font-size:1.65rem;font-weight:900;color:#0f172a;line-height:1;}
.pg-price-note{font-size:.78rem;color:#94a3b8;margin-top:4px;}
.pg-card-popular .pg-price{color:#A11D21;}

.pg-feat-list{list-style:none;padding:0;margin:0 0 24px;flex:1;display:flex;flex-direction:column;gap:9px;}
.pg-feat-list li{display:flex;align-items:center;gap:9px;font-size:.86rem;color:#374151;}
.pg-feat-list li i{width:16px;text-align:center;font-size:.78rem;flex-shrink:0;}
.pg-feat-list li i.fa-check{color:#16a34a;}
.pg-feat-no{color:#cbd5e1 !important;}
.pg-feat-no i{color:#d1d5db !important;}

.pg-cta{display:block;text-align:center;padding:11px 20px;border-radius:9px;font-size:.88rem;font-weight:700;text-decoration:none;transition:all .2s;cursor:pointer;border:1.5px solid transparent;margin-top:auto;}
.pg-cta-primary{background:#A11D21;color:#fff;border-color:#A11D21;}
.pg-cta-primary:hover{background:#7f1417;border-color:#7f1417;color:#fff;}
.pg-cta-outline{background:#fff;color:#A11D21;border-color:#A11D21;}
.pg-cta-outline:hover{background:#fff0f0;color:#A11D21;}
.pg-cta-sm{display:inline-block;padding:8px 18px;font-size:.82rem;}
.pg-cta-light{background:#fff;color:#A11D21;border-color:#fff;}
.pg-cta-light:hover{background:#f8fafc;color:#A11D21;}
.pg-cta-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.6);}
.pg-cta-outline-light:hover{background:rgba(255,255,255,.1);color:#fff;}

/* Comparison table */
.pg-compare-section{overflow:hidden;}
.pg-compare-section h2{font-size:1.3rem;font-weight:800;color:#0f172a;margin:0 0 20px;}
.pg-compare-wrap{overflow-x:auto;}
.pg-compare-table{width:100%;border-collapse:collapse;font-size:.86rem;}
.pg-compare-table th{padding:12px 16px;text-align:center;font-weight:700;color:#6b7280;background:#f8fafc;border-bottom:2px solid #e5e7eb;white-space:nowrap;}
.pg-compare-table th.pg-compare-feature{text-align:left;}
.pg-compare-table td{padding:11px 16px;text-align:center;border-bottom:1px solid #f1f5f9;color:#374151;}
.pg-compare-table td.pg-compare-feature,.pg-compare-table th.pg-compare-feature{text-align:left;font-weight:500;color:#374151;}
.pg-compare-table tr:last-child td{border-bottom:none;}
.pg-compare-group td{background:#fafafa;font-weight:700;color:#0f172a;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;padding:8px 16px;border-bottom:1px solid #e5e7eb;}
.pg-col-popular{background:#fff8f8;}
.pg-compare-table th.pg-col-popular{background:#fff0f0;color:#A11D21;}
.pg-compare-cta td{padding:16px;background:#fafafa;}
.pg-yes{color:#16a34a;font-size:.9rem;}
.pg-no{color:#d1d5db;font-size:.9rem;}
.pg-label-hot{display:inline-block;background:#fee2e2;color:#b91c1c;font-size:.68rem;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.04em;}
.pg-label-vip{display:inline-block;background:#fef9c3;color:#92400e;font-size:.68rem;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.04em;}

/* Fee tables (candidate) */
.pg-fee-table-wrap{overflow-x:auto;margin-bottom:16px;}
.pg-fee-table{width:100%;border-collapse:collapse;font-size:.88rem;}
.pg-fee-table th{padding:12px 16px;text-align:left;font-weight:700;color:#0f172a;background:#f8fafc;border-bottom:2px solid #e5e7eb;}
.pg-fee-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;color:#374151;vertical-align:top;}
.pg-fee-table tr:last-child td{border-bottom:none;}
.pg-fee-table tr:hover td{background:#fafafa;}
.pg-fee-price{font-weight:700;color:#A11D21;white-space:nowrap;}
.pg-fee-member{color:#7c3aed;}
.pg-fee-note{display:flex;align-items:flex-start;gap:8px;background:#eff6ff;border-radius:8px;padding:12px 16px;font-size:.82rem;color:#1e40af;line-height:1.5;}
.pg-fee-note i{margin-top:1px;flex-shrink:0;}

/* Bottom CTA */
.pg-bottom-cta{background:linear-gradient(135deg,#0f172a 0%,#A11D21 100%);padding:48px 0;}
.pg-bottom-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.pg-bottom-cta h2{font-size:1.5rem;font-weight:800;color:#fff;margin:0 0 6px;}
.pg-bottom-cta p{color:rgba(255,255,255,.72);font-size:.92rem;margin:0;}
.pg-bottom-cta-actions{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap;}

@media(max-width:768px){
  .pg-hero-title{font-size:1.8rem;}
  .pg-section{padding:24px 16px;}
  .pg-section-hd{flex-direction:column;}
  .pg-tab-btn{padding:12px 20px;font-size:.88rem;}
  .pg-dur-btn{padding:7px 14px;font-size:.82rem;}
  .pg-bottom-cta-inner{flex-direction:column;text-align:center;}
  .pg-bottom-cta-actions{justify-content:center;}
  .pg-compare-table th,.pg-compare-table td{padding:9px 10px;font-size:.8rem;}
}
