/* ============================================================
   Crowdlytics Job Portal — Stylesheet
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800;900&display=swap');

:root {
    --cjp-primary:        #FD0D8A;
    --cjp-primary-dark:   #d4006d;
    --cjp-primary-glow:   rgba(253, 13, 138, 0.30);
    --cjp-primary-border: rgba(253, 13, 138, 0.22);
    --cjp-primary-icon:   rgba(253, 13, 138, 0.10);
    --cjp-primary-hover:  rgba(253, 13, 138, 0.04);
    --cjp-pink-gradient:  linear-gradient(180deg, #FD0D8A 0%, #FF6EB4 50%, #FD0D8A 100%);

    --cjp-heading:        #363636;
    --cjp-body:           #5a5a5a;
    --cjp-muted:          #aaaaaa;
    --cjp-dark-text:      #bbbbbb;
    --cjp-dark-emphasis:  #FFFFFF;

    --cjp-card-bg:        #FFFFFF;
    --cjp-dark-card:      #111111;
    --cjp-border:         #EFEFEF;

    --cjp-radius-card:    14px;
    --cjp-radius-small:   10px;
    --cjp-font:           'Montserrat', sans-serif;

    --cjp-shadow:         0 2px 12px rgba(0,0,0,0.06), 0 1px 3px rgba(0,0,0,0.04);
    --cjp-shadow-hover:   0 12px 40px rgba(253,13,138,0.14), 0 4px 12px rgba(0,0,0,0.06);
}

/* ============================================================
   LISTINGS GRID
   ============================================================ */

.cjp-listings {
    display:     flex;
    flex-direction: column;
    gap:         16px;
    font-family: var(--cjp-font);
    margin:      0 auto;
    padding:     4px 0;
}

/* ============================================================
   CARD
   ============================================================ */

.cjp-card {
    background:    var(--cjp-card-bg);
    border:        1px solid var(--cjp-border);
    border-radius: var(--cjp-radius-card);
    box-shadow:    var(--cjp-shadow);
    display:       flex;
    flex-direction: column;
    position:      relative;
    overflow:      hidden;
    transition:    box-shadow 0.28s ease, transform 0.28s ease, border-color 0.28s ease;
}

.cjp-card:hover {
    box-shadow:   var(--cjp-shadow-hover);
    transform:    translateY(-3px);
    border-color: var(--cjp-primary-border);
}

