
/* GJ Suite Jobs & Lehre */
.gjjl-wrap{max-width:1120px;margin:0 auto;padding:18px 0}
.gjjl-hero{background:#fff;border:1px solid #f0e1df;border-radius:16px;padding:26px;box-shadow:0 8px 22px rgba(79,33,28,.06);margin-bottom:22px}
.gjjl-kicker{display:inline-block;color:#b53d33;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.gjjl-title{font-size:32px;line-height:1.15;margin:0 0 10px;color:#20242d}
.gjjl-lead{font-size:16px;line-height:1.55;color:#555;margin:0}
.gjjl-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0;border-bottom:1px solid #f1dedb;padding-bottom:12px}
.gjjl-tab{border:1px solid #e7cac5;border-radius:999px;background:#fff;color:#b53d33!important;text-decoration:none!important;padding:9px 14px;font-weight:700}
.gjjl-tab.is-active,.gjjl-tab:hover{background:#b53d33;color:#fff!important}
.gjjl-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.gjjl-card{background:#fff;border:1px solid #eee;border-radius:14px;overflow:hidden;box-shadow:0 6px 18px rgba(0,0,0,.05)}
.gjjl-card__body{padding:16px}
.gjjl-badge{display:inline-flex;align-items:center;border-radius:999px;background:#b53d33;color:#fff;font-size:11px;font-weight:800;padding:5px 9px;margin:0 6px 8px 0;text-transform:uppercase}
.gjjl-badge--job{background:#2f5f9f}
.gjjl-badge--apprentice{background:#b53d33}
.gjjl-badge--company{background:#16863a}
.gjjl-card h3{font-size:19px;line-height:1.25;margin:2px 0 8px}
.gjjl-card h3 a{color:#20242d;text-decoration:none}
.gjjl-card h3 a:hover{color:#b53d33;text-decoration:underline}
.gjjl-meta{color:#666;font-size:14px;line-height:1.45;margin:0 0 10px}
.gjjl-card p{color:#555;font-size:14px;line-height:1.45;margin:0 0 12px}
.gjjl-button{display:inline-flex;align-items:center;justify-content:center;background:#b53d33;color:#fff!important;text-decoration:none!important;border-radius:10px;padding:10px 14px;font-weight:700}
.gjjl-empty{padding:18px;background:#fafafa;border:1px solid #eee;border-radius:10px;color:#666}
.gjjl-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin:24px 0 14px}
.gjjl-section-head h2{margin:0;font-size:24px;color:#222}
.gjjl-company-block{background:#fff;border:1px solid #f0e1df;border-radius:14px;padding:18px;box-shadow:0 6px 18px rgba(79,33,28,.05);margin:24px 0}
.gjjl-company-list{display:grid;gap:12px;margin-top:12px}
.gjjl-company-job{border-top:1px solid #f0e1df;padding-top:12px}
.gjjl-company-job h4{font-size:18px;margin:0 0 7px}
.gjjl-card-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:10px}
.gjjl-card-row div{background:#faf7f6;border:1px solid #f0e1df;border-radius:10px;padding:10px}
.gjjl-card-row strong{display:block;color:#222;font-size:13px;margin-bottom:4px}
.gjjl-card-row span{display:block;color:#555;font-size:15px}
.gjjl-card-mark{display:inline-flex;align-items:center;background:#b53d33;color:#fff!important;border-radius:4px;font-size:10px;font-weight:800;padding:4px 6px;text-transform:uppercase;vertical-align:middle;margin-right:5px}
.gjjl-card-mark--jobs{background:#2f5f9f}
@media(max-width:900px){.gjjl-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:620px){.gjjl-grid,.gjjl-card-row{grid-template-columns:1fr}.gjjl-title{font-size:26px}.gjjl-hero{padding:20px}}

/* Jobs-Badge auf Firmenkarten */
.gjjl-card-mark{display:inline-flex;align-items:center;background:#b53d33;color:#fff!important;border-radius:4px;font-size:10px;font-weight:800;padding:4px 6px;text-transform:uppercase;vertical-align:middle;margin-right:5px;margin-bottom:4px}
.gjjl-card-mark--jobs{background:#2f5f9f}

/* GJ Suite 1.1.01 – sicherer Jobs-&-Lehre Layoutschutz */
.gjjl-wrap,
.gjjl-wrap *{
    box-sizing:border-box;
}
.gjjl-wrap{
    width:100%;
    max-width:1120px;
    overflow-x:hidden;
}
.gjjl-grid{
    width:100%;
}
.gjjl-card{
    max-width:100%;
}
.gjjl-card img{
    max-width:100%;
    height:auto;
}

/* GJ Suite 1.1.03 – Jobs & Lehre Karten nach Stellenportal-Stil */
.gjjl-wrap{width:100%;max-width:1120px;margin-left:auto;margin-right:auto;box-sizing:border-box}
.gjjl-wrap *{box-sizing:border-box}
.gjjl-job-board{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;width:100%;margin-top:16px}
.gjjl-job-card{background:#fff;border:1px solid #eadbd8;border-radius:14px;box-shadow:0 8px 22px rgba(72,35,30,.06);padding:18px;display:flex;flex-direction:column;min-height:285px;transition:transform .18s ease,box-shadow .18s ease}
.gjjl-job-card:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(72,35,30,.10)}
.gjjl-job-card__top{display:flex;gap:14px;align-items:flex-start;margin-bottom:12px}
.gjjl-job-card__logo{width:74px;height:74px;border-radius:12px;background:#f4f4f4;display:flex;align-items:center;justify-content:center;flex:0 0 74px;overflow:hidden;border:1px solid #eee}
.gjjl-job-card__logo img{width:100%;height:100%;object-fit:contain;padding:8px;background:#fff}
.gjjl-job-card__logo span{font-weight:800;font-size:18px;color:#b53d33}
.gjjl-job-card__head{min-width:0;flex:1}
.gjjl-job-card__head .gjjl-badge{margin-bottom:7px}
.gjjl-job-card h3{font-size:21px;line-height:1.22;margin:0 0 5px;color:#191919}
.gjjl-job-card h3 a{color:#191919;text-decoration:none}
.gjjl-job-card h3 a:hover{color:#b53d33;text-decoration:underline}
.gjjl-job-card__company{font-size:14px;color:#666;line-height:1.35}
.gjjl-job-card__excerpt{font-size:14px;line-height:1.48;color:#555;margin:0 0 14px;flex:1}
.gjjl-job-specs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:0 0 14px}
.gjjl-job-specs div{background:#faf6f5;border:1px solid #f0e1df;border-radius:9px;padding:9px 10px;min-height:58px}
.gjjl-job-specs strong{display:block;font-size:12px;color:#222;margin-bottom:3px}
.gjjl-job-specs span{display:block;font-size:14px;color:#555;line-height:1.25}
.gjjl-job-card__actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}
.gjjl-button--soft{background:#fff!important;color:#b53d33!important;border:1px solid #e5cbc7;box-shadow:none}
.gjjl-tabs .gjjl-tab{cursor:pointer}
@media(max-width:780px){.gjjl-job-board{grid-template-columns:1fr}.gjjl-job-card{min-height:0}}
@media(max-width:520px){.gjjl-job-card__top{flex-direction:column}.gjjl-job-card__logo{width:88px;height:68px}.gjjl-job-specs{grid-template-columns:1fr}}

/* GJ Suite 1.1.04 – Jobs UI, Übersicht und Einreichformular */
.gjjl-wrap--portal{
    max-width:1120px;
}
.gjjl-hero--compact{
    padding:24px 28px;
    margin-bottom:18px;
}
.gjjl-summary-row{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
    margin:0 0 18px;
}
.gjjl-summary-row div{
    background:#fff;
    border:1px solid #f0e1df;
    border-radius:12px;
    padding:14px 16px;
    box-shadow:0 5px 14px rgba(79,33,28,.04);
}
.gjjl-summary-row strong{
    display:block;
    font-size:24px;
    color:#b53d33;
    line-height:1;
}
.gjjl-summary-row span{
    display:block;
    margin-top:4px;
    color:#666;
    font-size:13px;
}
.gjjl-grid{
    align-items:stretch;
}
.gjjl-card{
    border-color:#f0e1df;
}
.gjjl-card h3{
    margin-top:8px;
}
.gjjl-submit-form{
    background:#fff;
    border:1px solid #f0e1df;
    border-radius:14px;
    padding:22px;
    box-shadow:0 8px 22px rgba(79,33,28,.06);
}
.gjjl-form-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
}
.gjjl-form-grid p{
    margin:0;
}
.gjjl-form-grid label{
    display:block;
    font-weight:700;
    color:#222;
    margin-bottom:6px;
}
.gjjl-form-grid input,
.gjjl-form-grid select,
.gjjl-form-grid textarea{
    width:100%;
    border:1px solid #ddd;
    border-radius:8px;
    padding:11px 12px;
    background:#fff;
}
.gjjl-form-wide{
    grid-column:1/-1;
}
.gjjl-notice{
    border-radius:10px;
    padding:13px 15px;
    margin:0 0 16px;
    border:1px solid transparent;
}
.gjjl-notice--success{
    background:#f0fff4;
    border-color:#b8e6c4;
    color:#126c2e;
}
.gjjl-notice--error{
    background:#fff3f3;
    border-color:#f0b8b8;
    color:#9a1b1b;
}
@media(max-width:720px){
    .gjjl-summary-row,
    .gjjl-form-grid{
        grid-template-columns:1fr;
    }
}

/* GJ Suite 1.1.05 – Summary-Fix */
.gjjl-summary-row{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
    margin:0 0 18px;
}
.gjjl-summary-row div{
    background:#fff;
    border:1px solid #f0e1df;
    border-radius:12px;
    padding:14px 16px;
    box-shadow:0 5px 14px rgba(79,33,28,.04);
}
.gjjl-summary-row strong{
    display:block;
    font-size:24px;
    color:#b53d33;
    line-height:1;
}
.gjjl-summary-row span{
    display:block;
    margin-top:4px;
    color:#666;
    font-size:13px;
}
@media(max-width:720px){.gjjl-summary-row{grid-template-columns:1fr}}

/* GJ Suite 1.1.07 – sicherer Jobs-Ortsfilter, strikt gekapselt */
.gjjl-wrap--portal{max-width:1120px;margin-left:auto;margin-right:auto}
.gjjl-location-tabs{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px;padding:0 0 12px;border-bottom:1px solid #f1dedb}
.gjjl-location-tab{display:inline-flex;border:1px solid #e7cac5;border-radius:999px;background:#fff;color:#b53d33!important;text-decoration:none!important;padding:8px 13px;font-weight:700}
.gjjl-location-tab.is-active,.gjjl-location-tab:hover{background:#b53d33;color:#fff!important}
.gjjl-tabs a.gjjl-tab{text-decoration:none!important}
.gjjl-card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.gjjl-button--soft{background:#fff;color:#b53d33!important;border:1px solid #e7cac5}

/* GJ Suite 1.1.12 – Jobs AJAX-Nachladen */
.gjjl-ajax-status{
    min-height:18px;
    margin:0 0 10px;
    font-size:13px;
    color:#777;
}
[data-gjjl-results].is-loading{
    opacity:.45;
    pointer-events:none;
    transition:opacity .15s ease;
}
.gjjl-tabs a.gjjl-tab,
.gjjl-location-tabs a.gjjl-location-tab{
    cursor:pointer;
}

/* GJ Suite 1.1.15 – Firmenlogos und Quellenhinweis */
.gjjl-job-card__logo img{
    width:100%;
    height:100%;
    object-fit:contain;
    object-position:center center;
    background:#fff;
}
.gjjl-job-card__source{
    margin-top:4px;
    font-size:12px;
    color:#777;
}
.gjjl-job-card__company + .gjjl-job-card__source{
    margin-top:2px;
}

/* GJ Suite 1.1.16 – Lehrlingsjournal-Karten bereinigt */
.gjjl-job-card .gjjl-job-card__source{
    color:#777;
    font-size:12px;
}

/* GJ Suite 1.1.18 – Firmendetail-Jobs & Ablaufstatus */
.gjjl-company-block--detail{margin:28px 0;padding:24px;border:1px solid #f0e1df;border-radius:16px;background:#fff;box-shadow:0 8px 22px rgba(79,33,28,.06)}
.gjjl-company-block__head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:16px}
.gjjl-company-block__head h2{margin:3px 0 0;font-size:24px;line-height:1.2}
.gjjl-company-job-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.gjjl-company-job--card{border:1px solid #f0e1df;border-radius:14px;padding:16px;background:#fffaf9}
.gjjl-company-job--card h3{margin:8px 0 10px;font-size:19px;line-height:1.25}
.gjjl-company-job__meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:10px 0 12px}
.gjjl-company-job__meta span{display:block;border:1px solid #f0e1df;border-radius:10px;background:#fff;padding:8px 10px;font-size:13px}
.gjjl-company-job__meta strong{display:block;margin-bottom:3px;color:#333}
.gjjl-job-statusline{padding:7px 10px;background:#f8f8f8;border-left:4px solid #b53d33}
@media(max-width:760px){.gjjl-company-job-grid{grid-template-columns:1fr}.gjjl-company-job__meta{grid-template-columns:1fr}.gjjl-company-block__head{display:block}}
