:root{color-scheme:dark;--bg:#050916;--surface:rgba(16,25,52,0.88);--surface-strong:#101a38;--text:#e9efff;--muted:#9bb0dc;--primary:#6170ff;--primary-strong:#4f4fe2;--accent:#08d8d2;--danger:#ff7d9c;--border:rgba(142,170,227,0.22)}*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100%;direction:rtl;font-family:iranyekan,Vazirmatn,IRANSansX,Tahoma,Segoe UI,Roboto,sans-serif;background:radial-gradient(circle at 12% 10%,#172b67 0,transparent 40%),radial-gradient(circle at 86% 0,#0d2d49 0,transparent 35%),var(--bg);color:var(--text)}.page-shell{position:relative;max-width:1120px;margin:0 auto;padding:40px 20px 60px;display:grid;grid-gap:18px;gap:18px}.app-layout{min-height:100vh}.app-main{-webkit-margin-start:280px;margin-inline-start:280px;max-width:none}.sidebar{position:fixed;inset-inline-start:0;top:0;bottom:0;width:280px;flex-direction:column;padding:16px 0;background:rgba(8,14,34,.96);-webkit-border-end:1px solid var(--border);border-inline-end:1px solid var(--border);z-index:30}.desktop-sidebar,.sidebar{display:flex}.mobile-sidebar,.sidebar-mobile-backdrop,.sidebar-mobile-close,.sidebar-mobile-toggle{display:none}.sidebar-profile{display:flex;align-items:center;gap:12px;width:100%;padding:12px 18px;border:0;background:transparent;color:var(--text);cursor:pointer;text-align:start}.sidebar-profile-text{display:grid;grid-gap:2px;gap:2px;flex:1 1;min-width:0}.sidebar-profile-text strong{font-size:.95rem}.sidebar-profile-text .muted{font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-profile-chevron{color:var(--muted);transition:transform .2s ease;flex-shrink:0}.sidebar-profile-chevron.open{transform:rotate(180deg)}.user-avatar{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:white;font-weight:700;font-size:.95rem;flex-shrink:0}.sidebar-profile-menu{padding:0 12px 8px}.sidebar-logout-button{display:inline-flex;align-items:center;gap:8px;width:100%;justify-content:flex-start;padding:10px 12px;background:rgba(255,255,255,.06);border:1px solid var(--border);font-size:.9rem}.sidebar-divider{height:1px;margin:8px 18px 16px;background:var(--border)}.sidebar-nav{padding:0 12px;flex:1 1}.sidebar-nav-item{display:inline-flex;align-items:center;gap:10px;width:100%;padding:11px 12px;border-radius:12px;color:var(--text);background:rgba(97,112,255,.12);border:1px solid rgba(97,112,255,.25);font-weight:600;text-decoration:none;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease}.sidebar-nav-item:hover{text-decoration:none;background:rgba(97,112,255,.2);border-color:rgba(97,112,255,.4)}.sidebar-nav-item:active,.sidebar-nav-item:focus,.sidebar-nav-item:visited{text-decoration:none}.sidebar-nav-item+.sidebar-nav-item{margin-top:8px}.sidebar-nav-item.active{background:linear-gradient(135deg,rgba(97,112,255,.32),rgba(79,79,226,.26));border-color:rgba(8,216,210,.45);box-shadow:inset 0 0 0 1px rgba(8,216,210,.2),0 8px 20px rgba(5,9,22,.35);color:#eef4ff}.sidebar-nav-item.disabled{background:rgba(255,255,255,.03);border-color:var(--border);color:var(--muted);opacity:.92;cursor:not-allowed;pointer-events:none}.sidebar-soon-tag{-webkit-margin-start:auto;margin-inline-start:auto;font-size:.7rem;font-weight:700;color:#fcd34d;background:rgba(245,158,11,.18);border:1px solid rgba(245,158,11,.38);border-radius:999px;padding:2px 8px;white-space:nowrap}.sidebar-brand{display:grid;justify-items:center;grid-gap:8px;gap:8px;padding:16px 18px 8px;color:var(--muted);opacity:.7;font-size:.85rem}@media (max-width:980px){.app-main{-webkit-margin-start:0;margin-inline-start:0;padding-top:72px}.desktop-sidebar{display:none}.sidebar-mobile-toggle{display:inline-flex;align-items:center;justify-content:center;position:fixed;top:16px;inset-inline-start:16px;z-index:40;width:42px;height:42px;padding:0;border-radius:10px;background:rgba(255,255,255,.08);border:1px solid var(--border)}.sidebar-mobile-backdrop{display:block;position:fixed;inset:0;z-index:50;background:rgba(4,7,16,.72);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.mobile-sidebar{display:flex;position:relative;width:min(320px,100%);height:100%}.sidebar-mobile-close{display:inline-flex;align-items:center;justify-content:center;position:absolute;top:12px;inset-inline-end:12px;z-index:1;width:36px;height:36px;padding:0;border-radius:8px;background:rgba(255,255,255,.08);border:1px solid var(--border)}}.login-page-shell{min-height:100vh;align-content:center}.login-page-shell .panel{width:min(980px,100%);margin:0 auto}.page-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(500px at 95% 0,rgba(8,216,210,.1),transparent 70%),radial-gradient(420px at 0 35%,rgba(111,116,255,.14),transparent 80%)}.panel{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:22px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:22px;box-shadow:0 18px 48px rgba(0,0,0,.35)}.hero h1{margin:0;font-size:clamp(1.7rem,3.2vw,2.4rem)}.hero p{margin:8px 0 0;color:var(--muted);max-width:54ch}.hero-grid{display:grid;grid-template-columns:1.25fr minmax(240px,.75fr);grid-gap:18px;gap:18px;align-items:center}.hero-chip-wrap{display:grid;grid-gap:10px;gap:10px}.hero-chip{border:1px solid var(--border);border-radius:14px;padding:12px 14px;background:rgba(8,14,34,.8);display:flex;justify-content:space-between;align-items:baseline}.hero-chip span{font-size:.8rem;color:var(--muted);text-transform:uppercase}.hero-chip strong{font-size:1.2rem}.eyebrow{display:inline-block;font-size:.78rem;letter-spacing:.09em;text-transform:uppercase;color:var(--accent)}.auth-panel h2,.eyebrow,.toolbar h2,h3{margin:0 0 10px}.dashboard-grid{display:grid;grid-template-columns:.95fr 1.05fr;grid-gap:18px;gap:18px}.auth-form{display:flex;gap:10px;flex-wrap:wrap}.auth-form-column{flex-direction:column;max-width:420px}::placeholder,button,input{font-family:inherit;font-size:inherit}input{min-width:280px;flex:1 1;border:1px solid var(--border);border-radius:12px;padding:11px 12px;background:rgba(7,13,33,.8);color:var(--text)}button{border:0;border-radius:12px;padding:10px 15px;cursor:pointer;color:white;background:linear-gradient(135deg,var(--primary),var(--primary-strong));font-weight:600}button:disabled{opacity:.65;cursor:not-allowed}.ghost-button{background:rgba(255,255,255,.08);border:1px solid var(--border)}.icon-button{display:inline-flex;align-items:center;justify-content:center;padding:6px;width:32px;height:32px;border-radius:6px;background:rgba(59,130,246,.15);border-color:rgba(59,130,246,.4);color:#60a5fa}.icon-button:hover:not(:disabled){background:rgba(59,130,246,.25)}.cancel-button{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.4);color:#f87171;padding:6px 10px;font-size:.8rem;font-weight:600}.cancel-button:hover:not(:disabled){background:rgba(239,68,68,.25)}.inline-link{display:inline-block;margin-top:12px;color:var(--accent);text-decoration:none;font-weight:600}.inline-link:hover{text-decoration:underline}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.toolbar-surface{border-radius:16px}.toolbar p{margin:0;color:var(--muted)}.instance-actions,.toolbar-actions{display:flex;gap:8px}.instance-actions{justify-content:flex-start;flex-wrap:wrap}.instance-details{padding:10px 0;color:var(--text)}.instance-details p{margin:0 0 8px}.kubeconfig-block{margin:0;padding:10px;border-radius:10px;border:1px solid var(--border);background:rgba(7,13,33,.8);color:var(--text);white-space:pre-wrap;word-break:break-word;max-height:220px;overflow:auto;direction:ltr;text-align:left}.instance-modal-backdrop{position:fixed;inset:0;background:rgba(4,7,16,.72);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:50;display:grid;place-items:center;padding:20px}.instance-modal{width:min(1200px,100%);height:min(86vh,900px);background:rgba(10,17,40,.96);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 70px rgba(0,0,0,.5);display:grid;grid-template-rows:auto 1fr;overflow:hidden}.instance-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}.instance-modal-header h3{margin:0}.instance-modal-meta{padding:14px;overflow:auto;height:100%;direction:rtl;text-align:right}.instance-modal-meta p{margin:0 0 10px}.field-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.field-row p{margin:0}.field-row-stack{align-items:flex-start}.copy-button{white-space:nowrap;padding:6px 10px;font-size:.82rem}.endpoint-list{display:grid;grid-gap:8px;gap:8px;margin-bottom:10px}.endpoint-link{margin-top:0}.active-challenges-wrap{min-height:220px}.active-challenges-list{margin:0;padding:0;list-style:none;display:grid;grid-gap:10px;gap:10px}.active-challenge-link{margin-top:0}.challenge-details-link{display:inline-flex;align-items:center;justify-content:center;margin-top:auto;width:100%;min-height:40px;border-radius:12px;padding:10px 14px;border:0;background:linear-gradient(135deg,var(--primary),var(--primary-strong));font-weight:600;text-decoration:none;color:#fff}.challenge-details-link:hover{text-decoration:none;filter:brightness(1.06)}.active-instance-indicator{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:rgba(8,216,210,.2);border:1px solid rgba(8,216,210,.45);color:var(--accent)}.active-instance-dot{width:10px;height:10px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 rgba(34,197,94,.8);animation:activePulse 1.2s ease-in-out infinite}@keyframes activePulse{0%{transform:scale(.9);box-shadow:0 0 0 0 rgba(34,197,94,.8)}70%{transform:scale(1);box-shadow:0 0 0 10px rgba(34,197,94,0)}to{transform:scale(.9);box-shadow:0 0 0 0 rgba(34,197,94,0)}}.challenge-details-panel{display:grid;grid-gap:14px;gap:14px}.challenge-page-image{width:100%;max-height:280px;object-fit:cover;border-radius:12px;border:1px solid var(--border)}.challenge-details-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.challenge-details-header h2{margin:0}.challenge-details-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:10px;gap:10px}.challenge-details-meta p{margin:0;color:var(--muted)}.challenge-active-note{display:inline-flex;align-items:center;gap:6px;margin:0}.challenge-end-button{justify-self:flex-start;padding:9px 14px}.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:14px;gap:14px}.challenge-card{position:relative;background:var(--surface-strong);border:1px solid var(--border);border-radius:14px;padding:14px;display:grid;grid-template-rows:auto auto auto 1fr auto;aspect-ratio:1/1;grid-gap:8px;gap:8px;overflow:hidden}.challenge-card-image{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:10px;border:1px solid var(--border)}.challenge-coming-soon-watermark{position:absolute;top:16px;left:-72px;z-index:2;transform:rotate(-35deg);transform-origin:center;background:rgba(245,158,11,.9);color:#1f1300;font-weight:700;font-size:.74rem;letter-spacing:.02em;min-width:230px;text-align:center;padding:6px 14px;border:0;-webkit-clip-path:polygon(8% 0,100% 0,92% 100%,0 100%);clip-path:polygon(8% 0,100% 0,92% 100%,0 100%);box-shadow:0 6px 14px rgba(0,0,0,.35);pointer-events:none}.challenge-card h4{margin:0}.challenge-card p{margin:0;color:var(--muted);min-height:0;overflow:hidden}.card-top{display:flex;justify-content:space-between;align-items:center}.badge{font-size:.74rem;text-transform:uppercase;border-radius:999px;border:1px solid var(--border);padding:3px 9px}.difficulty-badge{border-color:transparent}.difficulty-1{background:rgba(34,197,94,.2);color:#86efac}.difficulty-2{background:rgba(59,130,246,.2);color:#93c5fd}.difficulty-3{background:rgba(245,158,11,.22);color:#fcd34d}.difficulty-4{background:rgba(239,68,68,.22);color:#fca5a5}.muted{color:var(--muted)}.challenge-markdown{color:var(--text)}.challenge-markdown ol,.challenge-markdown p,.challenge-markdown ul{margin:0 0 10px}.challenge-markdown code{background:rgba(7,13,33,.9);border:1px solid var(--border);border-radius:6px;padding:1px 5px}.guide-content{display:grid;grid-gap:12px;gap:12px}.guide-content h1{margin:0}.guide-content p,.guide-content ul{margin:0;line-height:1.9}.guide-content ul{padding-right:20px;color:var(--text)}.table-wrap{overflow-x:auto;direction:rtl}table{width:100%;border-collapse:collapse}td,th{border-bottom:1px solid var(--border);text-align:right;padding:11px 9px;font-size:.9rem}.empty-state-cell{text-align:center}.challenge-name-cell{display:inline-flex;align-items:center;gap:6px}.challenge-icon{color:#facc15;flex-shrink:0}.auth-layout{display:grid;grid-template-columns:1fr .9fr;grid-gap:18px;gap:18px}.auth-brand p{margin:0;color:var(--muted)}.auth-brand h1{margin:6px 0 10px}.auth-feature-list{margin:16px 0 0;padding-left:18px;color:var(--muted);display:grid;grid-gap:8px;gap:8px}.auth-form-wrap{background:rgba(8,15,36,.75);border:1px solid var(--border);border-radius:16px;padding:18px}@media (max-width:980px){.auth-layout,.dashboard-grid,.hero-grid{grid-template-columns:1fr}}@media (max-width:1024px){.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:640px){.card-grid{grid-template-columns:1fr}}.status-running{color:#a8ffd9}.status-failed{color:#ffd3de}.status-terminated{color:#f8bfcc}.status-badge-cell{display:inline-flex;align-items:center;gap:5px}@keyframes spin{to{transform:rotate(1turn)}}.status-spinner{animation:spin 1s linear infinite;flex-shrink:0}.hero-logout-btn{align-self:center}.error-banner{margin:0;padding:11px 12px;background:rgba(255,125,156,.15)}.error-banner,.error-toast{border:1px solid rgba(255,125,156,.5);border-radius:12px;color:#ffdce7}.error-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:100;max-width:min(420px,calc(100vw - 32px));padding:12px 16px;background:rgba(20,10,18,.96);box-shadow:0 12px 40px rgba(0,0,0,.45);text-align:center}.keycloak-login-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 18px;border-radius:10px;border:1px solid rgba(97,112,255,.5);background:rgba(97,112,255,.15);color:var(--text);font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s;margin-bottom:4px}.keycloak-login-btn:hover{background:rgba(97,112,255,.3);border-color:rgba(97,112,255,.8)}.auth-divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.85rem;margin:12px 0}.auth-divider:after,.auth-divider:before{content:"";flex:1 1;height:1px;background:var(--border)}