/* ===== Memento Hub v2 — Premium Dark Theme ===== */
:root{--bg:#070710;--bg-surface:rgba(15,15,25,.85);--bg-card:rgba(20,20,35,.75);--bg-hover:rgba(30,30,50,.8);--bg-input:rgba(25,25,45,.7);--border:rgba(255,255,255,.06);--border-hover:rgba(255,255,255,.12);--text:#d4d4d8;--text-dim:#71717a;--text-bright:#fafafa;--accent:#818cf8;--accent2:#6366f1;--accent-glow:rgba(129,140,248,.25);--green:#4ade80;--blue:#60a5fa;--pink:#f472b6;--purple:#c084fc;--red:#f87171;--orange:#fb923c;--yellow:#fbbf24;--cyan:#22d3ee;--radius:10px;--radius-lg:14px;--font:'Inter',system-ui,sans-serif;--mono:'JetBrains Mono',monospace;--sidebar-w:240px;--shadow:0 4px 24px rgba(0,0,0,.5)}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
.hidden{display:none!important}

/* ===== LOGIN ===== */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.login-card{background:var(--bg-surface);backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:24px;padding:48px 40px;width:400px;max-width:90vw;text-align:center;position:relative;z-index:2;box-shadow:var(--shadow);animation:fadeInUp .6s ease}
.login-logo{font-size:56px;margin-bottom:16px;animation:float 3s ease-in-out infinite}
.login-title{font-size:28px;font-weight:700;color:var(--text-bright);margin-bottom:4px}
.login-subtitle{font-size:13px;color:var(--text-dim);margin-bottom:32px;letter-spacing:.5px}
.input-group{margin-bottom:20px}
.input-group input{width:100%;padding:14px 18px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-bright);font-family:var(--mono);font-size:14px;outline:0;transition:all .3s}
.input-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.input-group input::placeholder{color:var(--text-dim)}
.login-error{color:var(--red);font-size:13px;margin-top:12px;min-height:20px}
.login-bg-orbs{position:absolute;inset:0;z-index:0;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.35;animation:orbMove 8s ease-in-out infinite alternate}
.orb-1{width:300px;height:300px;background:var(--accent);top:10%;left:10%}
.orb-2{width:250px;height:250px;background:var(--pink);bottom:10%;right:15%;animation-delay:-3s}
.orb-3{width:200px;height:200px;background:var(--purple);top:50%;left:60%;animation-delay:-5s}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 2px 12px var(--accent-glow)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-glow)}
.btn-login{width:100%;justify-content:center;padding:14px;font-size:15px}
.btn-ghost{background:0 0;color:var(--text-dim);padding:8px 12px}
.btn-ghost:hover{color:var(--text-bright);background:rgba(255,255,255,.05)}
.btn-sm{font-size:11px;padding:6px 10px}
.btn-danger{background:rgba(248,113,113,.15);color:var(--red);border:1px solid rgba(248,113,113,.2)}
.btn-danger:hover{background:rgba(248,113,113,.25)}

/* ===== LAYOUT ===== */
.dashboard{display:flex;min-height:100vh}

/* ===== SIDEBAR ===== */
.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);backdrop-filter:blur(16px);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:20;transition:transform .3s}
.sidebar-logo{padding:20px 20px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
.logo-icon{font-size:28px}
.logo-text{font-size:18px;font-weight:700;color:var(--text-bright)}
.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius);color:var(--text-dim);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s;position:relative}
.nav-item:hover{color:var(--text);background:rgba(255,255,255,.04)}
.nav-item.active{color:var(--text-bright);background:rgba(129,140,248,.1)}
.nav-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent);border-radius:0 3px 3px 0}
.nav-item svg{flex-shrink:0}
.nav-badge{margin-left:auto;background:rgba(129,140,248,.2);color:var(--accent);padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;font-family:var(--mono)}
.sidebar-footer{padding:16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.daemon-info{display:flex;align-items:center;gap:10px}
.daemon-ver{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--accent)}
.daemon-up{font-size:10px;color:var(--text-dim)}
.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.status-ok{background:var(--green);box-shadow:0 0 8px var(--green)}
.status-down{background:var(--red);box-shadow:0 0 8px var(--red)}

