@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap";
@tailwind base;@tailwind components;@tailwind utilities;*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#02040a;--bg2:#050810;--bg3:#080c18;--surface:#0b1020;--surface2:#0f1628;--border:#151e35;--border2:#1e2d50;--border3:#263660;--text:#e2e8f8;--text2:#8896b8;--text3:#6a7a98;--green:#00e5a0;--green2:#00b87d;--blue:#3b9eff;--violet:#8b5cf6;--amber:#f59e0b;--red:#f43f5e;--cyan:#22d3ee}html,body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#1e2d50;border-radius:99px}.layout{min-height:100vh;display:flex}.sidebar{background:var(--bg2);border-right:1px solid var(--border);z-index:100;flex-direction:column;flex-shrink:0;width:220px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:24px 20px 20px;display:flex}.logo-icon{background:linear-gradient(135deg,#00e5a033,#3b9eff1a);border:1px solid #00e5a040;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 0 20px #00e5a01f}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 10px;display:flex}.nav-item{color:var(--text3);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{color:var(--text2);background:#ffffff0a}.nav-item.active{color:var(--text);background:#00e5a014;border:1px solid #00e5a01f}.nav-item.active .nav-icon{color:var(--green)}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:16px 10px;display:flex}.status-pill{background:#00e5a00f;border:1px solid #00e5a01f;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;display:flex}.pulse{background:var(--green);border-radius:50%;flex-shrink:0;width:6px;height:6px;position:relative}.pulse:after{content:"";background:#00e5a04d;border-radius:50%;animation:2s ease-out infinite pulse;position:absolute;inset:-3px}@keyframes pulse{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(2.5)}}.main{background:var(--bg);flex:1;min-height:100vh;margin-left:220px}.topbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:50;background:#02040acc;justify-content:space-between;align-items:center;padding:20px 32px;display:flex;position:sticky;top:0}.page-content{padding:32px}.metrics-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;transition:border-color .2s,transform .2s;position:relative;overflow:hidden}.metric-card:hover{border-color:var(--border2);transform:translateY(-1px)}.metric-card:after{content:"";background:linear-gradient(90deg,#0000,#ffffff0f,#0000);height:1px;position:absolute;top:0;left:0;right:0}.metric-icon{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:14px;display:flex}.metric-value{letter-spacing:-.02em;margin-bottom:4px;font-family:Inter,sans-serif;font-size:28px;font-weight:800;line-height:1}.metric-label{color:var(--text3);font-size:12px;font-weight:500}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:20px;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;transition:all .25s;position:relative;overflow:hidden}.project-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 20px 60px #0006,0 0 0 1px #00e5a00d}.project-card-accent{background:linear-gradient(90deg,var(--green),var(--blue));height:3px}.project-card-accent.no-backup{background:linear-gradient(90deg,var(--red),#f97316)}.project-header{justify-content:space-between;align-items:center;padding:20px 22px 16px;display:flex}.pm-badge{letter-spacing:.05em;color:var(--green);background:#00e5a01a;border:1px solid #00e5a033;border-radius:8px;align-items:center;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;display:inline-flex}.project-name{letter-spacing:-.02em;color:var(--text);font-size:18px;font-weight:700}.backup-status{align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;display:flex}.project-body{padding:0 22px 22px}.info-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;display:grid}.info-box{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:12px 14px}.info-box-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:4px;font-family:JetBrains Mono,monospace;font-size:10px}.info-box-value{color:var(--text2);font-size:13px;font-weight:600}.tags-row{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.tag{border:1px solid;border-radius:7px;align-items:center;gap:4px;padding:4px 9px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;display:inline-flex}.tag-green{color:#00e5a0;background:#00e5a012;border-color:#00e5a033}.tag-blue{color:#3b9eff;background:#3b9eff12;border-color:#3b9eff33}.tag-violet{color:#a78bfa;background:#a78bfa12;border-color:#a78bfa33}.tag-amber{color:#f59e0b;background:#f59e0b12;border-color:#f59e0b33}.tag-cyan{color:#22d3ee;background:#22d3ee12;border-color:#22d3ee33}.tag-orange{color:#fb923c;background:#fb923c12;border-color:#fb923c33}.snapshots-row{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px;display:grid}.snapshot-btn{cursor:pointer;background:0 0;border:1px solid;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:10px 6px;font-family:JetBrains Mono,monospace;transition:all .15s;display:flex}.snapshot-btn.available{color:var(--green);background:#00e5a00d;border-color:#00e5a033}.snapshot-btn.available:hover{background:#00e5a01f;border-color:#00e5a066;transform:translateY(-1px)}.snapshot-btn.empty{border-color:var(--border);color:var(--text3);cursor:not-allowed}.actions-row{grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:10px;display:grid}.action-btn{cursor:pointer;background:0 0;border:1px solid;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:14px 8px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;transition:all .15s;display:flex}.action-btn:disabled{opacity:.3;cursor:not-allowed}.action-btn.download{color:#3b9eff;background:#3b9eff0f;border-color:#3b9eff33}.action-btn.download:hover:not(:disabled){background:#3b9eff24;border-color:#3b9eff66;transform:translateY(-1px);box-shadow:0 4px 16px #3b9eff26}.action-btn.upload{color:#f59e0b;background:#f59e0b0f;border-color:#f59e0b33}.action-btn.upload:hover:not(:disabled){background:#f59e0b24;border-color:#f59e0b66;transform:translateY(-1px);box-shadow:0 4px 16px #f59e0b26}.action-btn.restore{color:#a78bfa;background:#a78bfa0f;border-color:#a78bfa33}.action-btn.restore:hover:not(:disabled){background:#a78bfa24;border-color:#a78bfa66;transform:translateY(-1px);box-shadow:0 4px 16px #a78bfa26}.trigger-btn{border:1px solid var(--border);width:100%;color:var(--text3);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;gap:7px;padding:9px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;transition:all .15s;display:flex}.trigger-btn:hover{border-color:var(--border2);color:var(--text2);background:#ffffff08}.disk-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;align-items:center;gap:20px;margin-bottom:28px;padding:20px 24px;display:flex}.disk-bar-wrap{flex:1}.disk-bar-labels{justify-content:space-between;margin-bottom:8px;display:flex}.disk-bar-track{background:var(--border);border-radius:99px;height:6px;overflow:hidden}.disk-bar-fill{background:linear-gradient(90deg,var(--green),var(--blue));border-radius:99px;height:100%}.btn-primary{background:linear-gradient(135deg,var(--green),var(--green2));color:#020a06;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:7px;padding:9px 18px;font-family:Inter,sans-serif;font-size:13px;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 20px #00e5a040}.btn-primary:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 6px 24px #00e5a059}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{color:var(--text2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:10px;align-items:center;gap:7px;padding:9px 16px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-ghost:hover{border-color:var(--border2);color:var(--text);background:#ffffff0a}.btn-icon{border:1px solid var(--border);width:32px;height:32px;color:var(--text3);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.btn-icon:hover{border-color:var(--border2);color:var(--text2);background:#ffffff0a}.section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text3);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.timeline-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.timeline-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden}.timeline-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.timeline-body{flex-direction:column;gap:8px;padding:12px;display:flex}.timeline-item{background:var(--bg3);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.log-area{border:1px solid var(--border);color:#6b82a8;background:#030508;border-radius:14px;max-height:600px;padding:20px;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.8;overflow-y:auto}.login-bg{background:radial-gradient(ellipse 80% 50% at 20% -10%,#00e5a014 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 110%,#3b9eff12 0%,transparent 60%),var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.login-grid{background-image:linear-gradient(#ffffff03 1px,#0000 1px),linear-gradient(90deg,#ffffff03 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0}.login-card{z-index:1;border:1px solid var(--border2);background:#080c18e6;border-radius:24px;width:100%;max-width:400px;animation:.5s cubic-bezier(.16,1,.3,1) both card-in;position:relative;overflow:hidden;box-shadow:0 0 0 1px #00e5a00f,0 40px 80px #0009,0 0 80px #00e5a00a}@keyframes card-in{0%{opacity:0;transform:translateY(24px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.login-top-bar{background:linear-gradient(90deg,transparent,var(--green)30%,var(--blue)70%,transparent);height:2px}.login-body{padding:36px 36px 32px}.login-logo-wrap{flex-direction:column;align-items:center;margin-bottom:32px;display:flex}.login-logo-icon{background:linear-gradient(135deg,#00e5a026,#3b9eff14);border:1px solid #00e5a033;border-radius:18px;justify-content:center;align-items:center;width:60px;height:60px;margin-bottom:16px;display:flex;position:relative;box-shadow:0 0 40px #00e5a01f}.login-logo-icon:before{content:"";-webkit-mask-composite:xor;background:linear-gradient(135deg,#00e5a066,#3b9eff33,#0000);border-radius:19px;padding:1px;position:absolute;inset:-1px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.field-wrap{margin-bottom:14px}.field-label-text{text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:7px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;display:block}.field-input-wrap{align-items:center;display:flex;position:relative}.field-icon-left{color:var(--text3);pointer-events:none;position:absolute;left:14px}.field-input{border:1px solid var(--border2);width:100%;color:var(--text);background:#ffffff08;border-radius:12px;outline:none;padding:12px 14px 12px 42px;font-family:Inter,sans-serif;font-size:14px;transition:all .2s}.field-input::placeholder{color:var(--text3)}.field-input:focus{background:#00e5a008;border-color:#00e5a066;box-shadow:0 0 0 3px #00e5a014}.eye-toggle{cursor:pointer;color:var(--text3);background:0 0;border:none;border-radius:6px;padding:4px;transition:color .15s;position:absolute;right:12px}.eye-toggle:hover{color:var(--text2)}.login-btn{background:linear-gradient(135deg,var(--green),var(--green2));color:#020a06;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:8px;padding:13px;font-family:Inter,sans-serif;font-size:14px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 24px #00e5a04d}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 30px #00e5a066}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#f43f5e;background:#f43f5e14;border:1px solid #f43f5e33;border-radius:10px;align-items:center;gap:8px;margin-bottom:14px;padding:11px 14px;font-family:JetBrains Mono,monospace;font-size:12px;display:flex}.modal-overlay{z-index:9000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface2);border:1px solid var(--border2);border-radius:22px;width:500px;max-width:95vw;animation:.2s cubic-bezier(.16,1,.3,1) both modal-in;overflow:hidden;box-shadow:0 40px 100px #000000b3}@keyframes modal-in{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-body{padding:24px}.modal-footer{justify-content:flex-end;gap:8px;padding:0 24px 24px;display:flex}.drop-zone{border:1.5px dashed var(--border2);text-align:center;cursor:pointer;border-radius:14px;margin-bottom:16px;padding:36px 20px;transition:all .2s}.drop-zone:hover,.drop-zone.drag{background:#00e5a00a;border-color:#00e5a066}.select-input{background:var(--bg3);border:1px solid var(--border2);width:100%;color:var(--text);border-radius:10px;outline:none;padding:10px 14px;font-family:JetBrains Mono,monospace;font-size:13px;transition:border-color .2s}.select-input:focus{border-color:#00e5a066}.progress-bar{background:var(--border);border-radius:99px;height:4px;margin-bottom:16px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--green),var(--blue));border-radius:99px;height:100%;transition:width .2s}.toast{z-index:9999;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:14px;align-items:center;gap:10px;padding:13px 18px;font-family:JetBrains Mono,monospace;font-size:13px;animation:.3s cubic-bezier(.16,1,.3,1) both toast-in;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 20px 50px #00000080}.toast.ok{color:var(--green);background:#080e1af7;border:1px solid #00e5a040}.toast.err{color:var(--red);background:#080e1af7;border:1px solid #f43f5e40}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.restore-warning{color:#f59e0b;background:#f59e0b12;border:1px solid #f59e0b33;border-radius:10px;margin-bottom:4px;padding:12px 14px;font-family:JetBrains Mono,monospace;font-size:12px}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.7s linear infinite spin}@keyframes fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:.4s cubic-bezier(.16,1,.3,1) both fade-up}.btn-spinner{border:2px solid #0003;border-top-color:#020a06;border-radius:50%;width:15px;height:15px;animation:.6s linear infinite spin}
