/**
 * Jeido Comments — Frontend Styles
 *
 * Modern, responsive comment UI with CSS custom properties for theming.
 * Layouts: classic · card · minimal
 */

/* ─── CSS Variables (defaults — overridden by inline style) ── */

:root {
    --jeido-color-primary: #2563eb;
    --jeido-color-accent: #8b5cf6;
    --jeido-color-bg: #ffffff;
    --jeido-color-bg-alt: #f8fafc;
    --jeido-color-text: #1e293b;
    --jeido-color-text-secondary: #64748b;
    --jeido-color-border: #e2e8f0;
    --jeido-color-success: #16a34a;
    --jeido-color-error: #dc2626;
    --jeido-avatar-size: 48px;
    --jeido-avatar-radius: 50%;
    --jeido-radius: 12px;
    --jeido-transition: .2s ease;
}

/* ─── Container ─────────────────────────────────────────────── */

.jeido-comments {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    font-size: 15px;
    line-height: 1.6;
    color: var(--jeido-color-text);
    width: 100%;
    margin: 40px 0;
}

.jeido-comments *, .jeido-comments *::before, .jeido-comments *::after {
    box-sizing: border-box;
}

/* ─── Header ────────────────────────────────────────────────── */

.jeido-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 24px;
}

.jeido-title {
    font-size: 22px;
    font-weight: 700;
    margin: 0;
    color: var(--jeido-color-text);
}

.jeido-count {
    color: var(--jeido-color-primary);
}

/* ─── Sort Controls ─────────────────────────────────────────── */

.jeido-sort-controls {
    display: flex;
    gap: 4px;
    background: var(--jeido-color-bg-alt);
    border-radius: 8px;
    padding: 3px;
}

.jeido-sort-btn {
    border: none;
    background: transparent;
    padding: 6px 14px;
    font-size: 13px;
    font-weight: 500;
    color: var(--jeido-color-text-secondary);
    border-radius: 6px;
    cursor: pointer;
    transition: all var(--jeido-transition);
}

.jeido-sort-btn:hover {
    color: var(--jeido-color-text);
}

.jeido-sort-btn.active {
    background: var(--jeido-color-bg);
    color: var(--jeido-color-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, .08);
}

/* ─── Comment Form ──────────────────────────────────────────── */

.jeido-form-wrap {
    margin-bottom: 32px;
}

.jeido-form {
    background: var(--jeido-color-bg);
    border: 1px solid var(--jeido-color-border);
    border-radius: var(--jeido-radius);
    padding: 20px;
    position: relative;
    transition: box-shadow var(--jeido-transition);
}

.jeido-form:focus-within {
    border-color: var(--jeido-color-primary);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, .1);
}

.jeido-form-logged-in {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
    font-size: 14px;
    color: var(--jeido-color-text-secondary);
}

.jeido-guest-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 12px;
}

/* ── Alias Field ──────────────────────────────────────────── */

.jeido-alias-field {
    margin-bottom: 12px;
}

.jeido-alias-field .jeido-input {
    max-width: 320px;
}

.jeido-alias-hint {
    font-size: 12px;
    color: var(--jeido-color-text-secondary);
    margin: 4px 0 0;
}

/* ─── Link Removed Badge ────────────────────────────────────── */

.jeido-link-removed {
    display: inline;
    color: var(--jeido-color-text-secondary);
    font-style: italic;
    font-size: 0.9em;
}

/* ─── Cloudflare Turnstile ──────────────────────────────────── */

.jeido-turnstile {
    margin: 8px 0;
}

.jeido-input {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--jeido-color-border);
    border-radius: 8px;
    font-size: 14px;
    color: var(--jeido-color-text);
    background: var(--jeido-color-bg);
    outline: none;
    transition: border-color var(--jeido-transition);
}

.jeido-input:focus {
    border-color: var(--jeido-color-primary);
}

/* ─── Formatting Toolbar ────────────────────────────────────── */

.jeido-toolbar {
    display: flex;
    gap: 2px;
    margin-bottom: 8px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--jeido-color-border);
}

.jeido-tb-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    color: var(--jeido-color-text-secondary);
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    transition: all var(--jeido-transition);
}

.jeido-tb-btn:hover {
    background: var(--jeido-color-bg-alt);
    color: var(--jeido-color-text);
}

.jeido-tb-btn.active {
    background: var(--jeido-color-primary);
    color: #fff;
}