/* Featured cards get a top gradient shimmer */
.cjp-card--featured {
    background: linear-gradient(160deg, #fff 80%, rgba(253,13,138,0.03) 100%);
}

/* ── Body ── */
.cjp-card__body {
    padding: 28px 32px 20px;
    flex: 1;
}

/* ── Badges ── */
.cjp-card__meta-top {
    display:       flex;
    flex-wrap:     wrap;
    gap:           7px;
    margin-bottom: 10px;
}

.cjp-badge {
    display:        inline-flex;
    align-items:    center;
    font-family:    var(--cjp-font);
    font-size:      9.5px;
    font-weight:    700;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    padding:        5px 12px;
    border-radius:  20px;
    line-height:    1;
    border:         1.5px solid transparent;
    white-space:    nowrap;
}

.cjp-badge--type {
    background:   rgba(253,13,138,0.08);
    color:        var(--cjp-primary);
    border-color: rgba(253,13,138,0.20);
}

.cjp-badge--remote {
    background:   rgba(99,102,241,0.09);
    color:        #6366F1;
    border-color: rgba(99,102,241,0.22);
}

.cjp-badge--featured {
    background:   rgba(245,158,11,0.09);
    color:        #D97706;
    border-color: rgba(245,158,11,0.22);
}

/* ── Title ── */
.cjp-card__title {
    font-family:    var(--cjp-font);
    font-size:      1.15rem;
    font-weight:    800;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    color:          var(--cjp-heading);
    margin:         10px 0 12px;
    line-height:    1.3;
}

.cjp-card__title a {
    color:           inherit;
    text-decoration: none;
    transition:      color 0.2s;
}

.cjp-card__title a:hover {
    color: var(--cjp-primary);
}

/* ── Info row: location + date ── */
.cjp-card__info-row {
    display:     flex;
    align-items: center;
    gap:         20px;
    margin-bottom: 16px;
    flex-wrap:   wrap;
}

.cjp-card__location {
    display:     flex;
    align-items: center;
    gap:         5px;
    font-size:   0.78rem;
    font-weight: 600;
    color:       var(--cjp-muted);
    margin:      0;
    letter-spacing: 0.2px;
}

.cjp-card__location svg {
    width:      13px;
    height:     13px;
    flex-shrink: 0;
    color:      var(--cjp-primary);
}

.cjp-card__date {
    display:     flex;
    align-items: center;
    gap:         5px;
    font-size:   0.78rem;
    font-weight: 600;
    color:       var(--cjp-muted);
    letter-spacing: 0.2px;
}

.cjp-card__date svg {
    width:      13px;
    height:     13px;
    flex-shrink: 0;
    color:      var(--cjp-primary);
}

/* ── Excerpt ── */
.cjp-card__excerpt {
    font-size:      0.85rem;
    font-weight:    400;
    color:          var(--cjp-body) !important;
    line-height:    1.75;
    margin:         0;
    padding-top:    16px;
    border-top:     1px solid var(--cjp-border);
    display:        -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow:       hidden;
    background:     none !important;
    -webkit-text-fill-color: var(--cjp-body);
}

/* ── Footer ── */
.cjp-card__footer {
    display:         flex;
    align-items:     center;
    justify-content: flex-end;
    padding:         16px 32px;
    border-top:      1px solid var(--cjp-border);
    background:      var(--cjp-primary-hover);
}

/* ── Button ── */
.cjp-btn {
    display:         inline-flex;
    align-items:     center;
    gap:             7px;
    font-family:     var(--cjp-font);
    font-size:       0.78rem;
    font-weight:     500;
    letter-spacing:  1px;
    text-transform:  uppercase;
    padding:         11px 30px;
    border-radius:   50px;
    cursor:          pointer;
    text-decoration: none;
    transition:      all 0.22s ease;
    line-height:     1;
    white-space:     nowrap;
    border:          none;
}

.cjp-btn--outline {
    background:   var(--cjp-primary);
    color:        #fff;
    box-shadow:   0 4px 18px var(--cjp-primary-glow);
}

.cjp-btn__arrow {
    width:      13px;
    height:     13px;
    transition: transform 0.22s ease;
}

.cjp-btn--outline:hover {
    background: var(--cjp-primary-dark);
    color:      #fff;
    box-shadow: 0 6px 22px var(--cjp-primary-glow);
}

.cjp-btn--outline:hover .cjp-btn__arrow {
    transform: translateX(3px);
}

/* Apply button (single page) */
.cjp-btn--apply {
    background: var(--cjp-primary);
    color:      #fff;
    box-shadow: 0 4px 20px var(--cjp-primary-glow);
    padding:    11px 30px;
}

.cjp-btn--apply:hover {
    background: var(--cjp-primary-dark);
    color:      #fff;
    box-shadow: 0 8px 28px var(--cjp-primary-glow);
    transform:  translateY(-1px);
}

/* ── No jobs message ── */
.cjp-no-jobs {
    text-align:    center;
    color:         var(--cjp-muted);
    padding:       48px 20px;
    border:        2px dashed var(--cjp-border);
    border-radius: var(--cjp-radius-card);
    font-family:   var(--cjp-font);
    font-size:     0.85rem;
    font-weight:   600;
    letter-spacing: 0.5px;
}

/* ============================================================
   SINGLE JOB PAGE
   ============================================================ */

/* Page wrapper — gives breathing room from the header */
.cjp-page {
    background:  #F7F7F9;
    min-height:  100vh;
    padding:     60px 0 80px;
    font-family: var(--cjp-font);
}

.cjp-page__inner {
    max-width: 1100px;
    margin:    0 auto;
    padding:   0 32px;
}

/* ── Back link ── */
.cjp-single__back {
    display:         inline-flex;
    align-items:     center;
    gap:             7px;
    color:           var(--cjp-muted);
    font-size:       0.7rem;
    font-weight:     700;
    letter-spacing:  1px;
    text-transform:  uppercase;
    text-decoration: none;
    margin-bottom:   28px;
    transition:      color 0.2s;
}

.cjp-single__back svg { width: 14px; height: 14px; }
.cjp-single__back:hover { color: var(--cjp-primary); }

/* ── Hero banner ── */
.cjp-single__hero {
    background:    var(--cjp-dark-card);
    border-radius: var(--cjp-radius-card);
    padding:       48px 52px;
    margin-bottom: 28px;
    position:      relative;
    overflow:      hidden;
    display:       flex;
    align-items:   center;
    justify-content: space-between;
    gap:           32px;
}

/* Radial glow blob */
.cjp-single__hero::after {
    content:        '';
    position:       absolute;
    top: -120px; right: -80px;
    width:  380px;
    height: 380px;
    background:     radial-gradient(circle, rgba(253,13,138,0.13) 0%, transparent 65%);
    pointer-events: none;
}

.cjp-single__hero-content {
    flex:     1;
    position: relative;
    z-index:  1;
}

.cjp-single__hero-cta {
    flex-shrink: 0;
    position:    relative;
    z-index:     1;
}

/* Badges */
.cjp-single__badge-row {
    display:       flex;
    flex-wrap:     wrap;
    gap:           8px;
    margin-bottom: 16px;
}

.cjp-single__hero .cjp-badge--type {
    background:   rgba(253,13,138,0.20);
    color:        #FF6EB4;
    border-color: rgba(253,13,138,0.35);
}
.cjp-single__hero .cjp-badge--remote {
    background:   rgba(99,102,241,0.18);
    color:        #A5B4FC;
    border-color: rgba(99,102,241,0.32);
}
.cjp-single__hero .cjp-badge--featured {
    background:   rgba(245,158,11,0.15);
    color:        #FBD449;
    border-color: rgba(245,158,11,0.28);
}

/* Title */
.cjp-single__title {
    font-family:    var(--cjp-font);
    font-size:      2.1rem;
    font-weight:    800;
    letter-spacing: 1px;
    text-transform: uppercase;
    color:          var(--cjp-dark-emphasis);
    margin:         0 0 20px;
    line-height:    1.2;
}

/* Meta row */
.cjp-single__meta {
    display:     flex;
    flex-wrap:   wrap;
    gap:         20px;
    color:       var(--cjp-dark-text);
    font-size:   0.78rem;
    font-weight: 600;
    letter-spacing: 0.3px;
}

.cjp-single__meta-item {
    display:     flex;
    align-items: center;
    gap:         7px;
}

.cjp-single__meta-item svg {
    width:  15px;
    height: 15px;
    flex-shrink: 0;
    color:  var(--cjp-primary);
}

/* ── Two-column layout ── */
.cjp-single__layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap:     28px;
    align-items: start;
}

