/* ─── Base & Reset ─────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#050508;--surface:rgba(255,255,255,.04);--surface-hover:rgba(255,255,255,.08);
  --border:rgba(255,255,255,.08);--border-hover:rgba(255,255,255,.15);
  --text:#e8e8ed;--text-muted:rgba(255,255,255,.6);--text-dim:rgba(255,255,255,.35);
  --accent:#3b82f6;--accent2:#06b6d4;--accent3:#10b981;
  --gradient:linear-gradient(135deg,#3b82f6,#06b6d4,#10b981);
  --gradient-subtle:linear-gradient(135deg,rgba(59,130,246,.15),rgba(6,182,212,.15));
  --radius:16px;--radius-sm:10px;--radius-xs:6px;
  --shadow:0 8px 32px rgba(0,0,0,.5);
  --font:'Inter',system-ui,-apple-system,sans-serif;
}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;line-height:1.6}

/* ─── Background Orbs ─────────────────────────────────── */
.bg-orb{position:fixed;border-radius:50%;filter:blur(120px);opacity:.12;pointer-events:none;z-index:0}
.bg-orb-1{width:600px;height:600px;background:#3b82f6;top:-200px;left:-100px;animation:float 20s ease-in-out infinite}
.bg-orb-2{width:500px;height:500px;background:#06b6d4;bottom:-150px;right:-100px;animation:float 25s ease-in-out infinite reverse}
.bg-orb-3{width:400px;height:400px;background:#10b981;top:40%;left:50%;animation:float 18s ease-in-out infinite 5s}
@keyframes float{0%,100%{transform:translate(0,0)}33%{transform:translate(30px,-40px)}66%{transform:translate(-20px,30px)}}

/* ─── Layout ──────────────────────────────────────────── */
.app-container{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:2rem 1.5rem 3rem}

/* ─── Glass Card ──────────────────────────────────────── */
.glass-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}

/* ─── Header ──────────────────────────────────────────── */
.header{text-align:center;padding:2.5rem 0 1.5rem}
.logo{display:flex;align-items:center;justify-content:center;gap:.75rem}
.logo-icon{width:44px;height:44px;color:var(--accent);filter:drop-shadow(0 0 12px rgba(59,130,246,.4))}
.logo h1{font-size:2.2rem;font-weight:800;letter-spacing:-.02em}
.gradient-text{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.subtitle{color:var(--text-muted);margin-top:.5rem;font-size:.95rem;font-weight:300}

/* ─── Search ──────────────────────────────────────────── */
.search-section{margin:1.5rem 0 2rem}
.search-box{padding:1.5rem}
.input-wrapper{display:flex;align-items:center;gap:.75rem;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .75rem;transition:border-color .3s,box-shadow .3s}
.input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(168,85,247,.15)}
.search-icon{width:22px;height:22px;color:var(--text-muted);flex-shrink:0}
#search-input{flex:1;background:none;border:none;color:var(--text);font-size:1rem;font-family:var(--font);outline:none}
#search-input::placeholder{color:var(--text-dim)}
.btn-primary{display:flex;align-items:center;gap:.5rem;background:var(--gradient);border:none;color:#fff;padding:.65rem 1.4rem;border-radius:var(--radius-xs);font-weight:600;font-size:.9rem;cursor:pointer;font-family:var(--font);transition:transform .2s,box-shadow .2s;white-space:nowrap}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(168,85,247,.35)}
.btn-primary svg{width:18px;height:18px}
.search-hints{display:flex;gap:.5rem;margin-top:.85rem;flex-wrap:wrap}
.hint-chip{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text-dim);background:rgba(255,255,255,.03);padding:.3rem .65rem;border-radius:20px}
.hint-chip svg{opacity:.5}

/* ─── Loading ─────────────────────────────────────────── */
.loading{display:flex;flex-direction:column;align-items:center;gap:1.2rem;padding:2.5rem 0}
.spinner{position:relative;width:50px;height:50px}
.spinner-ring{position:absolute;inset:0;border:3px solid transparent;border-radius:50%}
.spinner-ring:nth-child(1){border-top-color:var(--accent);animation:spin .8s linear infinite}
.spinner-ring:nth-child(2){border-right-color:var(--accent2);animation:spin 1.2s linear infinite reverse}
.spinner-ring:nth-child(3){inset:6px;border-bottom-color:var(--accent3);animation:spin 1.5s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{color:var(--text-muted);font-size:.9rem}

/* ─── Error ───────────────────────────────────────────── */
.error-msg{display:flex;align-items:center;gap:.75rem;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);padding:1rem 1.25rem;color:#fca5a5;margin:1rem 0}
.error-msg svg{width:22px;height:22px;flex-shrink:0;color:#ef4444}

/* ─── Profile Card ────────────────────────────────────── */
.profile-section{margin-bottom:2rem;animation:slideUp .5s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.profile-card{padding:2rem}
.profile-header{display:flex;gap:1.5rem;align-items:flex-start}
.profile-pic-wrapper{position:relative;flex-shrink:0}
.profile-pic{width:90px;height:90px;border-radius:50%;object-fit:cover;display:block}
.profile-pic-ring{position:absolute;inset:-4px;border-radius:50%;background:var(--gradient);z-index:-1;animation:ringPulse 3s ease-in-out infinite}
@keyframes ringPulse{0%,100%{opacity:.7}50%{opacity:1}}
.profile-info{flex:1;min-width:0}
.profile-name-row{display:flex;align-items:center;gap:.5rem}
.profile-name-row h2{font-size:1.4rem;font-weight:700}
.verified-badge{color:#3b82f6;background:rgba(59,130,246,.15);border-radius:50%;padding:2px;display:flex}
.profile-username{color:var(--accent);font-weight:500;margin:.2rem 0 .5rem}
.profile-bio{color:var(--text-muted);font-size:.9rem;line-height:1.5;white-space:pre-line}
.profile-stats{display:flex;gap:2rem;justify-content:center;margin:1.5rem 0;padding:1.25rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stat{text-align:center}
.stat-number{display:block;font-size:1.35rem;font-weight:700}
.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}
.profile-actions{display:flex;gap:.75rem;justify-content:center;margin-top:.5rem;flex-wrap:wrap}
.btn-secondary{display:flex;align-items:center;gap:.5rem;background:var(--surface-hover);border:1px solid var(--border);color:var(--text);padding:.7rem 1.3rem;border-radius:var(--radius-xs);font-weight:500;font-size:.88rem;cursor:pointer;font-family:var(--font);transition:all .2s}
.btn-secondary:hover{border-color:var(--border-hover);background:rgba(255,255,255,.1)}
.btn-secondary svg{width:18px;height:18px}
.btn-gradient{display:flex;align-items:center;gap:.5rem;background:var(--gradient);border:none;color:#fff;padding:.7rem 1.5rem;border-radius:var(--radius-xs);font-weight:600;font-size:.9rem;cursor:pointer;font-family:var(--font);transition:transform .2s,box-shadow .2s}
.btn-gradient:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(168,85,247,.35)}
.btn-gradient svg{width:18px;height:18px}

/* ─── Download Progress ───────────────────────────────── */
.download-progress{margin:1.5rem 0}
.progress-card{padding:1.5rem}
.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}
.progress-header h3{font-size:1rem;font-weight:600}
#progress-percent{color:var(--accent);font-weight:700}
.progress-bar-track{height:6px;background:rgba(255,255,255,.06);border-radius:10px;overflow:hidden}
.progress-bar-fill{height:100%;background:var(--gradient);border-radius:10px;width:0;transition:width .5s ease}
.progress-detail{color:var(--text-muted);font-size:.85rem;margin-top:.75rem}

/* ─── Posts Section ───────────────────────────────────── */
.posts-section{animation:slideUp .5s ease .2s both}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}
.section-title{display:flex;align-items:center;gap:.6rem;font-size:1.25rem;font-weight:700}
.section-title svg{width:22px;height:22px;color:var(--accent)}
.posts-count-badge{background:var(--gradient-subtle);color:var(--accent);padding:.3rem .85rem;border-radius:20px;font-size:.8rem;font-weight:600}

/* ─── Posts Grid ──────────────────────────────────────── */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.post-card{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;background:var(--surface);border:1px solid var(--border);transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:scale(1.03);box-shadow:0 8px 30px rgba(0,0,0,.4);z-index:2}
.post-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post-card:hover img{transform:scale(1.08)}
.post-overlay{position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(0,0,0,.8));opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:.85rem}
.post-card:hover .post-overlay{opacity:1}
.post-overlay-stats{display:flex;gap:1rem;font-size:.85rem;font-weight:600}
.post-overlay-stats span{display:flex;align-items:center;gap:.3rem}
.post-overlay-stats svg{width:16px;height:16px}
.post-type-badge{position:absolute;top:.6rem;right:.6rem;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);padding:.25rem .5rem;border-radius:var(--radius-xs);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.3rem}
.post-type-badge svg{width:14px;height:14px}

/* ─── Load More ───────────────────────────────────────── */
.load-more-wrapper{text-align:center;padding:2rem 0}
.btn-load-more{display:inline-flex;align-items:center;gap:.6rem;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.85rem 2rem;border-radius:var(--radius);font-weight:600;font-size:.95rem;cursor:pointer;font-family:var(--font);transition:all .3s}
.btn-load-more:hover{background:var(--surface-hover);border-color:var(--accent);box-shadow:0 0 0 3px rgba(168,85,247,.1)}
.btn-load-more svg{width:20px;height:20px;transition:transform .3s}
.btn-load-more:hover svg{transform:translateY(3px)}
.posts-loaded-info{color:var(--text-dim);font-size:.8rem;margin-top:.75rem}
.posts-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem 0;color:var(--text-muted);font-size:.9rem}
.mini-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}

