/* ═══════════════════════════════════════════════════════════
   AGRINOVEL GATEWAY v2 — Terminal UI
   Modes: Search · Chat · Generate
   Aesthetic: CRT phosphor green · black void · amber accents
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;700&display=swap');

/* ── Variables ─────────────────────────────────────────────── */
:root {
    --g:       #00ff41;
    --g2:      #00cc34;
    --g3:      #006618;
    --g4:      #0f2a0f;
    --g-glow:  rgba(0,255,65,.14);
    --amber:   #ffb800;
    --amber2:  rgba(255,184,0,.15);
    --blue:    #00d4ff;
    --red:     #ff4040;
    --white:   #e8ffe4;
    --dim:     #2a4a2a;
    --bg:      #020b02;
    --bg2:     #040d04;
    --border:  #0a220a;
    --font:    'JetBrains Mono', 'Courier New', monospace;
    --scan:    repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.12) 2px,rgba(0,0,0,.12) 4px);
    --r:       3px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:var(--font)}

/* ── Body ──────────────────────────────────────────────────── */
.agn-body {
    background: var(--bg);
    background-image: var(--scan);
    color: var(--g);
    font-family: var(--font);
    font-size: 13px;
    line-height: 1.65;
    min-height: 100vh;
    overflow-x: hidden;
    text-shadow: 0 0 7px rgba(0,255,65,.25);
}

/* CRT vignette */
.agn-body::before {
    content:'';
    position:fixed;inset:0;
    background:radial-gradient(ellipse 120% 120% at 50% 50%,transparent 55%,rgba(0,0,0,.75) 100%);
    pointer-events:none;z-index:9999;
}

/* ── Outer container ───────────────────────────────────────── */
#agn-gateway {
    max-width:1120px;
    margin:0 auto;
    padding:0 24px 100px;
}

/* ── Topbar ────────────────────────────────────────────────── */
.agn-topbar {
    display:flex;justify-content:space-between;align-items:center;
    padding:14px 0;
    border-bottom:1px solid var(--border);
}
.agn-logo {
    font-size:11px;font-weight:700;letter-spacing:.15em;
    color:var(--g);text-transform:uppercase;
}
.agn-logo-bk{color:var(--g3);font-weight:300}
.agn-topbar-right{display:flex;gap:8px;align-items:center}
.agn-pill {
    font-size:9px;letter-spacing:.1em;padding:3px 9px;
    border:1px solid var(--g3);color:var(--g3);border-radius:2px;
    text-transform:uppercase;
}
.agn-pill-dim{color:var(--dim);border-color:var(--dim)}
.agn-pill-link{color:var(--g2);border-color:var(--g2);transition:all .2s}
.agn-pill-link:hover{background:var(--g2);color:var(--bg)}
#agn-mode-pill{
    color:var(--amber);border-color:var(--amber);
    animation:pulse-pill 2s ease-in-out infinite;
}
@keyframes pulse-pill{0%,100%{opacity:1}50%{opacity:.5}}

/* ── ASCII Banner ──────────────────────────────────────────── */
.agn-banner{padding:20px 0 12px;overflow-x:auto}
.agn-ascii {
    font-size:8.5px;line-height:1.25;color:var(--g3);
    white-space:pre;text-shadow:0 0 10px rgba(0,255,65,.35);
}
@media(max-width:640px){.agn-banner{display:none}}