/* ─── Contenteditable Editor ────────────────────────────────── */

.jeido-editable {
    width: 100%;
    min-height: 100px;
    max-height: 300px;
    overflow-y: auto;
    padding: 12px 14px;
    border: none;
    font-size: 15px;
    font-family: inherit;
    line-height: 1.6;
    color: var(--jeido-color-text);
    background: transparent;
    outline: none;
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: break-word;
    cursor: text;
}

.jeido-editable:empty::before {
    content: attr(data-placeholder);
    color: var(--jeido-color-text-secondary);
    opacity: .6;
    pointer-events: none;
}

.jeido-editable code {
    background: var(--jeido-color-bg-alt);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 13px;
}

.jeido-editable a {
    color: var(--jeido-color-primary);
    text-decoration: underline;
}

/* ─── Textarea ──────────────────────────────────────────────── */

.jeido-textarea {
    width: 100%;
    min-height: 100px;
    padding: 12px 14px;
    border: none;
    resize: vertical;
    font-size: 15px;
    font-family: inherit;
    line-height: 1.6;
    color: var(--jeido-color-text);
    background: transparent;
    outline: none;
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: break-word;
}

.jeido-textarea::placeholder {
    color: var(--jeido-color-text-secondary);
    opacity: .6;
}

/* ─── Form Footer ───────────────────────────────────────────── */

.jeido-form-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 8px;
}

.jeido-char-count {
    font-size: 12px;
    color: var(--jeido-color-text-secondary);
}

.jeido-char-count.warning {
    color: #f59e0b;
}

.jeido-char-count.danger {
    color: var(--jeido-color-error);
}

.jeido-submit-btn {
    padding: 10px 24px;
    border: none;
    border-radius: 8px;
    background: var(--jeido-color-primary);
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--jeido-transition);
}

.jeido-submit-btn:hover {
    opacity: .9;
    transform: translateY(-1px);
}

.jeido-submit-btn:active {
    transform: translateY(0);
}

.jeido-submit-btn:disabled {
    opacity: .5;
    cursor: not-allowed;
    transform: none;
}

/* ─── Form Message ──────────────────────────────────────────── */

.jeido-form-message {
    padding: 10px 16px;
    border-radius: 8px;
    font-size: 14px;
    margin-top: 12px;
}

.jeido-form-message.success {
    background: #f0fdf4;
    color: var(--jeido-color-success);
    border: 1px solid #bbf7d0;
}

.jeido-form-message.error {
    background: #fef2f2;
    color: var(--jeido-color-error);
    border: 1px solid #fecaca;
}

/* ─── Comment List ──────────────────────────────────────────── */

.jeido-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* ─── Single Comment ────────────────────────────────────────── */

.jeido-comment {
    position: relative;
    padding: 20px 0;
    animation: jeidoFadeIn .3s ease;
}

@keyframes jeidoFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.jeido-comment-inner {
    display: flex;
    gap: 14px;
}

/* ─── Avatar ────────────────────────────────────────────────── */

.jeido-comment-avatar {
    flex-shrink: 0;
}

.jeido-avatar,
.jeido-comment-avatar img {
    width: var(--jeido-avatar-size);
    height: var(--jeido-avatar-size);
    border-radius: var(--jeido-avatar-radius);
    object-fit: cover;
}

/* ─── Comment Body ──────────────────────────────────────────── */

.jeido-comment-body {
    flex: 1;
    min-width: 0;
}

/* ─── Meta (Author + Time) ──────────────────────────────────── */

.jeido-comment-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}

.jeido-author {
    font-size: 14px;
    font-weight: 600;
    color: var(--jeido-color-text);
}

.jeido-time {
    font-size: 12px;
    color: var(--jeido-color-text-secondary);
}

/* ─── Reply-to Indicator ────────────────────────────────────── */

.jeido-reply-to {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 12px;
    color: var(--jeido-color-primary);
    opacity: .8;
}

.jeido-reply-to svg {
    opacity: .6;
}

/* ─── Badges ────────────────────────────────────────────────── */

.jeido-badge {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    padding: 2px 7px;
    border-radius: 4px;
}

.jeido-badge-admin {
    background: #dbeafe;
    color: #1d4ed8;
}

.jeido-badge-author {
    background: #f3e8ff;
    color: #7c3aed;
}

/* ─── Comment Content ───────────────────────────────────────── */

.jeido-comment-content {
    font-size: 15px;
    line-height: 1.6;
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: break-word;
    overflow: hidden;
}