/* ─── Modal ───────────────────────────────────────────── */
.modal{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.8);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-content{position:relative;max-width:850px;width:100%;max-height:90vh;overflow-y:auto;padding:0;animation:modalSlide .3s ease}
@keyframes modalSlide{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-close{position:absolute;top:1rem;right:1rem;background:rgba(0,0,0,.5);border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s}
.modal-close:hover{background:rgba(239,68,68,.6)}
.modal-close svg{width:18px;height:18px}
.modal-body{display:flex;flex-direction:column}
.modal-media{position:relative;width:100%;max-height:500px;overflow:hidden;border-radius:var(--radius) var(--radius) 0 0}
.modal-media img,.modal-media video{width:100%;max-height:500px;object-fit:contain;background:#000;display:block}
.modal-info{padding:1.5rem}
.modal-stats{display:flex;gap:1.5rem;margin-bottom:.75rem}
.modal-stat{display:flex;align-items:center;gap:.4rem;font-weight:600;font-size:.95rem}
.modal-stat svg{color:var(--accent2)}
.modal-date{color:var(--text-dim);font-size:.8rem;margin-bottom:.75rem}
.modal-caption{color:var(--text-muted);font-size:.9rem;line-height:1.6;max-height:150px;overflow-y:auto;white-space:pre-line;margin-bottom:1.25rem}
.modal-actions{display:flex;gap:.75rem}
.full-width{width:100%}

/* ─── Carousel ────────────────────────────────────────── */
.modal-carousel{position:relative}
.carousel-container{display:flex;overflow:hidden}
.carousel-container img,.carousel-container video{min-width:100%;max-height:500px;object-fit:contain;background:#000}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.6);border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;z-index:5;transition:background .2s}
.carousel-btn:hover{background:rgba(168,85,247,.7)}
.carousel-prev{left:.75rem}
.carousel-next{right:.75rem}
.carousel-dots{display:flex;justify-content:center;gap:.4rem;padding:.75rem 0;position:absolute;bottom:0;width:100%}
.carousel-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.3);border:none;cursor:pointer;transition:all .2s}
.carousel-dot.active{background:#fff;transform:scale(1.3)}

/* ─── Login Modal ─────────────────────────────────────── */
.login-modal-content{max-width:420px;padding:2.5rem}
.login-form{text-align:center}
.login-icon{color:var(--accent);margin-bottom:1rem}
.login-form h3{font-size:1.3rem;margin-bottom:.3rem}
.login-hint{color:var(--text-muted);font-size:.85rem;margin-bottom:1.5rem}
.form-group{margin-bottom:1rem}
.form-group input{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius-xs);padding:.75rem 1rem;color:var(--text);font-size:.95rem;font-family:var(--font);outline:none;transition:border-color .3s}
.form-group input:focus{border-color:var(--accent)}
.login-error{color:#fca5a5;font-size:.85rem;margin-top:1rem}

/* ─── AI Processor Section ────────────────────────────── */
.ai-processor-section{margin-top:2.5rem;animation:slideUp .5s ease .4s both}
.ai-card{padding:1.5rem}
.ai-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}
.ai-title-group{display:flex;gap:1rem;align-items:center}
.ai-icon-wrapper{width:48px;height:48px;background:var(--gradient-subtle);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--accent2)}
.ai-icon-wrapper svg{width:26px;height:26px}
.ai-card h3{font-size:1.1rem;font-weight:700}
.ai-subtitle{color:var(--text-muted);font-size:.85rem}
.input-label{display:block;margin-bottom:.5rem;font-size:.85rem;color:var(--text-dim);font-weight:500}
.ai-status{display:flex;align-items:center;gap:.75rem;margin-top:1.25rem;padding:1rem;background:rgba(255,255,255,.03);border-radius:var(--radius-xs);color:var(--accent2);font-size:.9rem}
.ai-drop-zone{margin:1rem 0;padding:2rem;border:2px dashed var(--border);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-muted);cursor:pointer;transition:all .3s ease}
.ai-drop-zone:hover,.ai-drop-zone.active{border-color:var(--accent2);background:rgba(6,182,212,.05);color:var(--text)}
.ai-drop-zone svg{width:40px;height:40px;opacity:.5}
.ai-drop-zone.active svg{transform:translateY(-5px);opacity:1;color:var(--accent2)}

