/* JGR Theme – Content CSS v3
   Vollständige Neugestaltung aller ClanSphere-Ausgaben im JGR-Stil.
   Gilt für alles in {func:show}: Tabellen, Formulare, Forum, Profile, Listen. */

/* ─────────────────────────────────────────────────────────────
   BASIS
───────────────────────────────────────────────────────────── */
#content {
    color: var(--tx1);
    font-family: var(--fi);
    font-size: 13px;
    line-height: 1.6;
    min-width: 0;
    overflow-x: hidden;
    contain: layout;
}
#content hr {
    border: none;
    border-top: 1px solid rgba(255,255,255,0.08);
    margin: 14px 0;
}
/* Überschriften: gleiche Größe wie Widget-Heads (12px) */
#content h1 { font-family: var(--fh); font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--tx1); margin-bottom: 6px; }
#content h2 { font-family: var(--fh); font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--tx2); margin-bottom: 5px; }
#content h3 { font-family: var(--fh); font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--tx3); margin-bottom: 4px; }
#content p  { color: var(--tx2); margin-bottom: 6px; }
#content a:link, #content a:visited { color: var(--sky); }
#content a:hover { color: var(--gold); }
#content ol  { margin-left: 20px; color: var(--tx2); }
#content ul li { list-style: disc; margin-left: 16px; color: var(--tx2); padding: 2px 0; }
#content img { max-width: 100%; height: auto; }
#content .card-body {
    overflow-x: auto;
    overflow-y: visible;
    word-wrap: break-word;
    overflow-wrap: break-word;
    padding: 12px;
    box-sizing: border-box;
}
/* .forum Tabellen: volle Breite im card-body */
#content .card-body .forum,
#content .card-body #csp_content .forum {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
}

#infobox { display: none; }

/* ─────────────────────────────────────────────────────────────
   TABELLEN – das Herzstück
───────────────────────────────────────────────────────────── */
.forum {
    background: rgba(255,255,255,0.06);
    border-collapse: separate;
    border-spacing: 1px;
    width: 100%;
    max-width: 100%;
    margin: 0 auto 14px auto;
    border-radius: 6px;
    table-layout: fixed;
}
.forum td, .forum th {
    border: none;
    vertical-align: middle;
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: break-word;
    overflow: hidden;
    padding: 9px 12px;
}


/* Tabellenköpfe */
/* .headb = gleicher Stil wie .card-head der Widgets */
.headb, .newshead {
    background: rgba(255,255,255,0.07);
    color: var(--tx2);
    padding: 6px 10px;
    font-family: var(--fh);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .10em;
    text-transform: uppercase;
    border-bottom: 1px solid rgba(255,255,255,0.09);
}
/* News-Überschriften größer als Forum-Spaltenköpfe */
.newshead {
    font-size: 12px;
    letter-spacing: .06em;
    padding: 8px 12px;
}
/* News-Headline exklusiv in Gold */
.newshead div, .newshead a, .newshead {
    color: var(--gold) !important;
    text-shadow: 0 0 10px rgba(255,204,0,0.20);
}

/* Wert-Zeilen (hell) */
.leftb, .centerb, .rightb {
    background: rgba(255,255,255,0.08);
    color: var(--tx1);
    transition: background .15s;
    line-height: 1.5;
}
/* Label-Zeilen (dunkel) */
.leftc, .centerc, .rightc {
    background: rgba(255,255,255,0.03);
    color: var(--tx3);
    font-family: var(--fh);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .05em;
    white-space: nowrap;
    line-height: 1.5;
    text-overflow: ellipsis;
}
/* Thread Text-Spalte: white-space normal damit Text umbricht */
.jgr-thread-table td.leftc:not([style*="width:180px"]) {
    white-space: normal !important;
    text-overflow: clip !important;
}
/* Hover auf Daten-Zeilen */
.forum tr:hover .leftb,
.forum tr:hover .centerb,
.forum tr:hover .rightb {
    background: rgba(41,182,246,0.06);
}

