/* ─── GNS Widget v3 ─────────────────────────────────────────────────────── */
.gns-widget {
    --gns-c: #b91c1c;
    --gns-r: 12px;
    --gns-border: #e5e5e3;
    --gns-bg: #ffffff;
    --gns-bg2: #f8f7f5;
    --gns-text: #1a1a1a;
    --gns-muted: #6b7280;
    --gns-skel: #ebebeb;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background: var(--gns-bg);
    border: 1px solid var(--gns-border);
    border-top: 3px solid var(--gns-c);
    border-radius: var(--gns-r);
    margin: 0 0 28px;
    overflow: hidden;
    box-sizing: border-box;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

/* ── Header ─────────────────────────────────────────────────────────────── */
.gns-hd {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 13px 16px 11px;
    border-bottom: 1px solid var(--gns-border);
    background: var(--gns-bg);
    gap: 8px;
}
.gns-hd-left { display: flex; align-items: center; gap: 8px; min-width: 0; }
.gns-hd-right { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }

.gns-icon {
    width: 18px;
    height: 18px;
    color: var(--gns-c);
    flex-shrink: 0;
}
.gns-title {
    font-size: 13.5px;
    font-weight: 700;
    color: var(--gns-text);
    letter-spacing: -.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.gns-ai-badge {
    font-size: 10px;
    font-weight: 800;
    color: var(--gns-c);
    background: color-mix(in srgb, var(--gns-c) 10%, transparent);
    border: 1px solid color-mix(in srgb, var(--gns-c) 25%, transparent);
    border-radius: 4px;
    padding: 2px 6px;
    letter-spacing: .06em;
}
.gns-refresh-btn {
    width: 28px;
    height: 28px;
    border: 1px solid var(--gns-border);
    border-radius: 6px;
    background: transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gns-muted);
    transition: color .15s, border-color .15s, background .15s;
    padding: 0;
}
.gns-refresh-btn svg { width: 14px; height: 14px; }
.gns-refresh-btn:hover { color: var(--gns-c); border-color: var(--gns-c); background: color-mix(in srgb, var(--gns-c) 6%, transparent); }
.gns-refresh-btn.spinning svg { animation: gns-spin .7s linear infinite; }

/* ── Tabs ───────────────────────────────────────────────────────────────── */
.gns-tabs {
    display: flex;
    gap: 0;
    padding: 10px 16px 0;
    border-bottom: 1px solid var(--gns-border);
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}
.gns-tabs::-webkit-scrollbar { display: none; }
.gns-tab {
    font-family: inherit;
    font-size: 12px;
    font-weight: 500;
    color: var(--gns-muted);
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    padding: 6px 12px 8px;
    cursor: pointer;
    white-space: nowrap;
    transition: color .15s, border-color .15s;
    margin-bottom: -1px;
}
.gns-tab:hover { color: var(--gns-c); }
.gns-tab.active { color: var(--gns-c); border-bottom-color: var(--gns-c); font-weight: 600; }

/* ── Body ───────────────────────────────────────────────────────────────── */
.gns-body { padding: 16px 18px 10px; min-height: 120px; }

/* ── Skeleton loader ────────────────────────────────────────────────────── */
.gns-skeleton { padding: 4px 0; }
.gns-skel-line {
    height: 13px;
    background: linear-gradient(90deg, var(--gns-skel) 25%, #f5f5f3 50%, var(--gns-skel) 75%);
    background-size: 200% 100%;
    border-radius: 6px;
    margin-bottom: 10px;
    animation: gns-shimmer 1.4s ease-in-out infinite;
}
.gns-skel-line.w80 { width: 80%; }
.gns-skel-line.w60 { width: 60%; }
.gns-skel-line.w90 { width: 90%; }
.gns-skel-line.w70 { width: 70%; }
.gns-skel-line.w85 { width: 85%; }
@keyframes gns-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
@keyframes gns-spin { to { transform:rotate(360deg); } }

/* ── Signal badge ───────────────────────────────────────────────────────── */
.gns-signal {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    border-radius: 8px;
    border: 1px solid;
    padding: 9px 12px;
    margin-bottom: 13px;
    flex-wrap: wrap;
}
.gns-signal-dot {
    font-size: 13px;
    font-weight: 900;
    flex-shrink: 0;
    line-height: 1.4;
}
.gns-signal strong {
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
    line-height: 1.4;
}
.gns-signal-reason {
    font-size: 12px;
    line-height: 1.4;
    opacity: .85;
}

/* ── Insight headline ───────────────────────────────────────────────────── */
.gns-headline {
    font-size: 15px;
    font-weight: 700;
    color: var(--gns-text);
    line-height: 1.4;
    margin: 0 0 13px;
    padding-left: 11px;
    border-left: 3px solid var(--gns-c);
}

/* ── Bullet takeaways ───────────────────────────────────────────────────── */
.gns-bullets {
    margin: 0 0 8px;
    padding: 0;
    list-style: none;
}
.gns-bullets li {
    font-size: 13.5px;
    line-height: 1.65;
    color: var(--gns-text);
    padding: 8px 0 8px 18px;
    border-bottom: 1px solid #f0f0ee;
    position: relative;
}
.gns-bullets li:last-child { border-bottom: none; padding-bottom: 2px; }
.gns-bullets li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 16px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--gns-c);
    opacity: .75;
}

/* ── Brief paragraph ────────────────────────────────────────────────────── */
.gns-brief {
    font-size: 14px;
    line-height: 1.8;
    color: var(--gns-text);
    margin: 0 0 8px;
}