/* ─── AI Terminal ────────────────────────────────────── */
.terminal-container{margin-top:1.5rem;background:#000;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);box-shadow:0 10px 30px rgba(0,0,0,.5)}
.terminal-header{background:#1a1a1f;padding:.6rem 1rem;display:flex;align-items:center;border-bottom:1px solid var(--border)}
.terminal-dots{display:flex;gap:6px}
.terminal-dots span{width:10px;height:10px;border-radius:50%}
.terminal-dots span:nth-child(1){background:#ff5f56}
.terminal-dots span:nth-child(2){background:#ffbd2e}
.terminal-dots span:nth-child(3){background:#27c93f}
.terminal-title{flex:1;text-align:center;font-size:.75rem;color:var(--text-dim);font-family:monospace;letter-spacing:1px}
.terminal-body{height:250px;padding:1rem;overflow-y:auto;font-family:'Courier New',Courier,monospace;font-size:.85rem;line-height:1.4;color:#a3e635;display:flex;flex-direction:column;gap:.25rem}
.terminal-body::-webkit-scrollbar{width:6px}
.terminal-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}
.terminal-line.system{color:#38bdf8}
.terminal-line.error{color:#ef4444}
.terminal-line.success{color:#4ade80}
.terminal-line.info{color:#94a3b8}

/* ─── Costs Dashboard ─────────────────────────────────────── */
.costs-table-wrapper::-webkit-scrollbar { width: 6px; }
.costs-table-wrapper::-webkit-scrollbar-track { background: transparent; }
.costs-table-wrapper::-webkit-scrollbar-thumb { background: var(--border); border-radius: 10px; }
.costs-table tr:hover { background: rgba(255,255,255,0.02); }
.costs-table th { font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; border-bottom: 2px solid var(--border); }
.cost-stat-card { transition: transform 0.2s, border-color 0.2s; }
.cost-stat-card:hover { transform: translateY(-2px); border-color: var(--primary) !important; }

/* ─── Footer ──────────────────────────────────────────── */
.footer{text-align:center;padding:3rem 0 1rem;color:var(--text-dim);font-size:.8rem}
.footer a{color:var(--accent);text-decoration:none}
.footer a:hover{text-decoration:underline}
.heart{color:var(--accent2);animation:heartbeat 1.5s infinite}
@keyframes heartbeat{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.footer-disclaimer{margin-top:.4rem;font-size:.72rem;opacity:.5}

/* ─── Utility ─────────────────────────────────────────── */
.hidden{display:none!important}

/* ─── Responsive ──────────────────────────────────────── */
@media(max-width:768px){
  .posts-grid{grid-template-columns:repeat(2,1fr)}
  .profile-header{flex-direction:column;align-items:center;text-align:center}
  .profile-pic{width:72px;height:72px}
  .profile-stats{gap:1.5rem}
  .modal-content{max-width:100%;margin:1rem}
  .btn-primary span{display:none}
}
@media(max-width:480px){
  .app-container{padding:1rem .75rem 2rem}
  .posts-grid{gap:.5rem}
  .profile-actions{flex-direction:column}
  .profile-actions button{width:100%;justify-content:center}
}

/* ─── AI Folder Detection ────────────────────────────── */
.detected-folders {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
    min-height: 32px;
}
.folder-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--border);
    padding: 0.35rem 0.75rem;
    border-radius: 20px;
    font-size: 0.8rem;
    cursor: pointer;
    transition: all 0.2s;
    color: var(--text-muted);
}
.folder-chip:hover {
    background: var(--gradient-subtle);
    border-color: var(--accent2);
    color: var(--text);
    transform: translateY(-1px);
}
.folder-chip svg {
    color: var(--accent2);
    opacity: 0.8;
}
.btn-refresh {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 4px;
    border-radius: 4px;
    transition: all 0.2s;
    display: flex;
    align-items: center;
}
.btn-refresh:hover {
    color: var(--accent2);
    background: rgba(255,255,255,0.05);
}
.loading-mini {
    font-size: 0.75rem;
    color: var(--text-dim);
    font-style: italic;
}

/* ─── TAKEOFF Agent Chat ──────────────────────────────── */
.chat-section{padding:0;overflow:hidden}
.chat-header{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;border-bottom:1px solid var(--border);background:rgba(59,130,246,.05)}
.chat-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#06b6d4);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}
.chat-status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#10b981;margin-right:5px;box-shadow:0 0 6px #10b981;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.5}}
.chat-clear-btn{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--text-muted);padding:.4rem .85rem;border-radius:var(--radius-xs);font-size:.78rem;cursor:pointer;font-family:var(--font);transition:all .2s}
.chat-clear-btn:hover{background:rgba(255,255,255,.1);border-color:var(--border-hover)}

.chat-messages{min-height:320px;max-height:480px;overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.85rem;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
.chat-messages::-webkit-scrollbar{width:4px}
.chat-messages::-webkit-scrollbar-track{background:transparent}
.chat-messages::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}

.chat-msg{display:flex;max-width:80%}
.chat-msg.user{align-self:flex-end;flex-direction:row-reverse}
.chat-msg.bot{align-self:flex-start}

.chat-bubble{padding:.75rem 1.1rem;border-radius:18px;font-size:.9rem;line-height:1.55;word-break:break-word}
.chat-msg.bot .chat-bubble{background:rgba(255,255,255,.06);border:1px solid var(--border);border-bottom-left-radius:4px;color:var(--text)}
.chat-msg.user .chat-bubble{background:linear-gradient(135deg,#3b82f6,#06b6d4);color:#fff;border-bottom-right-radius:4px;box-shadow:0 4px 15px rgba(59,130,246,.3)}
.chat-bubble-error{background:rgba(239,68,68,.12) !important;border-color:rgba(239,68,68,.3) !important;color:#fca5a5 !important}

.chat-typing{display:flex;align-items:center;gap:5px;padding:.7rem 1rem}
.chat-typing span{width:7px;height:7px;border-radius:50%;background:var(--text-dim);display:inline-block;animation:typing-bounce .9s infinite}
.chat-typing span:nth-child(2){animation-delay:.15s}
.chat-typing span:nth-child(3){animation-delay:.3s}
@keyframes typing-bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}

.chat-input-area{padding:1rem 1.5rem 1.2rem;border-top:1px solid var(--border);background:rgba(0,0,0,.15)}
.chat-input-wrapper{display:flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.45rem .45rem .45rem .9rem;transition:border-color .2s,box-shadow .2s}
.chat-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.15)}
.chat-input{flex:1;background:none;border:none;color:var(--text);font-size:.92rem;font-family:var(--font);outline:none}
.chat-input::placeholder{color:var(--text-dim)}
.chat-send-btn{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#06b6d4);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,opacity .15s;flex-shrink:0}
.chat-send-btn:hover:not(:disabled){transform:scale(1.05)}
.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}
.chat-hint{font-size:.72rem;color:var(--text-dim);margin-top:.55rem;text-align:center}

/* ─── Download Options Panel ──────────────────────────── */
.download-options-panel{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;margin-bottom:14px;display:flex;flex-direction:column;gap:14px}
.options-group{display:flex;flex-direction:column;gap:8px}
.options-label{font-size:11px;font-weight:600;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.6px}
.options-checkboxes,.options-radios{display:flex;flex-wrap:wrap;gap:10px}
.opt-check,.opt-radio{display:flex;align-items:center;gap:6px;font-size:13px;color:rgba(255,255,255,.85);cursor:pointer;user-select:none}
.opt-check input,.opt-radio input{accent-color:#a855f7;width:15px;height:15px;cursor:pointer}

/* ─── Followers Intelligence Panel ────────────────────── */
.followers-panel{background:rgba(168,85,247,.06);border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:16px;margin-top:10px;display:flex;flex-direction:column;gap:10px}
.followers-panel-header{display:flex;align-items:center;gap:8px}
.followers-panel-header h4{margin:0;font-size:14px;font-weight:600;color:var(--text)}
.badge-beta{font-size:10px;font-weight:700;padding:2px 7px;background:rgba(168,85,247,.25);color:#c084fc;border-radius:4px;letter-spacing:.5px}
.followers-hint{font-size:12px;color:var(--text-dim);margin:0;line-height:1.5}
.followers-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.select-limit{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);color:var(--text);border-radius:8px;padding:8px 12px;font-size:13px;font-family:var(--font);cursor:pointer}
.followers-status{display:flex;align-items:center;gap:12px;font-size:13px;color:rgba(255,255,255,.7);flex-wrap:wrap}
.btn-excel{padding:6px 14px;background:#16a34a;color:#fff;border-radius:8px;font-size:13px;font-weight:600;text-decoration:none;border:none;cursor:pointer}
.btn-excel:hover{background:#15803d}
.followers-warning{font-size:12px;padding:8px 12px;border-radius:8px;line-height:1.5}
.followers-warning.warn-low{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);color:#6ee7b7}
.followers-warning.warn-mid{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25);color:#fcd34d}
.followers-warning.warn-high{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);color:#fca5a5}
.followers-terminal{margin-top:12px;background:#0d1117;border:1px solid rgba(168,85,247,.2);border-radius:8px;overflow:hidden}
.followers-terminal-header{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;background:rgba(168,85,247,.1);font-size:11px;font-weight:600;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.5px}
.followers-terminal-body{height:180px;overflow-y:auto;padding:10px 12px;font-family:'Courier New',monospace;font-size:12px;line-height:1.6;color:#c9d1d9}
.followers-terminal-body .tl-error{color:#f97583}
.followers-terminal-body .tl-success{color:#85e89d}
.followers-terminal-body .tl-warn{color:#ffab70}
.terminal-clear-btn{background:none;border:none;color:rgba(255,255,255,.3);cursor:pointer;font-size:10px;padding:2px 6px}
.terminal-clear-btn:hover{color:rgba(255,255,255,.7)}
