/* ══════════════════════════════════════════════════════════════════════════
   service-logs.css  —  Service Logs page specific styles
   .card/.btn override shared.css. Sidebar-toggle/page-body/page-sidebar/mob-overlay.
   Defines --fail/--info/--warn/--success locally.
   ══════════════════════════════════════════════════════════════════════════ */

.wrap{width:100%;max-width:var(--page-max);margin:0 auto;position:relative;z-index:400;}
@keyframes vcrise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* Config notice */
.config-notice{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,0.75);backdrop-filter:blur(8px);align-items:center;justify-content:center;}
.config-notice.show{display:flex;}
.config-notice .notice-box{background:linear-gradient(145deg,#0e0e1c,#12121e);border:1px solid rgba(255,195,55,0.25);border-radius:var(--radius);padding:1.75rem 2rem;max-width:420px;width:90%;box-shadow:0 0 0 1px rgba(255,195,55,0.08),0 24px 64px rgba(0,0,0,0.6);text-align:center;}
.config-notice .notice-icon{font-size:2rem;margin-bottom:0.65rem;}
.config-notice .notice-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:0.35rem;}
.config-notice .notice-body{font-size:0.82rem;color:var(--text-dim);line-height:1.55;}

/* Page-specific: card */
.card{background:var(--card-bg);border:1px solid var(--glass-border);border-radius:24px;padding:1.5rem 1.75rem;box-shadow:0 8px 32px rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.1),inset 0 -1px 0 rgba(0,0,0,0.1);backdrop-filter:blur(40px) saturate(150%);-webkit-backdrop-filter:blur(40px) saturate(150%);position:relative;overflow:hidden;margin-bottom:1.25rem;}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3),transparent);}
.card::after{content:'';position:absolute;inset:0;background:var(--glass-shine);pointer-events:none;border-radius:24px;}