.jeido-comment-content p {
    margin: 0 0 8px;
}

.jeido-comment-content p:last-child {
    margin-bottom: 0;
}

.jeido-comment-content code {
    background: var(--jeido-color-bg-alt);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 13px;
}

.jeido-comment-content a {
    color: var(--jeido-color-primary);
    text-decoration: none;
}

.jeido-comment-content a:hover {
    text-decoration: underline;
}

.jeido-edited-label {
    font-size: 12px;
    color: var(--jeido-color-text-secondary);
    font-style: italic;
}

/* ─── Sticky ────────────────────────────────────────────────── */

.jeido-sticky {
    background: linear-gradient(135deg, rgba(37, 99, 235, .03), rgba(139, 92, 246, .03));
    border: 1px solid rgba(37, 99, 235, .12);
    border-radius: var(--jeido-radius);
    padding: 20px;
    margin-bottom: 8px;
}

.jeido-sticky-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    color: var(--jeido-color-primary);
    margin-bottom: 8px;
}

/* ─── Actions Bar ───────────────────────────────────────────── */

.jeido-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    flex-wrap: wrap;
}

.jeido-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border: none;
    background: transparent;
    color: var(--jeido-color-text-secondary);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    border-radius: 6px;
    transition: all var(--jeido-transition);
}

.jeido-action-btn:hover {
    background: var(--jeido-color-bg-alt);
    color: var(--jeido-color-text);
}

/* ─── Vote Group ────────────────────────────────────────────── */

.jeido-vote-group {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    background: var(--jeido-color-bg-alt);
    border-radius: 20px;
    padding: 2px 4px;
}

.jeido-vote-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: none;
    background: transparent;
    color: var(--jeido-color-text-secondary);
    cursor: pointer;
    border-radius: 50%;
    transition: all var(--jeido-transition);
}

.jeido-vote-btn:hover {
    background: var(--jeido-color-border);
}

.jeido-vote-up.active {
    color: var(--jeido-color-primary);
}

.jeido-vote-down.active {
    color: var(--jeido-color-error);
}

.jeido-score {
    font-size: 13px;
    font-weight: 600;
    min-width: 20px;
    text-align: center;
    color: var(--jeido-color-text);
}

/* ─── Reactions ─────────────────────────────────────────────── */

.jeido-reactions-wrapper {
    position: relative;
}

.jeido-react-toggle {
    font-size: 16px;
    padding: 4px 8px;
}

.jeido-reaction-picker {
    position: absolute;
    bottom: 100%;
    left: 0;
    display: flex;
    gap: 2px;
    background: var(--jeido-color-bg);
    border: 1px solid var(--jeido-color-border);
    border-radius: 24px;
    padding: 6px 10px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, .1);
    z-index: 10;
    animation: jeidoPopIn .15s ease;
}

@keyframes jeidoPopIn {
    from { opacity: 0; transform: scale(.9) translateY(4px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}

.jeido-reaction-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    font-size: 20px;
    cursor: pointer;
    border-radius: 50%;
    transition: transform .15s ease;
}

.jeido-reaction-btn:hover {
    transform: scale(1.3);
    background: var(--jeido-color-bg-alt);
}

.jeido-reaction-btn.active {
    background: var(--jeido-color-bg-alt);
}

/* ─── Reaction Summary ──────────────────────────────────────── */

.jeido-reaction-summary {
    display: flex;
    gap: 6px;
    margin-top: 8px;
    flex-wrap: wrap;
}

.jeido-reaction-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    background: var(--jeido-color-bg-alt);
    border: 1px solid var(--jeido-color-border);
    border-radius: 20px;
    font-size: 13px;
    cursor: default;
}

.jeido-reaction-chip.mine {
    border-color: var(--jeido-color-primary);
    background: rgba(37, 99, 235, .06);
}

.jeido-reaction-count {
    font-size: 12px;
    font-weight: 600;
    color: var(--jeido-color-text-secondary);
}

/* ─── Children / Threads ────────────────────────────────────── */

.jeido-children {
    /* Indent replies to align with parent's text start (avatar + gap) */
    margin-left: calc(var(--jeido-avatar-size) + 14px);
    padding-left: 0;
}

/* Reply comments — subtle background stepping, no lines */
.jeido-children > .jeido-comment {
    padding: 14px 16px;
    margin-bottom: 0;
    border-bottom: none;
    border-radius: 10px;
    background: rgba(127, 127, 127, .04);
    margin-top: 4px;
}