.bottom {
    background: rgba(255,255,255,0.03);
    color: var(--tx2);
    padding: 8px 14px;
    font-size: 11px;
}
.notpublic {
    background: rgba(255,255,255,0.015) !important;
    color: rgba(255,255,255,0.22) !important;
    font-style: italic;
}
.left, .leftb, .leftc     { text-align: left; }
.center, .centerb, .centerc { text-align: center; }
.right,  .rightb,  .rightc  { text-align: right; }
.left, .center, .right { padding: 1px; }

/* Icons: überall inline, links von Text */
#content img,
.forum img:not(.jgr-cat-img),
.leftb img:not(.jgr-cat-img), .leftc img,
.centerb img, .centerc img,
.rightb img, .rightc img {
    display: inline-block;
    vertical-align: middle;
    margin-right: 4px;
    flex-shrink: 0;
    position: relative;
    top: -1px;
}
.leftc img {
    transform: scale(0.82);
    transform-origin: center center;
    opacity: 0.85;
}

/* ─────────────────────────────────────────────────────────────
   FORMULARE
───────────────────────────────────────────────────────────── */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="search"],
input[type="url"],
select {
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.16);
    border-radius: 5px;
    color: var(--tx1);
    font-family: var(--fi);
    font-size: 12px;
    padding: 7px 11px;
    transition: border-color .2s, background .2s, box-shadow .2s;
    max-width: 100%;
    box-sizing: border-box;
    vertical-align: middle;
}
input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
input[type="url"]:focus,
select:focus {
    outline: none;
    border-color: var(--sky);
    background: rgba(255,255,255,0.11);
    box-shadow: 0 0 0 3px rgba(41,182,246,0.16);
}
input::placeholder { color: rgba(255,255,255,0.28); }

textarea, .rte_abcode {
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.16);
    border-radius: 5px;
    color: var(--tx1);
    font-family: var(--fi);
    font-size: 12px;
    padding: 8px 11px;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    resize: vertical !important;
    min-height: 80px;
    max-height: 520px;
    overflow-x: hidden !important;
    transition: border-color .2s, box-shadow .2s;
}
textarea:focus, .rte_abcode:focus {
    outline: none;
    border-color: var(--sky);
    box-shadow: 0 0 0 3px rgba(41,182,246,0.16);
}

select {
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%237AAFCC'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 10px;
    -webkit-appearance: none; -moz-appearance: none; appearance: none;
    padding-right: 30px;
}
select option { background: #001050; color: var(--tx1); }

input[type="checkbox"],
input[type="radio"] {
    accent-color: var(--sky);
    width: 14px; height: 14px;
    vertical-align: middle;
    margin-right: 5px;
    cursor: pointer;
}
label { color: var(--tx2); font-size: 12px; vertical-align: middle; cursor: pointer; }

/* Inputs in Tabellenzellen: nie breiter als die Zelle */
.leftb input[type="text"]:not(.jgr-time-sel),
.leftb input[type="password"],
.leftb input[type="email"],
.leftb input[type="url"],
.leftb input[type="number"],
.leftb input[type="search"],
.leftb select:not(.jgr-date-sel):not(.jgr-date-sel-sm),
.centerb input[type="text"]:not(.jgr-time-sel),
.centerb select:not(.jgr-date-sel) {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}



/* ─────────────────────────────────────────────────────────────
   BUTTONS
───────────────────────────────────────────────────────────── */
input[type="submit"],
input[type="button"],
input[type="reset"],
button {
    display: inline-block;
    padding: 5px 12px;
    border-radius: 5px;
    font-family: var(--fh);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .10em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all .20s;
    white-space: nowrap;
    vertical-align: middle;
    background: rgba(41,182,246,0.16);
    border: 1px solid rgba(41,182,246,0.40);
    color: var(--skybright);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.10);
}
input[type="submit"]:hover,
input[type="button"]:hover,
button:hover {
    background: rgba(41,182,246,0.30);
    border-color: rgba(41,182,246,0.65);
    color: #fff;
    box-shadow: 0 0 16px rgba(41,182,246,0.22),
                inset 0 1px 0 rgba(255,255,255,0.14);
    transform: translateY(-1px);
}
input[type="submit"]:active,
input[type="button"]:active,
button:active { transform: translateY(0); box-shadow: none; }