/* Layout */
.viewer-layout{display:grid;grid-template-columns:240px 1fr;gap:1rem;align-items:flex-start;}
.sidebar{position:relative;z-index:1;}
.sidebar-label{font-size:0.65rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin:0 0 0.65rem 0.1rem;}
.service-list{display:flex;flex-direction:column;gap:0.35rem;}
.service-btn{display:flex;align-items:center;gap:0.65rem;padding:0.65rem 0.85rem;border-radius:11px;border:1px solid rgba(88,101,242,0.15);background:rgba(88,101,242,0.06);cursor:pointer;transition:all 0.18s;width:100%;text-align:left;font-family:inherit;color:var(--text);position:relative;overflow:hidden;}
.service-btn::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.04),transparent);transition:left 0.45s ease;}
.service-btn:hover::after{left:100%;}
.service-btn:hover{background:rgba(88,101,242,0.13);border-color:rgba(88,101,242,0.35);}
.service-btn.active{background:rgba(88,101,242,0.2);border-color:rgba(88,101,242,0.5);box-shadow:0 0 0 1px rgba(88,101,242,0.25),0 4px 14px rgba(88,101,242,0.2);}
.svc-btn-icon{width:30px;height:30px;border-radius:8px;background:rgba(255,255,255,0.06);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;overflow:hidden;}
.svc-btn-icon img{width:18px;height:18px;object-fit:contain;display:block;}
.svc-btn-info{flex:1;min-width:0;}
.svc-btn-name{font-size:0.84rem;font-weight:700;color:var(--text);display:block;}
.svc-btn-meta{font-size:0.68rem;color:var(--text-dim);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.svc-btn-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,0.12);flex-shrink:0;}
.svc-btn-dot.has-logs{background:var(--success);box-shadow:0 0 5px rgba(46,204,113,0.4);}
.svc-btn-dot.has-errors{background:var(--fail);box-shadow:0 0 5px rgba(231,76,60,0.4);}
.svc-btn-dot.loading{background:rgba(88,101,242,0.6);animation:dotpulse 1s infinite;}
@keyframes dotpulse{0%,100%{opacity:1}50%{opacity:0.3}}
.log-file-list{display:flex;flex-direction:column;gap:0.2rem;margin-top:0.35rem;padding-left:0.5rem;}
.log-file-btn{display:flex;align-items:center;gap:0.5rem;padding:0.4rem 0.7rem;border-radius:8px;border:1px solid transparent;background:transparent;cursor:pointer;transition:all 0.15s;font-family:inherit;color:var(--text-dim);font-size:0.78rem;text-align:left;width:100%;}
.log-file-btn:hover{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.07);color:var(--text);}
.log-file-btn.active{background:rgba(88,101,242,0.12);border-color:rgba(88,101,242,0.3);color:#a8b4ff;}
.log-file-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.log-file-size{font-size:0.65rem;color:#555;flex-shrink:0;}
.log-main{position:relative;z-index:1;display:flex;flex-direction:column;gap:0.75rem;min-width:0;}
.log-title-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:0.5rem;}
.log-title{font-size:1rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:0.5rem;}
.log-title-actions{display:flex;gap:0.5rem;align-items:center;}
.log-stats{display:flex;gap:0.5rem;flex-wrap:wrap;}
.stat-pill{display:flex;align-items:center;gap:0.3rem;padding:0.22rem 0.65rem;border-radius:20px;font-size:0.72rem;font-weight:600;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);color:var(--text-dim);}
.stat-pill .count{font-weight:700;}
.pill-info .count{color:var(--info)}.pill-warn .count{color:var(--warn)}.pill-error .count{color:var(--fail)}.pill-lines .count{color:var(--text-dim)}
.filter-tabs{display:flex;gap:0.35rem;flex-wrap:wrap;}
.filter-tab{padding:0.25rem 0.7rem;border-radius:20px;font-size:0.73rem;font-weight:600;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.04);color:var(--text-dim);cursor:pointer;transition:all 0.15s;font-family:inherit;}
.filter-tab:hover{border-color:rgba(88,101,242,0.4);color:var(--text);}
.filter-tab.active{background:rgba(88,101,242,0.2);border-color:rgba(88,101,242,0.5);color:#a8b4ff;}
.log-body-wrap{background:rgba(0,0,0,0.45);border:1px solid rgba(88,101,242,0.15);border-radius:12px;overflow:hidden;}
.log-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0.4rem 0.8rem;border-bottom:1px solid rgba(88,101,242,0.1);background:rgba(0,0,0,0.2);gap:0.5rem;flex-wrap:wrap;}
.log-search{flex:1;min-width:140px;max-width:280px;background:rgba(255,255,255,0.04);border:1px solid rgba(88,101,242,0.2);border-radius:7px;padding:0.32rem 0.7rem;color:var(--text);font-size:0.78rem;outline:none;font-family:inherit;transition:border-color 0.2s;}
.log-search:focus{border-color:rgba(88,101,242,0.5)}.log-search::placeholder{color:#555}
.log-meta{font-size:0.7rem;color:#3a3a5a;display:flex;align-items:center;gap:0.4rem;}
.log-body{height:520px;overflow-y:auto;padding:0.6rem 0.85rem;font-family:'DM Mono',monospace;font-size:0.73rem;line-height:1.6;}
.log-body::-webkit-scrollbar{width:4px;height:4px}.log-body::-webkit-scrollbar-track{background:transparent}.log-body::-webkit-scrollbar-thumb{background:rgba(88,101,242,0.25);border-radius:2px}
.log-line{display:flex;gap:0.4rem;padding:0.04rem 0;white-space:pre-wrap;word-break:break-all;}
.log-line.hidden{display:none;}
.log-ts{color:#3a3a5a;flex-shrink:0;user-select:none;font-size:0.7rem;}
.log-lvl{flex-shrink:0;font-weight:700;width:56px;}
.log-lvl.INFO{color:var(--info)}.log-lvl.DEBUG{color:#555}.log-lvl.WARNING{color:var(--warn)}.log-lvl.ERROR{color:var(--fail)}.log-lvl.CRITICAL{color:var(--fail)}
.log-msg{flex:1;color:#c8d3f5}
.log-msg.INFO{color:#c8d3f5}.log-msg.DEBUG{color:#555}.log-msg.WARNING{color:var(--warn)}.log-msg.ERROR{color:var(--fail)}.log-msg.CRITICAL{color:var(--fail)}.log-raw{color:#8890b8}
.log-sep{display:flex;align-items:center;gap:0.5rem;padding:0.4rem 0;white-space:nowrap;}
.log-sep-line{flex:1;height:1px;background:rgba(88,101,242,0.1)}.log-sep-label{font-size:0.65rem;color:#3a3a5a;user-select:none}
.log-empty{padding:2.5rem;text-align:center;color:#3d4266;font-style:italic;font-size:0.85rem;white-space:normal;}
.no-selection{padding:3rem;text-align:center;color:#3d4266;font-size:0.9rem;white-space:normal;}
.no-selection .big-icon{font-size:2.5rem;display:block;margin-bottom:0.75rem;opacity:0.4;}
/* btn base + ghost/accent/sm inherited from shared.css */
.btn-toggle-on{background:rgba(52,211,153,0.12) !important;border-color:rgba(52,211,153,0.4) !important;color:var(--green) !important}
.spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(88,101,242,0.3);border-top-color:var(--accent);border-radius:50%;animation:spin 0.7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* ── Page body ── */
.page-body{display:flex;gap:0;position:relative;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:24px;box-shadow:0 8px 32px rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.1);overflow:hidden;min-height:600px;}
.page-body::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3),transparent);z-index:2;pointer-events:none;}

/* Sidebar section */
.sb-section{display:flex;flex-direction:column;gap:0.2rem;}
.sb-section-hdr{font-size:0.58rem;font-weight:700;letter-spacing:2.2px;text-transform:uppercase;color:var(--text-muted);padding:0 0.5rem;margin-bottom:0.3rem;display:flex;align-items:center;gap:0.5rem;}
.sb-section-hdr::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(255,255,255,0.06),transparent);}

/* Sidebar button */
.sb-btn{display:flex;align-items:center;gap:0.65rem;padding:0.6rem 0.8rem;border-radius:10px;border:1px solid rgba(88,101,242,0.1);background:rgba(88,101,242,0.04);cursor:pointer;width:100%;text-align:left;font-family:inherit;color:var(--text);transition:all 0.15s;position:relative;}
.sb-btn:hover{background:rgba(88,101,242,0.1);border-color:rgba(88,101,242,0.25);}
.sb-btn.active{background:rgba(88,101,242,0.18);border-color:rgba(88,101,242,0.45);box-shadow:0 0 0 1px rgba(88,101,242,0.2),0 4px 14px rgba(88,101,242,0.12);}
.sb-icon{width:32px;height:32px;border-radius:9px;background:rgba(255,255,255,0.06);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px;}
.sb-btn.active .sb-icon{background:rgba(124,92,252,0.22);}
.sb-name{font-size:0.84rem;font-weight:700;color:var(--text);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-badge{font-size:0.62rem;font-weight:700;padding:0.1rem 0.45rem;border-radius:20px;flex-shrink:0;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);color:var(--text-dim);}
.sb-badge.ok{background:rgba(52,211,153,0.1);border-color:rgba(52,211,153,0.25);color:var(--green);}
.sb-badge.warn{background:rgba(251,191,36,0.1);border-color:rgba(251,191,36,0.25);color:var(--amber);}
.sb-badge.err{background:rgba(248,113,113,0.12);border-color:rgba(248,113,113,0.3);color:var(--red);}
.sb-btn.active .sb-badge{background:rgba(124,92,252,0.2);border-color:rgba(124,92,252,0.4);color:var(--accent2);}

/* Sub-file list */
.sb-files{display:flex;flex-direction:column;gap:2px;padding:0.2rem 0 0.1rem 0.5rem;}
.sb-file-btn{display:flex;align-items:center;gap:0.5rem;padding:0.35rem 0.65rem;border-radius:7px;border:1px solid transparent;background:transparent;cursor:pointer;width:100%;font-family:inherit;color:var(--text-dim);font-size:0.78rem;text-align:left;transition:all 0.12s;}
.sb-file-btn:hover{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.06);color:var(--text);}
.sb-file-btn.active{background:rgba(124,92,252,0.12);border-color:rgba(124,92,252,0.28);color:#c4b5fd;}
.sb-file-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,0.12);flex-shrink:0;}
.sb-file-btn.active .sb-file-dot{background:var(--accent);}
.sb-file-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-file-size{font-size:0.65rem;color:var(--text-muted);flex-shrink:0;}

/* Log main area */
.log-main{flex:1;min-width:0;padding:1.4rem 1.5rem;display:flex;flex-direction:column;gap:1.1rem;}
.log-stats{display:flex;column-gap:0.5rem;row-gap:0.55rem;flex-wrap:wrap;}
.filter-tabs{display:flex;column-gap:0.35rem;row-gap:1rem;flex-wrap:wrap;}

@media(max-width:600px){
  .page-header-row{flex-wrap:wrap;gap:0.35rem;margin-bottom:0.75rem}
  .back-btn{width:38px;min-width:38px;font-size:1rem}
  .title-card{padding:0.6rem 0.85rem;gap:0.5rem;min-width:0;flex:1}
  .title-card h1{font-size:1rem;letter-spacing:-0.2px}
  .page-sub{font-size:0.68rem}.page-icon{font-size:1.15rem}
  .user-btn,.bell-btn{padding:0 0.55rem;font-size:1rem}
}