/* ===== MOBILE ===== */
.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:15;padding:0 16px;align-items:center;justify-content:space-between;font-weight:600;backdrop-filter:blur(12px)}

/* ===== MAIN CONTENT ===== */
.main-content{margin-left:var(--sidebar-w);flex:1;padding:28px;min-height:100vh}
.tab-content{display:none;animation:fadeIn .3s ease}
.tab-content.active{display:block}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.page-title{font-size:22px;font-weight:700;color:var(--text-bright)}
.header-actions{display:flex;align-items:center;gap:10px}
.text-dim{font-size:12px;color:var(--text-dim);font-family:var(--mono)}
.select-sm{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:6px 12px;font-family:var(--font);font-size:12px;outline:0;cursor:pointer}
.input-search{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-bright);padding:8px 14px;font-family:var(--font);font-size:13px;outline:0;width:220px;transition:border-color .2s}
.input-search:focus{border-color:var(--accent)}
.live-badge{display:inline-flex;align-items:center;gap:4px;color:var(--green);font-size:11px;font-weight:600;animation:pulse 2s infinite}

/* ===== METRICS GRID ===== */
.metrics-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:24px}
.metric-card{padding:18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);backdrop-filter:blur(12px);transition:all .3s;position:relative;overflow:hidden}
.metric-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow)}
.metric-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.metric-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:rgba(255,255,255,.03)}
.metric-icon svg{color:var(--c)}
.metric-trend{font-family:var(--mono);font-size:11px;padding:2px 8px;border-radius:8px;background:rgba(74,222,128,.1);color:var(--green)}
.metric-trend.down{background:rgba(248,113,113,.1);color:var(--red)}
.metric-value{font-size:28px;font-weight:700;color:var(--text-bright);font-family:var(--mono);line-height:1}
.metric-label{font-size:11px;color:var(--text-dim);margin-top:4px;letter-spacing:.3px}
.sparkline{width:100%;height:40px;margin-top:10px;opacity:.6}
.disk-bar{height:6px;background:rgba(255,255,255,.06);border-radius:3px;margin-top:12px;overflow:hidden}
.disk-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--purple));border-radius:3px;transition:width .5s ease}

/* ===== OVERVIEW GRID ===== */
.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ===== PANELS ===== */
.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);backdrop-filter:blur(12px);overflow:hidden}
.panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}
.panel-title{font-size:14px;font-weight:600;color:var(--text-bright);display:flex;align-items:center;gap:8px}
.panel-title svg{color:var(--accent)}

/* ===== SERVICES ===== */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px}
.service-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(255,255,255,.02);border-radius:var(--radius);border:1px solid transparent;transition:all .2s}
.service-item:hover{border-color:var(--border-hover)}
.service-item.loading{opacity:.5}
.service-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.service-dot.up{background:var(--green);box-shadow:0 0 6px var(--green)}
.service-dot.down{background:var(--red);box-shadow:0 0 6px var(--red)}
.service-dot.unknown{background:var(--text-dim)}
.service-name{font-size:13px;font-weight:500;color:var(--text)}
.service-detail{font-size:10px;color:var(--text-dim);font-family:var(--mono)}

/* ===== ACTIVITY FEED ===== */
.activity-feed{padding:14px;max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.activity-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius);background:rgba(255,255,255,.02);animation:fadeIn .3s}
.activity-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-success{background:var(--green)}.dot-error{background:var(--red)}.dot-info{background:var(--blue)}.dot-warning{background:var(--yellow)}
.activity-text{flex:1;font-size:12px;color:var(--text)}
.activity-time{font-size:10px;color:var(--text-dim);font-family:var(--mono);white-space:nowrap}

/* ===== CHARTS ===== */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.chart-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;overflow:hidden}
.chart-panel.full-width{grid-column:1/-1}
.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.chart-header h3{font-size:14px;font-weight:600;color:var(--text-bright)}
.chart-val{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--accent)}
.chart-panel canvas{width:100%;height:180px;display:block}
.sys-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.sys-info-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:rgba(255,255,255,.02);border-radius:var(--radius)}
.sys-label{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}
.sys-val{font-size:14px;font-weight:600;color:var(--text-bright);font-family:var(--mono)}