/* Primär (name=submit) → Gold */
input[name="submit"] {
    background: linear-gradient(135deg,
        rgba(255,200,0,0.28) 0%,
        rgba(200,90,0,0.28) 100%);
    border-color: rgba(255,175,0,0.52);
    color: #FFE082;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.12);
}
input[name="submit"]:hover {
    background: linear-gradient(135deg,
        rgba(255,200,0,0.46) 0%,
        rgba(200,90,0,0.46) 100%);
    border-color: rgba(255,175,0,0.78);
    color: #fff;
    box-shadow: 0 0 18px rgba(255,155,0,0.24),
                inset 0 1px 0 rgba(255,255,255,0.16);
}

/* Löschen (name=delete/remove) → Rot */
input[name="delete"],
input[name="remove"] {
    background: rgba(229,57,53,0.16);
    border-color: rgba(229,57,53,0.40);
    color: #FF8A80;
}
input[name="delete"]:hover,
input[name="remove"]:hover {
    background: rgba(229,57,53,0.30);
    border-color: rgba(229,57,53,0.65);
    color: #fff;
    box-shadow: 0 0 14px rgba(229,57,53,0.20);
}

/* Reset → dezent Grau */
input[type="reset"] {
    background: rgba(255,255,255,0.06);
    border-color: rgba(255,255,255,0.20);
    color: var(--tx3);
}
input[type="reset"]:hover {
    background: rgba(255,255,255,0.12);
    color: var(--tx1);
}

/* ─────────────────────────────────────────────────────────────
   MELDUNGSBOXEN
───────────────────────────────────────────────────────────── */
#msg_normal, #msg_success, #msg_error {
    border-radius: 8px;
    margin: 0 auto 14px auto;
    overflow: hidden;
    border: 1px solid;
    font-family: var(--fi);
    font-size: 12px;
}
#msg_normal div, #msg_success div, #msg_error div { padding: 12px 18px; }
#msg_normal  {
    background: rgba(41,182,246,0.07);
    border-color: rgba(41,182,246,0.22);
    color: var(--tx2);
}
#msg_success {
    background: rgba(76,175,80,0.10);
    border-color: rgba(76,175,80,0.32);
    color: #A5D6A7;
}
#msg_error {
    background: rgba(229,57,53,0.10);
    border-color: rgba(229,57,53,0.32);
    color: #FF8A80;
}

/* ─────────────────────────────────────────────────────────────
   PAGINATION
───────────────────────────────────────────────────────────── */
.pages, .navpages {
    display: flex; flex-wrap: wrap; gap: 5px;
    padding: 12px 0;
    font-family: var(--fh);
    font-size: 11px;
    align-items: center;
}
.pages a, .navpages a {
    background: rgba(255,255,255,0.07);
    border-radius: 4px;
    padding: 4px 10px;
    color: var(--tx2);
    transition: all .15s;
}
.pages a:hover, .navpages a:hover {
    background: rgba(41,182,246,0.18);
    border-color: rgba(41,182,246,0.40);
    color: var(--sky);
}
.pages strong, .navpages strong {
    background: rgba(41,182,246,0.22);
    border: 1px solid rgba(41,182,246,0.42);
    border-radius: 4px;
    padding: 4px 10px;
    color: var(--sky);
    font-weight: 700;
}