/* ── Main content ── */
.cjp-single__main {
    min-width: 0;
}

.cjp-single__section {
    background:    var(--cjp-card-bg);
    border:        1px solid var(--cjp-border);
    border-radius: var(--cjp-radius-card);
    padding:       40px 44px;
    box-shadow:    var(--cjp-shadow);
}

.cjp-single__section-title {
    font-family:    var(--cjp-font);
    font-size:      1rem;
    font-weight:    800;
    letter-spacing: 2px;
    text-transform: uppercase;
    color:          var(--cjp-primary);
    margin:         0 0 28px;
    padding-bottom: 16px;
    border-bottom:  1px solid var(--cjp-border);
}

/* Description typography */
.cjp-single__content {
    font-size:   0.95rem;
    font-weight: 400;
    line-height: 1.95;
    color:       var(--cjp-body);
}

/* ─────────────────────────────────────────────
   CONTENT — single vertical flow
───────────────────────────────────────────── */
.cjp-single__content {
    display:        block;
    font-size:      0.93rem;
    line-height:    1.85;
    color:          var(--cjp-body);
}

/* Paragraphs */
.cjp-single__content p {
    margin: 0 0 1rem;
    color:  var(--cjp-body);
}

/* ── Headings hierarchy ── */

/* H2 = top-level section (e.g. "1. Project Coordination") */
.cjp-single__content h2 {
    font-family:    var(--cjp-font);
    font-size:      0.95rem;
    font-weight:    700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    color:          var(--cjp-heading);
    margin:         2.2em 0 0.6em;
    padding-bottom: 8px;
    border-bottom:  2px solid var(--cjp-border);
    line-height:    1.3;
}