/* ===== SKILLS v2 ===== */
.skill-categories{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.cat-btn{padding:7px 14px;border:1px solid var(--border);border-radius:20px;background:0 0;color:var(--text-dim);font-family:var(--font);font-size:12px;cursor:pointer;transition:all .2s}
.cat-btn:hover{border-color:var(--border-hover);color:var(--text)}
.cat-btn.active{background:rgba(129,140,248,.15);border-color:var(--accent);color:var(--accent)}
.skills-grid-v2{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.skill-card{padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .25s}
.skill-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 20px rgba(129,140,248,.1)}
.skill-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.skill-card-name{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--text-bright)}
.skill-card-version{font-family:var(--mono);font-size:10px;color:var(--text-dim)}
.skill-card-footer{display:flex;align-items:center;gap:8px;margin-top:8px}
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:600;font-family:var(--mono)}
.badge-approved{background:rgba(74,222,128,.12);color:var(--green)}
.badge-pending{background:rgba(251,191,36,.12);color:var(--yellow)}
.skill-exec{font-size:10px;color:var(--text-dim);font-family:var(--mono)}

/* ===== ACTIONS v2 ===== */
.action-groups{display:flex;flex-direction:column;gap:24px}
.action-group{}
.group-title{font-size:14px;font-weight:600;color:var(--text-bright);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.danger-title{color:var(--red)}
.action-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.action-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all .25s;font-family:var(--font)}
.action-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow)}
.action-card.danger{border-color:rgba(248,113,113,.15)}
.action-card.danger:hover{border-color:rgba(248,113,113,.35);box-shadow:0 4px 20px rgba(248,113,113,.1)}
.action-card.running{opacity:.6;pointer-events:none}
.action-card.running .ac-icon{animation:spin 1s linear infinite}
.ac-icon{font-size:24px}
.ac-name{font-size:13px;font-weight:600;color:var(--text-bright)}
.ac-desc{font-size:11px;color:var(--text-dim)}

/* ===== OUTPUT LOG ===== */
.output-log{padding:14px;max-height:400px;overflow-y:auto;font-family:var(--mono);font-size:12px}
.log-entry{padding:8px 12px;border-radius:8px;margin-bottom:4px;animation:fadeIn .3s;word-break:break-word;white-space:pre-wrap;line-height:1.5}
.log-info{background:rgba(96,165,250,.08);color:var(--blue)}
.log-success{background:rgba(74,222,128,.08);color:var(--green)}
.log-error{background:rgba(248,113,113,.08);color:var(--red)}
.log-output{background:rgba(255,255,255,.03);color:var(--text-dim)}

/* ===== AUDIT LOG ===== */
.audit-log{padding:14px;max-height:600px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}
.log-empty{padding:40px;text-align:center;color:var(--text-dim);font-size:13px}

/* ===== MODAL ===== */
.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.modal-content{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:480px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow);animation:fadeInUp .3s}
.modal-sm{width:380px}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}
.modal-header h3{font-size:16px;font-weight:600;color:var(--text-bright)}
.modal-body{padding:18px 22px}
.modal-body p{color:var(--text-dim);font-size:14px}
.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 22px;border-top:1px solid var(--border)}
.param-field{margin-bottom:12px}
.param-field label{display:block;font-size:11px;font-weight:500;color:var(--text-dim);margin-bottom:5px;font-family:var(--mono)}
.param-field input{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-bright);font-family:var(--mono);font-size:13px;outline:0;transition:border-color .2s}
.param-field input:focus{border-color:var(--accent)}
.checkbox-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-dim);cursor:pointer}