/* ─────────────────────────────────────────────────────────────
   FORUM-SPEZIFISCH
───────────────────────────────────────────────────────────── */
/* Thread-Starter Beitrag */
.thread_author_comment .leftc {
    background: rgba(41,182,246,0.07);
    border-left: 2px solid rgba(41,182,246,0.35);
}
/* Nutzerstatus */
.uonline   { color: #4CAF50; font-weight: 700; }
.uoffline  { color: var(--crimson); }
.uinactive { color: var(--tx3); }
.uthreadstarter { color: var(--gold); font-weight: 700; }

/* Zitat */
.quote {
    background: rgba(255,255,255,0.04);
    border-left: 3px solid rgba(41,182,246,0.40);
    border-radius: 0 5px 5px 0;
    color: var(--tx2);
    padding: 10px 16px;
    font-style: italic;
    margin: 10px 0;
    font-size: 12px;
}

/* Text-Klassen */
.h1 { color: var(--tx1); font-size: 13px; font-weight: 700; font-family: var(--fh); letter-spacing: .08em; text-transform: uppercase; }
.h2 { color: var(--tx2); font-size: 12px; font-weight: 700; font-family: var(--fh); letter-spacing: .08em; text-transform: uppercase; }
.h3 { color: var(--tx3); font-size: 11px; font-weight: 700; font-family: var(--fh); letter-spacing: .06em; text-transform: uppercase; }

/* ─────────────────────────────────────────────────────────────
   KALENDER (Modul-Output)
───────────────────────────────────────────────────────────── */
.calhead {
    background: rgba(41,182,246,0.14);
    color: var(--tx2);
    padding: 5px 4px;
    text-align: center;
    font-family: var(--fh);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .08em;
}
.calday  { background: rgba(255,255,255,0.03); color: rgba(255,255,255,0.32); padding: 4px 3px; text-align: right; font-size: 11px; }
.calweek { background: rgba(255,255,255,0.015); color: rgba(255,255,255,0.18); padding: 4px 3px; text-align: right; font-size: 11px; }
.calevent {
    background: rgba(41,182,246,0.14);
    color: var(--sky);
    padding: 4px 3px;
    text-align: right;
    font-size: 11px;
    font-weight: 700;
}
.caltoday {
    background: linear-gradient(135deg, rgba(79,195,247,0.38), rgba(2,119,189,0.38));
    color: #fff;
    font-weight: 700;
    padding: 4px 3px;
    text-align: right;
    font-size: 11px;
    border-radius: 3px;
}

/* ─────────────────────────────────────────────────────────────
   MANAGE-KACHELN (Verwaltung / Einstellungen / System)
───────────────────────────────────────────────────────────── */
.jgr-manage-head {
    background: var(--glass);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius);
    padding: 14px 18px;
    margin-bottom: 16px;
    box-shadow: var(--card-shadow);
}
.jgr-manage-title {
    font-family: var(--fh);
    font-size: 16px;
    font-weight: 700;
    letter-spacing: .06em;
    color: var(--tx1);
    margin-bottom: 4px;
}
.jgr-manage-sub  { font-family: var(--fi); font-size: 11px; color: var(--tx3); }
.jgr-manage-count { color: var(--sky); font-weight: 700; }

.jgr-manage-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 10px;
}
.jgr-manage-tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 18px 10px 14px;
    background: var(--glass);
    border: 1px solid var(--glass-border-lo);
    border-radius: var(--radius);
    box-shadow: var(--card-shadow);
    text-decoration: none;
    transition: all .22s;
    min-height: 100px;
    cursor: pointer;
}
.jgr-manage-tile:hover {
    background: var(--glass-hi);
    border-color: rgba(41,182,246,0.45);
    box-shadow: 0 4px 20px rgba(0,0,0,0.22),
                0 0 18px rgba(41,182,246,0.18),
                inset 0 1px 0 rgba(255,255,255,0.22);
    transform: translateY(-2px);
}
.jgr-manage-tile:hover .jgr-manage-label { color: var(--gold); }