.cjp-single__content h2:first-child { margin-top: 0; }

/* H3 = child sub-heading — indented with pink dash */
.cjp-single__content h3 {
    font-family:    var(--cjp-font);
    font-size:      0.85rem;
    font-weight:    700;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    color:          var(--cjp-primary);
    margin:         1.4em 0 0.4em;
    padding-left:   18px;
    position:       relative;
    line-height:    1.4;
}

.cjp-single__content h3::before {
    content:      '';
    position:     absolute;
    left:         0;
    top:          50%;
    transform:    translateY(-50%);
    width:        8px;
    height:       2px;
    background:   var(--cjp-primary);
    border-radius: 2px;
}

/* H4 = grandchild — deeper indent */
.cjp-single__content h4 {
    font-family:    var(--cjp-font);
    font-size:      0.8rem;
    font-weight:    600;
    color:          var(--cjp-body);
    margin:         1em 0 0.3em;
    padding-left:   34px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

/* ── Lists ── */
.cjp-single__content ul,
.cjp-single__content ol {
    display:        flex !important;
    flex-direction: column !important;
    gap:            6px;
    padding-left:   36px;
    margin:         0.4em 0 1.2em;
    list-style:     disc;
    width:          100%;
    box-sizing:     border-box;
}

.cjp-single__content ol { list-style: decimal; }

.cjp-single__content li {
    display:     list-item !important;
    font-size:   0.91rem;
    line-height: 1.75;
    color:       var(--cjp-body);
    padding-left: 4px;
    width:       100%;
}

.cjp-single__content ul li::marker { color: var(--cjp-primary); }

/* Nested lists */
.cjp-single__content ul ul,
.cjp-single__content ol ol,
.cjp-single__content ul ol,
.cjp-single__content ol ul {
    margin:       0.3em 0 0;
    padding-left: 18px;
}

/* ── Inline text ── */
.cjp-single__content strong {
    font-weight: 700;
    color:       var(--cjp-heading);
}

.cjp-single__content a {
    color:           var(--cjp-primary);
    font-weight:     600;
    text-decoration: none;
}

.cjp-single__content a:hover { text-decoration: underline; }

/* ─────────────────────────────────────────────
   GUTENBERG COLUMNS → force single column
   (Gutenberg adds inline flex-basis styles so
   we need !important on every layout property)
───────────────────────────────────────────── */
.cjp-single__content .wp-block-columns,
.cjp-single__content [class*="wp-block-columns"] {
    display:        flex !important;
    flex-direction: column !important;
    flex-wrap:      nowrap !important;
    gap:            0 !important;
    width:          100% !important;
}

.cjp-single__content .wp-block-column,
.cjp-single__content [class*="wp-block-column"] {
    flex:           none !important;
    flex-basis:     100% !important;
    width:          100% !important;
    max-width:      100% !important;
    min-width:      0 !important;
    margin-left:    0 !important;
    padding-left:   0 !important;
}

/* Strip any inline styles that set multi-column layout */
.cjp-single__content *[style*="column-count"],
.cjp-single__content *[style*="columns:"],
.cjp-single__content *[style*="float"] {
    column-count: 1 !important;
    columns:      auto !important;
    float:        none !important;
}

/* ─────────────────────────────────────────────
   TABLE (e.g. Competencies) — styled properly
───────────────────────────────────────────── */
.cjp-single__content table {
    width:           100%;
    border-collapse: collapse;
    margin:          1.2em 0 1.6em;
    font-size:       0.88rem;
    border-radius:   var(--cjp-radius-small);
    overflow:        hidden;
    box-shadow:      var(--cjp-shadow);
}

.cjp-single__content thead tr {
    background: var(--cjp-primary);
}

.cjp-single__content thead th {
    color:          #fff;
    font-family:    var(--cjp-font);
    font-weight:    700;
    font-size:      0.72rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding:        12px 18px;
    text-align:     left;
    border:         none;
}

.cjp-single__content tbody tr {
    border-bottom: 1px solid var(--cjp-border);
    transition:    background 0.15s;
}

.cjp-single__content tbody tr:nth-child(even) {
    background: rgba(253,13,138,0.03);
}

.cjp-single__content tbody tr:hover {
    background: rgba(253,13,138,0.06);
}

.cjp-single__content td {
    padding:     11px 18px;
    color:       var(--cjp-body);
    font-weight: 500;
    border:      none;
    vertical-align: middle;
}

.cjp-single__content td:first-child {
    color:       var(--cjp-heading);
    font-weight: 600;
}

.cjp-single__content td:last-child {
    color:       var(--cjp-primary);
    font-weight: 700;
    font-size:   0.8rem;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

/* Bottom apply */
.cjp-single__bottom-apply {
    margin-top:  28px;
    text-align:  center;
}

/* ── Sidebar ── */
.cjp-single__sidebar {
    display:        flex;
    flex-direction: column;
    gap:            20px;
    position:       sticky;
    top:            166px;
}

.cjp-sidebar__card {
    background:    var(--cjp-card-bg);
    border:        1px solid var(--cjp-border);
    border-radius: var(--cjp-radius-card);
    padding:       28px 24px;
    box-shadow:    var(--cjp-shadow);
}

.cjp-sidebar__title {
    font-family:    var(--cjp-font);
    font-size:      0.68rem;
    font-weight:    800;
    letter-spacing: 2px;
    text-transform: uppercase;
    color:          var(--cjp-primary);
    margin:         0 0 20px;
    padding-bottom: 14px;
    border-bottom:  1px solid var(--cjp-border);
}

.cjp-sidebar__row {
    display:     flex;
    align-items: flex-start;
    gap:         14px;
    padding:     14px 0;
    border-bottom: 1px solid var(--cjp-border);
}

.cjp-sidebar__row:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.cjp-sidebar__row:first-child {
    padding-top: 0;
}

.cjp-sidebar__icon {
    flex-shrink:     0;
    width:           36px;
    height:          36px;
    border-radius:   10px;
    background:      var(--cjp-primary-icon);
    border:          1px solid var(--cjp-primary-border);
    display:         flex;
    align-items:     center;
    justify-content: center;
    color:           var(--cjp-primary);
}

.cjp-sidebar__icon svg {
    width:  16px;
    height: 16px;
}

.cjp-sidebar__label {
    display:        block;
    font-size:      0.68rem;
    font-weight:    700;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    color:          var(--cjp-muted);
    margin-bottom:  3px;
}

.cjp-sidebar__value {
    display:     block;
    font-size:   0.88rem;
    font-weight: 600;
    color:       var(--cjp-heading);
}

/* Full-width button modifier */
.cjp-btn--full {
    width:           100%;
    justify-content: center;
    padding:         15px 24px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media ( max-width: 900px ) {
    .cjp-single__layout {
        grid-template-columns: 1fr;
    }

    .cjp-single__sidebar {
        position: static;
        order:    -1;
    }

    .cjp-single__hero {
        flex-direction: column;
        align-items:    flex-start;
        padding:        36px 28px;
    }
}

@media ( max-width: 640px ) {
    .cjp-page {
        padding: 36px 0 60px;
    }

    .cjp-page__inner {
        padding: 0 18px;
    }

    .cjp-card__body,
    .cjp-card__footer {
        padding-left:  20px;
        padding-right: 20px;
    }

    .cjp-single__title {
        font-size: 1.5rem;
    }

    .cjp-single__section {
        padding: 28px 22px;
    }
}