/* ── Search box ────────────────────────────────────────────── */
.agn-searchbox {
    display:flex;align-items:center;gap:10px;
    padding:14px 0 10px;
    border-bottom:1px solid var(--g2);
    margin-bottom:16px;
}
.agn-prompt{color:var(--g);font-size:18px;flex-shrink:0;text-shadow:0 0 12px var(--g)}
.agn-input {
    flex:1;background:transparent;border:none;outline:none;
    font-family:var(--font);font-size:17px;
    color:var(--white);caret-color:var(--g);
    text-shadow:0 0 6px rgba(255,255,255,.2);
}
.agn-input::placeholder{color:var(--dim);font-size:13px}
.agn-cursor-blink{color:var(--g);font-size:20px;animation:blink 1.1s step-end infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.agn-send-btn {
    background:transparent;border:1px solid var(--g3);
    color:var(--g2);font-size:16px;padding:4px 10px;
    border-radius:var(--r);transition:all .2s;flex-shrink:0;
}
.agn-send-btn:hover{background:var(--g);color:var(--bg);box-shadow:0 0 10px var(--g)}

/* ── Mode tabs ─────────────────────────────────────────────── */
.agn-mode-tabs {
    display:flex;gap:6px;flex-wrap:wrap;
    padding:12px 0;border-bottom:1px solid var(--border);
    margin-bottom:20px;
}
.agn-tab {
    background:transparent;border:1px solid var(--dim);color:var(--dim);
    font-size:10px;letter-spacing:.1em;padding:4px 12px;
    border-radius:var(--r);transition:all .2s;
}
.agn-tab:hover,.agn-tab--active {
    border-color:var(--g);color:var(--g);
    box-shadow:0 0 8px var(--g-glow);
}
.agn-tab--active{background:rgba(0,255,65,.06)}
.agn-tab--clear{border-color:var(--red);color:var(--red);margin-left:auto}
.agn-tab--clear:hover{background:var(--red);color:#fff}

/* ── Terminal stream ───────────────────────────────────────── */
.agn-stream{
    font-size:12px;line-height:1.75;
    margin-bottom:24px;min-height:10px;
}
.agn-line{display:block;color:var(--g);white-space:pre-wrap;word-break:break-word}
.agn-line-dim   {color:var(--dim)}
.agn-line-amber {color:var(--amber);text-shadow:0 0 8px rgba(255,184,0,.3)}
.agn-line-white {color:var(--white);font-weight:500}
.agn-line-head  {color:var(--g);font-weight:700;margin-top:10px;text-shadow:0 0 10px rgba(0,255,65,.5)}
.agn-line-count {
    color:var(--amber);font-size:13px;font-weight:700;
    margin:8px 0;padding:8px 0;
    border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.agn-line-err   {color:var(--red)}

/* progress bar */
.agn-progress-row{display:flex;align-items:center;gap:10px;margin:2px 0;font-size:11px;color:var(--dim)}
.agn-bar-wrap{width:140px;height:7px;background:var(--border);border-radius:1px;overflow:hidden}
.agn-bar-fill{height:100%;width:0;background:var(--g);box-shadow:0 0 6px var(--g);transition:width .5s ease}
.agn-bar-pct{width:34px;color:var(--g3)}

/* ── Chat panel ─────────────────────────────────────────────── */
.agn-chat-panel{
    border:1px solid var(--border);border-radius:var(--r);
    margin-bottom:24px;background:var(--bg2);overflow:hidden;
}
.agn-chat-messages{
    padding:20px;min-height:120px;max-height:420px;overflow-y:auto;
    display:flex;flex-direction:column;gap:14px;
}
.agn-msg{max-width:82%;padding:12px 16px;border-radius:var(--r);font-size:12.5px;line-height:1.7}
.agn-msg-user{
    align-self:flex-end;
    background:rgba(0,255,65,.07);border:1px solid var(--g3);color:var(--white);
}
.agn-msg-bot{
    align-self:flex-start;
    background:var(--bg);border:1px solid var(--border);color:var(--g);
}
.agn-msg-bot .agn-msg-label{
    font-size:9px;letter-spacing:.12em;color:var(--g3);margin-bottom:6px;
}
.agn-msg-user .agn-msg-label{
    font-size:9px;letter-spacing:.12em;color:var(--g2);margin-bottom:6px;text-align:right;
}
.agn-chat-input-row{
    display:flex;align-items:center;gap:8px;
    padding:12px 16px;border-top:1px solid var(--border);
}
.agn-chat-input{
    flex:1;background:transparent;border:none;outline:none;
    font-family:var(--font);font-size:13px;color:var(--white);caret-color:var(--g);
}
.agn-chat-input::placeholder{color:var(--dim)}
.agn-chat-send-btn{
    background:transparent;border:1px solid var(--g3);color:var(--g2);
    font-size:10px;letter-spacing:.1em;padding:5px 14px;border-radius:var(--r);
    transition:all .2s;
}
.agn-chat-send-btn:hover{background:var(--g);color:var(--bg);box-shadow:0 0 10px var(--g)}
/* Suggest generate button inside chat */
.agn-suggest-gen-btn{
    display:inline-block;margin-top:10px;
    background:rgba(255,184,0,.1);border:1px solid var(--amber);
    color:var(--amber);font-size:10px;letter-spacing:.08em;
    padding:5px 14px;border-radius:var(--r);cursor:pointer;
    transition:all .2s;
}
.agn-suggest-gen-btn:hover{background:var(--amber);color:#000}

/* ── Results grid ───────────────────────────────────────────── */
.agn-results{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(310px,1fr));
    gap:14px;margin-bottom:28px;
}
.agn-card{
    background:var(--bg2);border:1px solid var(--border);
    padding:18px 20px;position:relative;
    display:block;text-decoration:none;
    opacity:0;transform:translateY(7px);
    transition:opacity .3s ease,transform .3s ease,border-color .2s,box-shadow .2s;
    overflow:hidden;
}
.agn-card.in{opacity:1;transform:translateY(0)}
.agn-card:hover{border-color:var(--g);box-shadow:0 0 18px var(--g-glow)}
.agn-card::before{
    content:'';position:absolute;top:0;left:0;width:3px;height:100%;
    background:var(--g);opacity:0;transition:opacity .2s;
}
.agn-card:hover::before{opacity:1}
.agn-card-idx{font-size:9px;color:var(--g3);letter-spacing:.1em;margin-bottom:5px}
.agn-card-title{font-size:13px;font-weight:700;color:var(--white);line-height:1.4;margin-bottom:7px}
.agn-card-excerpt{font-size:11px;color:var(--dim);line-height:1.6;margin-bottom:10px}
.agn-card-meta{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:9px}
.agn-chip{
    font-size:9px;letter-spacing:.07em;padding:2px 7px;
    border-radius:1px;border:1px solid;text-transform:uppercase;
}
.agn-chip-rel{color:var(--g);border-color:var(--g);background:rgba(0,255,65,.05)}
.agn-chip-read{color:var(--amber);border-color:rgba(255,184,0,.4)}
.agn-chip-cat{color:var(--blue);border-color:rgba(0,212,255,.3)}
.agn-chip-tag{color:var(--dim);border-color:var(--border)}
.agn-card-url{font-size:10px;color:var(--g3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}
.agn-rel-bar{height:2px;background:var(--border);margin-top:10px;border-radius:1px;overflow:hidden}
.agn-rel-fill{height:100%;background:linear-gradient(90deg,var(--g3),var(--g));box-shadow:0 0 4px var(--g)}

/* ── Generate panel ─────────────────────────────────────────── */
.agn-gen-panel{
    border:1px solid var(--border);border-radius:var(--r);
    padding:28px;margin-bottom:28px;background:var(--bg2);
}
.agn-gen-panel h2{font-size:13px;color:var(--amber);letter-spacing:.08em;margin-bottom:16px;font-weight:700}
.agn-gen-article{color:var(--white);font-size:13px;line-height:1.8}
.agn-gen-article h1{font-size:20px;color:var(--white);margin-bottom:16px;font-weight:700;line-height:1.3}
.agn-gen-article h2{font-size:14px;color:var(--amber);margin:20px 0 8px;font-weight:700;letter-spacing:.05em}
.agn-gen-article h3{font-size:13px;color:var(--g);margin:14px 0 6px;font-weight:600}
.agn-gen-article p{color:var(--dim);margin-bottom:12px;line-height:1.8}

/* AI notice inside generated article */
.agn-ai-badge{
    display:inline-flex;align-items:center;gap:8px;
    padding:6px 14px;
    background:rgba(255,184,0,.07);border:1px solid rgba(255,184,0,.3);
    border-radius:var(--r);font-size:10px;color:var(--amber);
    letter-spacing:.06em;margin-bottom:20px;
}

/* Tags row inside gen panel */
.agn-gen-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}

/* Action buttons in gen panel */
.agn-gen-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}
.agn-action-btn{
    font-size:10px;letter-spacing:.1em;padding:7px 18px;
    border-radius:var(--r);cursor:pointer;transition:all .2s;
    text-transform:uppercase;border:1px solid;
}
.agn-action-btn--primary{background:var(--g);color:var(--bg);border-color:var(--g);font-weight:700}
.agn-action-btn--primary:hover{box-shadow:0 0 16px var(--g);transform:translateY(-1px)}
.agn-action-btn--secondary{background:transparent;color:var(--amber);border-color:var(--amber)}
.agn-action-btn--secondary:hover{background:var(--amber);color:#000}
.agn-action-btn--ghost{background:transparent;color:var(--dim);border-color:var(--dim)}
.agn-action-btn--ghost:hover{color:var(--g);border-color:var(--g)}
.agn-action-btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}

/* Image prompt copybox */
.agn-image-prompt-box{
    margin-top:16px;padding:12px 14px;
    background:rgba(0,255,65,.03);border:1px dashed var(--g3);
    border-radius:var(--r);font-size:11px;color:var(--dim);
}
.agn-image-prompt-box strong{color:var(--g2);display:block;margin-bottom:4px}

/* ── No results / zero state ────────────────────────────────── */
.agn-no-results{
    grid-column:1/-1;text-align:center;padding:40px 20px;
    color:var(--dim);font-size:13px;
}
.agn-no-results a{color:var(--g)}

/* ── Pagination ─────────────────────────────────────────────── */
.agn-pagination{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;padding:16px 0;border-top:1px solid var(--border)}
.agn-page-btn{
    background:transparent;border:1px solid var(--g3);color:var(--g3);
    font-family:var(--font);font-size:11px;padding:5px 13px;
    cursor:pointer;letter-spacing:.05em;transition:all .2s;border-radius:var(--r);
}
.agn-page-btn:hover,.agn-page-btn.on{background:var(--g);color:var(--bg);border-color:var(--g);box-shadow:0 0 10px var(--g)}

/* ── Footer ─────────────────────────────────────────────────── */
.agn-footer{
    text-align:center;padding:28px 0 14px;border-top:1px solid var(--border);
    color:var(--dim);font-size:10px;letter-spacing:.07em;
    display:flex;gap:10px;justify-content:center;align-items:center;flex-wrap:wrap;
}
.agn-footer a{color:var(--g2);transition:color .2s}
.agn-footer a:hover{color:var(--g)}

/* ── Scrollbars ─────────────────────────────────────────────── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#000}
::-webkit-scrollbar-thumb{background:var(--g3);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--g)}
::selection{background:var(--g);color:var(--bg)}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:640px){
    #agn-gateway{padding:0 14px 60px}
    .agn-input{font-size:15px}
    .agn-results{grid-template-columns:1fr}
    .agn-mode-tabs{gap:5px}
    .agn-tab{font-size:9px;padding:4px 8px}
}

/* ── Typing cursor for chat ─────────────────────────────────── */
.agn-typing-dot::after{
    content:'▋';animation:blink 0.9s step-end infinite;
    color:var(--g);margin-left:3px;
}

/* ── Saved article success banner ──────────────────────────── */
.agn-save-success{
    padding:12px 16px;background:rgba(0,255,65,.07);
    border:1px solid var(--g);border-radius:var(--r);
    font-size:12px;color:var(--g);margin-top:14px;
}
.agn-save-success a{color:var(--amber);text-decoration:underline}