.jgr-manage-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
}
.jgr-manage-icon img {
    width: 48px !important;
    height: 48px !important;
    display: block;
    object-fit: contain;
    filter: drop-shadow(0 2px 6px rgba(41,182,246,0.25));
}
.jgr-manage-tile:hover .jgr-manage-icon img {
    filter: drop-shadow(0 2px 12px rgba(41,182,246,0.55));
}
.jgr-manage-label {
    font-family: var(--fh);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--tx2);
    text-align: center;
    line-height: 1.3;
    transition: color .2s;
}

/* Tabellen-Ansicht (manage_admin.tpl) */
.jgr-manage-table { margin-bottom: 0; }
.jgr-admin-name { font-family: var(--fi); font-size: 12px; }
.jgr-admin-name img { transform: none; width: 16px !important; height: 16px !important; vertical-align: middle; margin-right: 6px; opacity: 0.85; }
.jgr-admin-action a {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 4px 12px;
    background: rgba(41,182,246,0.12);
    border: 1px solid rgba(41,182,246,0.30);
    border-radius: 4px;
    font-family: var(--fh); font-size: 9px; font-weight: 700;
    letter-spacing: .10em; text-transform: uppercase;
    color: var(--sky); transition: all .15s;
}
.jgr-admin-action a:hover {
    background: rgba(41,182,246,0.25);
    border-color: rgba(41,182,246,0.55);
    color: #fff;
}

/* ─────────────────────────────────────────────────────────────
   MANAGE-ITEMS (alte .manage Klasse)
───────────────────────────────────────────────────────────── */
.manage {
    background: var(--glass);
    border: 1px solid var(--glass-border-lo);
    border-radius: 6px;
    margin: 4px;
    padding: 8px 12px;
    transition: background .15s;
    display: inline-block;
}
.manage:hover { background: var(--glass-hi); border-color: rgba(41,182,246,0.30); }

/* ─────────────────────────────────────────────────────────────
   THEME-BAR / MISC
───────────────────────────────────────────────────────────── */
.themebar {
    background: rgba(255,255,255,0.03);
    border: 1px dashed rgba(255,255,255,0.12);
    border-radius: 5px;
    margin: 6px 0;
    padding: 8px 12px;
    color: var(--tx3);
    font-size: 11px;
}

/* AJAX Ladeanzeige */
#ajax_loading {
    position: absolute;
    top: 50%; right: 50%;
    background: rgba(0,10,60,0.90);
    border: 1px solid rgba(41,182,246,0.30);
    border-radius: 8px;
    padding: 12px 20px;
    color: var(--tx2);
    font-family: var(--fi);
    font-size: 12px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.35);
}

/* Scroll-Up Button */
.scroll-up-bar {
    display: flex;
    justify-content: flex-end;
    padding: 8px 14px;
    border-top: 1px solid rgba(255,255,255,0.07);
}
.scroll-up-btn {
    font-family: var(--fh);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--tx3);
    display: flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
    background: none;
    border: none;
    transition: color .15s;
}
.scroll-up-btn:hover { color: var(--gold); }

/* Kompakte Kacheln (manage_list) */
.jgr-manage-grid-compact {
    grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
    gap: 8px;
}
.jgr-manage-tile-compact {
    min-height: 75px;
    padding: 12px 8px 10px;
}
.jgr-manage-icon-sm {
    width: 32px;
    height: 32px;
}
.jgr-manage-icon-sm img {
    width: 32px !important;
    height: 32px !important;
}



/* Text-Spalte daneben nimmt den Rest */
.forum td[style*="width:150px"] + td,
.forum td[style*="width: 150px"] + td {
    width: auto;
    word-break: break-word;
    overflow-wrap: break-word;
    overflow: hidden;
}