/* ===== TOAST ===== */
.toast-container{position:fixed;top:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px}
.toast{padding:14px 18px;border-radius:var(--radius);backdrop-filter:blur(12px);font-size:13px;display:flex;align-items:center;gap:10px;animation:slideIn .3s ease;max-width:380px;box-shadow:var(--shadow)}
.toast-success{background:rgba(74,222,128,.15);color:var(--green);border:1px solid rgba(74,222,128,.2)}
.toast-error{background:rgba(248,113,113,.15);color:var(--red);border:1px solid rgba(248,113,113,.2)}
.toast-info{background:rgba(96,165,250,.15);color:var(--blue);border:1px solid rgba(96,165,250,.2)}

/* ===== SKELETON ===== */
.skeleton-card{height:90px;border-radius:var(--radius-lg);background:linear-gradient(90deg,rgba(255,255,255,.02) 25%,rgba(255,255,255,.05) 50%,rgba(255,255,255,.02) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}

/* ===== ANIMATIONS ===== */
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes orbMove{0%{transform:translate(0,0)}100%{transform:translate(30px,-20px)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes slideIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* ===== DATA TABLE (Deploys) ===== */
.table-wrap{overflow-x:auto;padding:0}
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{text-align:left;padding:12px 16px;font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
.data-table td{padding:10px 16px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
.data-table tr:hover td{background:rgba(255,255,255,.02)}
.deploy-status{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;font-family:var(--mono)}
.deploy-ok{background:rgba(74,222,128,.1);color:var(--green)}
.deploy-fail{background:rgba(248,113,113,.1);color:var(--red)}
.deploy-pending{background:rgba(251,191,36,.1);color:var(--yellow)}
.btn-rollback{background:rgba(251,191,36,.1);color:var(--yellow);border:1px solid rgba(251,191,36,.2);padding:4px 10px;border-radius:8px;font-size:11px;cursor:pointer;font-family:var(--font);transition:all .2s}
.btn-rollback:hover{background:rgba(251,191,36,.2)}

/* ===== SSL GRID ===== */
.ssl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px;padding:14px}
.ssl-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(255,255,255,.02);border-radius:var(--radius);border:1px solid transparent}
.ssl-item:hover{border-color:var(--border-hover)}
.ssl-icon{font-size:18px}
.ssl-domain{font-size:13px;font-weight:500;color:var(--text)}
.ssl-expiry{font-size:10px;font-family:var(--mono)}
.ssl-ok{color:var(--green)}.ssl-warn{color:var(--yellow)}.ssl-danger{color:var(--red)}

/* ===== SETTINGS ===== */
.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.settings-body{padding:16px;display:flex;flex-direction:column;gap:14px}
.setting-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.setting-row label{font-size:13px;color:var(--text-dim);white-space:nowrap}
.input-setting{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-bright);padding:8px 12px;font-family:var(--mono);font-size:12px;outline:0;width:180px}
.token-display{display:flex;align-items:center;gap:8px}
.token-display code{font-family:var(--mono);font-size:12px;color:var(--text-dim);background:var(--bg-input);padding:6px 12px;border-radius:8px}
.theme-btns{display:flex;gap:6px}
.theme-btns .btn{border:1px solid var(--border)}
.theme-btns .btn.active{border-color:var(--accent);background:rgba(129,140,248,.1);color:var(--accent)}

/* ===== RESPONSIVE ===== */
@media(max-width:1200px){.metrics-grid{grid-template-columns:repeat(3,1fr)}.charts-grid{grid-template-columns:1fr}.settings-grid{grid-template-columns:1fr}}
@media(max-width:768px){
    .sidebar{transform:translateX(-100%)}
    .sidebar.open{transform:translateX(0)}
    .mobile-header{display:flex}
    .main-content{margin-left:0;padding:72px 16px 16px}
    .metrics-grid{grid-template-columns:repeat(2,1fr)}
    .overview-grid{grid-template-columns:1fr}
    .services-grid{grid-template-columns:repeat(2,1fr)}
    .sys-info-grid{grid-template-columns:repeat(2,1fr)}
    .action-grid{grid-template-columns:repeat(2,1fr)}
    .skills-grid-v2{grid-template-columns:1fr}
    .ssl-grid{grid-template-columns:1fr}
    .settings-grid{grid-template-columns:1fr}
}