/* ── Row layout (eli5 + professional) ──────────────────────────────────── */
.gns-row {
    display: grid;
    grid-template-columns: 148px 1fr;
    gap: 4px 14px;
    padding: 8px 0;
    border-bottom: 1px solid #f0f0ee;
    align-items: baseline;
}
.gns-row:last-of-type { border-bottom: none; }
.gns-row-lbl {
    font-size: 11px;
    font-weight: 700;
    color: var(--gns-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    padding-top: 2px;
    line-height: 1.5;
}
.gns-row-val {
    font-size: 13.5px;
    line-height: 1.65;
    color: var(--gns-text);
}

/* ── Bottom line ────────────────────────────────────────────────────────── */
.gns-bottom-line {
    font-size: 13.5px;
    line-height: 1.65;
    color: var(--gns-text);
    background: var(--gns-bg2);
    border-radius: 7px;
    padding: 10px 13px;
    margin-top: 10px;
    border-left: 3px solid var(--gns-c);
}
.gns-bottom-line strong { color: var(--gns-c); font-weight: 700; margin-right: 5px; }

/* ── Risk badge ─────────────────────────────────────────────────────────── */
.gns-risk-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    border-radius: 20px;
    padding: 3px 12px;
    margin-top: 12px;
    letter-spacing: .02em;
}

/* ── Affected segments ──────────────────────────────────────────────────── */
.gns-segs {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 5px;
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid #f0f0ee;
}
.gns-segs-lbl {
    font-size: 11px;
    font-weight: 700;
    color: var(--gns-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-right: 2px;
}
.gns-seg {
    font-size: 11.5px;
    font-weight: 500;
    background: var(--gns-bg2);
    color: var(--gns-muted);
    border: 1px solid var(--gns-border);
    border-radius: 5px;
    padding: 3px 9px;
}

/* ── Keywords ───────────────────────────────────────────────────────────── */
.gns-kws {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #f0f0ee;
}
.gns-kw {
    font-size: 11px;
    font-weight: 500;
    color: var(--gns-c);
    background: color-mix(in srgb, var(--gns-c) 8%, transparent);
    border: 1px solid color-mix(in srgb, var(--gns-c) 20%, transparent);
    border-radius: 5px;
    padding: 2px 9px;
}

/* ── Error ──────────────────────────────────────────────────────────────── */
.gns-error-msg {
    font-size: 13px;
    color: #991b1b;
    background: #fee2e2;
    border: 1px solid #fca5a5;
    border-radius: 7px;
    padding: 9px 13px;
    display: none;
}
.gns-error-msg:not(:empty) { display: block; }

/* ── Footer ─────────────────────────────────────────────────────────────── */
.gns-ft {
    padding: 8px 18px 12px;
    border-top: 1px solid #f5f5f3;
}
.gns-ft-note {
    font-size: 11px;
    color: #b0b0ad;
    line-height: 1.4;
}

/* ── Manual widget extras ───────────────────────────────────────────────── */
.gns-input-label {
    display: block;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--gns-muted);
    margin-bottom: 6px;
    margin-top: 14px;
}
.gns-textarea {
    display: block;
    width: 100%;
    box-sizing: border-box;
    border: 1px solid var(--gns-border);
    border-radius: 8px;
    padding: 10px 12px;
    font-size: 13.5px;
    font-family: inherit;
    color: var(--gns-text);
    background: var(--gns-bg2);
    resize: vertical;
    outline: none;
    transition: border-color .2s, background .2s;
    margin-bottom: 12px;
}
.gns-textarea:focus { border-color: var(--gns-c); background: #fff; }
.gns-submit-btn {
    font-family: inherit;
    font-size: 13.5px;
    font-weight: 600;
    background: var(--gns-c);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 10px 22px;
    cursor: pointer;
    transition: opacity .15s;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-bottom: 14px;
}
.gns-submit-btn:disabled { opacity: .45; cursor: not-allowed; }
.gns-submit-btn:hover:not(:disabled) { opacity: .84; }
.gns-spinner {
    width: 13px;
    height: 13px;
    border: 2px solid rgba(255,255,255,.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: gns-spin .65s linear infinite;
    flex-shrink: 0;
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
    .gns-hd  { padding: 11px 14px 10px; }
    .gns-body { padding: 14px 14px 8px; }
    .gns-ft  { padding: 7px 14px 11px; }
    .gns-tabs { padding: 8px 14px 0; }
    .gns-tab  { font-size: 11.5px; padding: 5px 10px 7px; }
    .gns-row  { grid-template-columns: 1fr; gap: 2px; }
    .gns-row-lbl { font-size: 10.5px; }
    .gns-headline { font-size: 14px; }
    .gns-bullets li { font-size: 13px; }
    .gns-row-val { font-size: 13px; }
    .gns-title { font-size: 13px; }
}
@media (max-width: 380px) {
    .gns-tab { padding: 5px 8px 7px; font-size: 11px; }
}

/* ── Notice boxes (quota / error inside widget) ─────────────────────── */
.gns-notice {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    font-size: 13px;
    line-height: 1.6;
    border-radius: 8px;
    padding: 10px 13px;
    margin: 4px 0;
}
.gns-notice svg { flex-shrink: 0; margin-top: 1px; }
.gns-notice-warn {
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
}
.gns-notice-warn svg { color: #d97706; }
.gns-notice-err {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}
.gns-notice-err svg { color: #dc2626; }