/* ── THREAD-ANSICHT: Userinfo 180px, Text nimmt den Rest ── */
.jgr-thread-table {
    table-layout: fixed !important;
}
.jgr-thread-table td[style*="width:180px"] {
    overflow: hidden;
}
.jgr-thread-table td[style*="width:180px"] {
    width: 180px !important;
    min-width: 180px !important;
    max-width: 180px !important;
    vertical-align: top;
    word-break: break-word;
}
.jgr-thread-table td.leftc:not([style*="width:180px"]),
.jgr-thread-table td.leftb:not([style*="width:180px"]) {
    word-break: break-word;
    overflow-wrap: break-word;
    vertical-align: top;
    white-space: normal !important;
    color: var(--tx1);
    font-family: var(--fi);
    font-size: 13px;
    font-weight: 400;
    letter-spacing: normal;
}
.forum td[style*="width:180px"] {
    width: 180px !important;
    min-width: 180px !important;
    max-width: 180px !important;
    vertical-align: top;
    overflow: hidden;
    word-break: break-word;
}
.jgr-thread-table td[style*="width:150px"],
.jgr-thread-table td[style*="width: 150px"] {
    width: 160px !important;
    min-width: 160px !important;
    max-width: 160px !important;
    vertical-align: top;
}
/* Text-Spalte bekommt den Rest */
.jgr-thread-table td.leftc + td.leftc,
.jgr-thread-table td.leftc + td.leftb {
    width: auto;
    min-width: 0;
    word-break: break-word;
    overflow-wrap: break-word;
    vertical-align: top;
}

/* ── FORENÜBERSICHT: bessere Lesbarkeit ─────────────────── */
.forum .leftb a {
    color: var(--tx1);
    font-weight: 700;
}
.forum .leftb a:hover {
    color: var(--sky);
}
.forum .leftb strong a {
    color: var(--tx1) !important;
    font-family: var(--fh);
    font-size: 13px;
    letter-spacing: .04em;
}
.forum .leftb strong a:hover {
    color: var(--gold) !important;
}
/* Board-Beschreibung unter dem Namen */
.forum .leftb br + * { color: var(--tx3); font-size: 11px; }
/* Letzte Posts: lesbare Schrift */
.forum .leftb[style*="width:180px"] {
    font-size: 11px;
    color: var(--tx2);
    line-height: 1.6;
}
.forum .leftb[style*="width:180px"] a {
    color: var(--sky);
}

/* ── FORENÜBERSICHT: Tabellen-Layout ────────────────────── */
.jgr-list-table {
    table-layout: auto !important;
}
.jgr-list-table td.rightb[style*="width:70px"] {
    width: 70px !important;
    min-width: 70px !important;
    text-align: center;
    font-family: var(--fh);
    font-size: 12px;
    font-weight: 700;
    color: var(--tx2);
}
.jgr-list-table td.leftb[style*="width:220px"] {
    width: 220px !important;
    min-width: 220px !important;
    font-size: 11px;
    color: var(--tx2);
    line-height: 1.6;
    vertical-align: top;
}
.jgr-list-table td.leftb[style*="width:220px"] a {
    color: var(--sky);
}

/* ── VERWALTUNGS-TABELLEN: harmonisches Layout ───────────── */
/* Datenzellen: Text umbrechen, lesbare Schrift */
.forum .leftc {
    white-space: normal;
    word-break: break-word;
    overflow-wrap: break-word;
    font-size: 11px;
    letter-spacing: .02em;
    color: var(--tx2);
    vertical-align: middle;
}
/* Optionsspalten (Edit/Delete) minimal */
.forum td.leftc:has(a[href*="edit"]),
.forum td.leftc:has(a[href*="remove"]),
.forum td.leftc:has(a[href*="del"]) {
    width: 32px !important;
    text-align: center;
    white-space: nowrap;
}
/* Letzte Spalte (Optionen) immer kompakt */
.forum td[style*="width:50px"] {
    width: 50px !important;
    text-align: center;
}
/* Paginierung rechts */
.forum .rightb {
    text-align: right;
    color: var(--tx2);
    font-size: 11px;
}
/* Links in Datenzellen */
.forum .leftc a {
    color: var(--sky);
    text-decoration: none;
}
.forum .leftc a:hover {
    color: var(--gold);
}