/* Smaller avatars for replies */
.jeido-children .jeido-comment-avatar img,
.jeido-children .jeido-avatar {
    width: calc(var(--jeido-avatar-size) - 6px);
    height: calc(var(--jeido-avatar-size) - 6px);
}

/* Depth 2 — align with depth-1 reply's text start (smaller avatar + gap) */
.jeido-children .jeido-children {
    margin-left: calc(var(--jeido-avatar-size) - 6px + 14px);
}

.jeido-children .jeido-children > .jeido-comment {
    background: rgba(127, 127, 127, .07);
}

/* Depth 3+ — align with depth-2 reply's text start (even smaller avatar + gap) */
.jeido-children .jeido-children .jeido-children {
    margin-left: calc(var(--jeido-avatar-size) - 12px + 14px);
}

.jeido-children .jeido-children .jeido-children > .jeido-comment {
    background: rgba(127, 127, 127, .10);
}

/* Even deeper — slightly smaller avatars */
.jeido-children .jeido-children .jeido-comment-avatar img,
.jeido-children .jeido-children .jeido-avatar {
    width: calc(var(--jeido-avatar-size) - 12px);
    height: calc(var(--jeido-avatar-size) - 12px);
}

/* ─── Reply Form (inline) ───────────────────────────────────── */

.jeido-reply-form-placeholder .jeido-form {
    margin-top: 12px;
    padding: 16px;
    border-radius: 10px;
    animation: jeidoFadeIn .2s ease;
}

.jeido-reply-form-placeholder .jeido-textarea {
    min-height: 60px;
}

.jeido-reply-cancel {
    margin-left: 8px;
    padding: 10px 18px;
    border: 1px solid var(--jeido-color-border);
    border-radius: 8px;
    background: transparent;
    color: var(--jeido-color-text-secondary);
    font-size: 14px;
    cursor: pointer;
    transition: all var(--jeido-transition);
}

.jeido-reply-cancel:hover {
    background: var(--jeido-color-bg-alt);
}

/* ─── Edit Mode ─────────────────────────────────────────────── */

.jeido-edit-textarea {
    width: 100%;
    min-height: 80px;
    padding: 10px 12px;
    border: 1px solid var(--jeido-color-primary);
    border-radius: 8px;
    font-size: 14px;
    font-family: inherit;
    line-height: 1.6;
    resize: vertical;
    outline: none;
    background: var(--jeido-color-bg);
    color: var(--jeido-color-text);
}

.jeido-edit-actions {
    display: flex;
    gap: 8px;
    margin-top: 8px;
}

.jeido-edit-save {
    padding: 6px 16px;
    border: none;
    border-radius: 6px;
    background: var(--jeido-color-primary);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
}

.jeido-edit-cancel {
    padding: 6px 16px;
    border: 1px solid var(--jeido-color-border);
    border-radius: 6px;
    background: transparent;
    color: var(--jeido-color-text-secondary);
    font-size: 13px;
    cursor: pointer;
}

/* ─── Load More ─────────────────────────────────────────────── */

.jeido-load-more-wrap {
    text-align: center;
    margin-top: 24px;
}

/* ─── Login CTA (guest fallback) ────────────────────────────── */

.jeido-login-cta {
    text-align: center;
    padding: 28px 20px;
    margin-bottom: 32px;
    background: var(--jeido-color-bg-alt);
    border: 1px dashed var(--jeido-color-border);
    border-radius: var(--jeido-radius);
}

.jeido-login-cta-text {
    font-size: 16px;
    font-weight: 600;
    color: var(--jeido-color-text);
    margin: 0 0 14px;
}

.jeido-login-cta-buttons {
    display: flex;
    gap: 10px;
    justify-content: center;
}

/* ─── View All Comments Button ──────────────────────────────── */

.jeido-view-comments-wrap {
    text-align: center;
    margin: 8px 0 16px;
}

.jeido-view-comments-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 28px;
    border: 1px solid var(--jeido-color-border);
    background: var(--jeido-color-bg);
    color: var(--jeido-color-text);
    font-size: 14px;
    font-weight: 600;
    border-radius: 8px;
    cursor: pointer;
    transition: all var(--jeido-transition);
}

.jeido-view-comments-btn svg {
    flex-shrink: 0;
    color: var(--jeido-color-primary);
}