/* ── DATUM/ZEIT FELDER ──────────────────────────────────── */
.jgr-dateselect {
    display: flex;
    flex-wrap: nowrap;
    gap: 5px;
    align-items: flex-end;
    padding: 2px 0;
}
.jgr-date-sel {
    font-family: var(--fi);
    font-size: 11px;
    color: var(--tx1);
    background: rgba(255,255,255,0.07);
    border-radius: 4px;
    padding: 0 4px;
    height: 26px;
    width: 70px;
    box-sizing: border-box;
    cursor: pointer;
}
.jgr-date-sel-xs { width: 52px !important; }
.jgr-date-field {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 5px;
    vertical-align: middle;
}
.jgr-date-label {
    font-family: var(--fh);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--tx3);
    line-height: 1;
    white-space: nowrap;
}
.jgr-time-group {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    vertical-align: middle;
}
input[type="text"].jgr-time-sel {
    font-family: var(--fi);
    font-size: 11px;
    color: var(--tx1);
    background: rgba(255,255,255,0.07);
    border-radius: 4px;
    padding: 0 2px !important;
    height: 26px !important;
    width: 2.2em !important;
    max-width: 2.2em !important;
    min-width: 0 !important;
    box-sizing: content-box !important;
    text-align: center;
}
.jgr-date-divider {
    color: var(--tx3);
    margin: 0 2px;
}
.jgr-date-colon {
    color: var(--tx3);
    font-weight: 700;
}
/* Smileys: JGR Flexbox */
.jgr-smileys {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 6px 0;
    align-items: center;
}
.jgr-smiley {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 4px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    transition: all .15s;
    cursor: pointer;
    text-decoration: none;
    line-height: 0;
    vertical-align: middle;
    overflow: hidden;
}
.jgr-smiley:hover {
    background: rgba(41,182,246,0.15);
    border-color: rgba(41,182,246,0.35);
    transform: scale(1.15);
}
.jgr-smiley img {
    width: 22px !important;
    height: 22px !important;
    display: block !important;
    margin: auto !important;
    padding: 0;
    flex-shrink: 0;
}
.jgr-smiley-more {
    font-size: 10px;
    color: var(--sky);
    text-decoration: none;
    padding: 4px 8px;
    border: 1px solid rgba(41,182,246,0.30);
    border-radius: 4px;
    transition: all .15s;
}
.jgr-smiley-more:hover { background: rgba(41,182,246,0.12); }

/* Formular-Abstände: Buttons und Dropdowns nicht zu eng */
.leftb select, .centerb select, .leftc select {
    margin-right: 6px;
    margin-bottom: 4px;
}
.leftb input[type="submit"],
.leftb input[type="button"],
.centerb input[type="submit"] {
    margin-left: 4px;
    margin-top: 2px;
}

/* Abgerundete Ecken: erste und letzte Zeile der Tabelle */
.forum tr:first-child td:first-child,
.forum tr:first-child th:first-child {
    border-radius: 5px 0 0 0;
}
.forum tr:first-child td:last-child,
.forum tr:first-child th:last-child {
    border-radius: 0 5px 0 0;
}
.forum tr:first-child td:only-child,
.forum tr:first-child th:only-child {
    border-radius: 5px 5px 0 0;
}
.forum tr:last-child td:first-child {
    border-radius: 0 0 0 5px;
}
.forum tr:last-child td:last-child {
    border-radius: 0 0 5px 0;
}
.forum tr:last-child td:only-child {
    border-radius: 0 0 5px 5px;
}

/* ── KATEGORIE-BILD im Beitrag ──────────────────────────── */
.jgr-cat-img {
    float: left;
    width: 192px;
    height: 256px;
    object-fit: cover;
    border-radius: 8px;
    margin: 7px 14px 7px 0 !important;
    border: 1px solid rgba(255,255,255,0.10);
    box-shadow: 0 1px 4px rgba(0,0,0,0.18);
    flex-shrink: 0;
}
.jgr-news-body {
    color: var(--tx1);
    font-size: 13px;
    line-height: 1.75;
}
.jgr-news-body p {
    margin: 0 0 0.9em 0;
}
.jgr-news-body br + br {
    display: block;
    margin-top: 0.7em;
    content: "";
}
/* Text unterhalb des Bildes: sauber ausgerichtet */
.jgr-news-body::after {
    content: "";
    display: table;
    clear: both;
}

/* ── KATEGORIEBILD: Mobile 20% kleiner ──────────────────── */
@media (max-width: 640px) {
    .jgr-cat-img {
        width: 154px !important;
        height: 205px !important;
        margin: 6px 12px 6px 0 !important;
    }
}

/* ── WEITERLESEN BUTTON ─────────────────────────────────── */
.jgr-readmore-wrap {
    margin-top: 10px;
    clear: both;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.jgr-readmore-wrap a,
.jgr-readmore-wrap button {
    vertical-align: middle;
    box-sizing: border-box;
}
.jgr-readmore-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 28px;
    padding: 0 14px;
    font-family: var(--fh);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--sky) !important;
    border: 1px solid rgba(41,182,246,0.35);
    border-radius: 4px;
    background: rgba(41,182,246,0.07);
    text-decoration: none;
    transition: all .18s;
    line-height: 1;
}
.jgr-readmore-btn:hover {
    background: rgba(41,182,246,0.18);
    border-color: rgba(41,182,246,0.6);
    color: #fff !important;
}

/* ── THREAD: Avatar auf Spaltengröße begrenzen ──────────── */
.jgr-thread-table td[style*="width:180px"] img {
    max-width: 140px !important;
    width: auto !important;
    height: auto !important;
    display: block;
    margin: 4px 0;
}

/* ── THREAD: Userinfo-Spalte sauber gestaffelt ──────────── */
.jgr-userinfo {
    padding: 10px 10px !important;
}
.jgr-ui-nick {
    font-size: 11px;
    font-weight: 700;
    color: var(--sky);
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.jgr-ui-rank {
    font-size: 10px;
    color: var(--gold);
    font-family: var(--fh);
    letter-spacing: .04em;
    margin-bottom: 8px;
}
.jgr-ui-avatar {
    margin-bottom: 8px;
}
.jgr-ui-avatar img {
    max-width: 140px !important;
    height: auto !important;
    display: block;
    border-radius: 4px;
}
.jgr-ui-meta {
    font-size: 10px;
    color: var(--tx3);
    line-height: 1.6;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.jgr-ui-author {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--sky);
    opacity: 0.6;
    margin-bottom: 4px;
}

/* ── SHARE BUTTON ───────────────────────────────────────── */
.jgr-readmore-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
/* ── AKTIONS-BUTTONS: Link kopieren, E-Mail, Drucken ────── */
.jgr-share-btn, .jgr-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    height: 28px;
    padding: 0 14px;
    font-family: var(--fh);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--tx3);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 4px;
    background: rgba(255,255,255,0.05);
    cursor: pointer;
    transition: all .18s;
    line-height: 1;
    text-decoration: none;
    box-sizing: border-box;
    vertical-align: middle;
}
.jgr-share-btn:hover, .jgr-action-btn:hover {
    background: rgba(255,255,255,0.10);
    border-color: rgba(255,255,255,0.3);
    color: var(--tx1);
}
.jgr-share-btn:active, .jgr-action-btn:active {
    background: rgba(255,255,255,0.18);
    border-color: rgba(255,255,255,0.5);
    transform: scale(0.96);
}
.jgr-share-btn img, .jgr-action-btn img {
    width: 12px !important;
    height: 12px !important;
    display: block !important;
    flex-shrink: 0;
    margin: 0 !important;
}
.jgr-share-btn.copied {
    color: #81C784;
    border-color: rgba(129,199,132,0.4);
    background: rgba(129,199,132,0.08);
}

/* Share-Zeile im vollständigen Beitrag */
.jgr-share-row {
    background: rgba(255,255,255,0.04) !important;
    padding: 10px 12px !important;
    border-top: 1px solid rgba(255,255,255,0.08);
}