.jeido-view-comments-btn:hover {
    border-color: var(--jeido-color-primary);
    color: var(--jeido-color-primary);
    box-shadow: 0 2px 8px rgba(37, 99, 235, .1);
}

/* ─── Inline Login Prompt (vote/react/reply gate) ───────────── */

.jeido-login-prompt {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    margin-top: 10px;
    background: var(--jeido-color-bg-alt);
    border: 1px solid var(--jeido-color-border);
    border-radius: 8px;
    font-size: 13px;
    color: var(--jeido-color-text-secondary);
    animation: jeidoFadeIn .2s ease;
}

/* ─── Shared Button Styles ──────────────────────────────────── */

.jeido-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: all var(--jeido-transition);
    border: none;
    line-height: 1;
}

.jeido-btn-sm {
    padding: 5px 14px;
    font-size: 12px;
}

.jeido-btn-primary {
    background: var(--jeido-color-primary);
    color: #fff;
}

.jeido-btn-primary:hover {
    opacity: .9;
}

.jeido-btn-secondary {
    background: transparent;
    color: var(--jeido-color-primary);
    border: 1px solid var(--jeido-color-primary);
}

.jeido-btn-secondary:hover {
    background: var(--jeido-color-primary);
    color: #fff;
}

.jeido-load-more-btn {
    padding: 12px 32px;
    border: 1px solid var(--jeido-color-border);
    background: var(--jeido-color-bg);
    color: var(--jeido-color-text);
    font-size: 14px;
    font-weight: 500;
    border-radius: 8px;
    cursor: pointer;
    transition: all var(--jeido-transition);
}

.jeido-load-more-btn:hover {
    border-color: var(--jeido-color-primary);
    color: var(--jeido-color-primary);
}

.jeido-load-more-btn:disabled {
    opacity: .5;
    cursor: not-allowed;
}

/* ═══ Layout: Card ══════════════════════════════════════════ */

.jeido-layout-card .jeido-comment {
    background: var(--jeido-color-bg);
    border: 1px solid var(--jeido-color-border);
    border-radius: var(--jeido-radius);
    padding: 20px;
    margin-bottom: 12px;
    border-bottom: none;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .04);
}

.jeido-layout-card .jeido-children {
    margin-left: calc(var(--jeido-avatar-size) + 14px);
    padding-left: 0;
}

.jeido-layout-card .jeido-children > .jeido-comment {
    background: rgba(127, 127, 127, .04);
    border: 1px solid var(--jeido-color-border);
    border-radius: var(--jeido-radius);
    padding: 16px;
    margin-bottom: 4px;
    box-shadow: none;
}

/* ═══ Layout: Minimal ═══════════════════════════════════════ */

.jeido-layout-minimal .jeido-comment-avatar {
    display: none;
}

.jeido-layout-minimal .jeido-comment {
    padding: 14px 0;
}

.jeido-layout-minimal .jeido-children {
    margin-left: 28px;
    padding-left: 0;
}

.jeido-layout-minimal .jeido-children .jeido-comment-avatar {
    display: none;
}

/* ═══ Dark Mode ═════════════════════════════════════════════ */

.jeido-comments[style*="color-scheme: dark"],
.jeido-comments.jeido-dark {
    --jeido-color-bg: #1e1e2e;
    --jeido-color-bg-alt: #2a2a3c;
    --jeido-color-text: #e2e8f0;
    --jeido-color-text-secondary: #94a3b8;
    --jeido-color-border: #334155;
}

/* ═══ Responsive ════════════════════════════════════════════ */

@media (max-width: 600px) {
    .jeido-comments {
        font-size: 14px;
        margin: 24px 0;
    }

    .jeido-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .jeido-guest-fields {
        grid-template-columns: 1fr;
    }

    .jeido-comment-inner {
        gap: 10px;
    }

    .jeido-comment-avatar img,
    .jeido-avatar {
        width: 36px;
        height: 36px;
    }

    .jeido-children {
        margin-left: calc(36px + 10px);
        padding-left: 0;
    }

    .jeido-children .jeido-children {
        margin-left: calc(30px + 10px);
        padding-left: 0;
    }

    .jeido-reaction-picker {
        left: -20px;
    }

    .jeido-form {
        padding: 14px;
    }
}

/* ═══ Accessibility ═════════════════════════════════════════ */

.jeido-comments :focus-visible {
    outline: 2px solid var(--jeido-color-primary);
    outline-offset: 2px;
}

/* Screen reader only */
.jeido-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
