@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";
:root{--bg-primary:#0a0e17;--bg-secondary:#111827;--bg-card:#1a2234;--bg-card-hover:#1f2a40;--bg-code:#0d1117;--bg-inline-code:#63b3ed1f;--bg-sidebar:#0d1321;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--text-heading:#f1f5f9;--accent-blue:#3b82f6;--accent-blue-glow:#3b82f64d;--accent-cyan:#06b6d4;--accent-purple:#8b5cf6;--accent-green:#10b981;--accent-orange:#f59e0b;--accent-red:#ef4444;--accent-pink:#ec4899;--gradient-brand:linear-gradient(135deg,#3b82f6 0%,#8b5cf6 50%,#06b6d4 100%);--gradient-card:linear-gradient(135deg,#3b82f614 0%,#8b5cf60f 100%);--gradient-hero:linear-gradient(180deg,#3b82f61f 0%,transparent 60%);--border-color:#94a3b81f;--border-active:#3b82f680;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-glow:0 0 30px #3b82f626;--sidebar-width:280px;--content-max-width:880px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.7}a{color:var(--accent-blue);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-cyan)}h1,h2,h3,h4,h5,h6{color:var(--text-heading);font-weight:700;line-height:1.3}h1{margin-bottom:1rem;font-size:2.2rem}h2{margin-top:2.5rem;margin-bottom:.75rem;font-size:1.65rem}h3{margin-top:2rem;margin-bottom:.5rem;font-size:1.3rem}h4{margin-top:1.5rem;margin-bottom:.4rem;font-size:1.1rem}p{color:var(--text-secondary);margin-bottom:1rem}strong{color:var(--text-primary);font-weight:600}.page-wrapper{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);max-width:calc(var(--content-max-width) + 6rem);flex:1;padding:2.5rem 3rem}@media (max-width:900px){.main-content{margin-left:0;padding:1.5rem}}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);z-index:100;flex-direction:column;height:100vh;padding:1.5rem 0;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding:.5rem 1.5rem 1.5rem}.sidebar-logo h2{background:var(--gradient-brand);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.1rem;font-weight:800}.sidebar-logo span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:2px;font-size:.72rem;display:block}.sidebar-section{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);padding:.6rem 1.5rem .3rem;font-size:.68rem;font-weight:600}.sidebar-link{color:var(--text-secondary);border-left:3px solid #0000;align-items:center;gap:.7rem;padding:.55rem 1.5rem;font-size:.88rem;font-weight:450;text-decoration:none;transition:all .2s;display:flex}.sidebar-link:hover{color:var(--text-primary);background:#3b82f60f}.sidebar-link.active{color:var(--accent-blue);border-left-color:var(--accent-blue);background:#3b82f61a;font-weight:550}.sidebar-link .module-number{width:22px;height:22px;color:var(--accent-blue);background:#3b82f61f;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex}.sidebar-link.active .module-number{background:var(--accent-blue);color:#fff}@media (max-width:900px){.sidebar{display:none}}.landing{max-width:1200px;margin:0 auto;padding:3rem 2rem}.hero{text-align:center;padding:4rem 0 3rem;position:relative}.hero:before{content:"";pointer-events:none;z-index:-1;background:radial-gradient(#3b82f626 0%,#0000 70%);width:600px;height:400px;position:absolute;top:-100px;left:50%;transform:translate(-50%)}.hero-badge{color:var(--accent-blue);background:#3b82f61a;border:1px solid #3b82f640;border-radius:100px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.35rem 1rem;font-size:.78rem;font-weight:500;display:inline-flex}.hero h1{letter-spacing:-.03em;margin-bottom:1.2rem;font-size:3.2rem;font-weight:800;line-height:1.15}.hero h1 .gradient-text{background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero p{max-width:640px;color:var(--text-secondary);margin:0 auto 2rem;font-size:1.15rem}.hero-cta{background:var(--gradient-brand);color:#fff;border-radius:12px;align-items:center;gap:.5rem;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:all .3s;display:inline-flex;box-shadow:0 4px 20px #3b82f64d}.hero-cta:hover{color:#fff;transform:translateY(-2px);box-shadow:0 6px 30px #3b82f666}.modules-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem;margin-top:2rem;display:grid}.module-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.8rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:block;position:relative;overflow:hidden}.module-card:before{content:"";background:var(--gradient-brand);opacity:0;height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.module-card:hover{border-color:var(--border-active);box-shadow:var(--shadow-glow);transform:translateY(-4px)}.module-card:hover:before{opacity:1}.module-card-header{align-items:center;gap:1rem;margin-bottom:.8rem;display:flex}.module-card-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.module-card-title{color:var(--text-heading);margin:0;font-size:1.1rem;font-weight:700}.module-card-number{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-top:2px;font-size:.7rem;font-weight:600}.module-card p{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.6}.module-card-tags{flex-wrap:wrap;gap:.4rem;margin-top:1rem;display:flex}.tag{color:var(--accent-cyan);background:#63b3ed14;border:1px solid #63b3ed26;border-radius:100px;padding:.2rem .6rem;font-size:.7rem;font-weight:500}.module-page{max-width:var(--content-max-width)}.module-header{border-bottom:1px solid var(--border-color);margin-bottom:2.5rem;padding-bottom:2rem}.module-header .module-number-label{text-transform:uppercase;letter-spacing:.1em;color:var(--accent-blue);margin-bottom:.5rem;font-size:.78rem;font-weight:600}.module-header h1{margin-bottom:.8rem}.module-header .module-description{color:var(--text-secondary);margin:0;font-size:1.1rem;line-height:1.6}.section{margin-bottom:3rem}.section-divider{border:none;border-top:1px solid var(--border-color);margin:3rem 0}.code-block{background:var(--bg-code);border:1px solid var(--border-color);border-radius:var(--radius-md);margin:1.2rem 0;overflow:hidden}.code-block-header{border-bottom:1px solid var(--border-color);background:#ffffff08;justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex}.code-block-lang{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.72rem;font-weight:600}.code-block-filename{color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:.78rem}.code-block pre{color:var(--text-primary);margin:0;padding:1rem 1.2rem;font-family:JetBrains Mono,monospace;font-size:.84rem;line-height:1.7;overflow-x:auto}code{font-family:JetBrains Mono,monospace}:not(pre)>code{background:var(--bg-inline-code);color:var(--accent-cyan);border-radius:5px;padding:.15rem .45rem;font-size:.88em;font-weight:450}.callout{border-radius:var(--radius-md);border-left:4px solid;margin:1.5rem 0;padding:1.2rem 1.4rem;font-size:.92rem}.callout p{color:inherit;margin:0}.callout-title{text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:.5rem;margin-bottom:.4rem;font-size:.82rem;font-weight:700;display:flex}.callout.azure{border-color:var(--accent-blue);color:#93c5fd;background:#3b82f614}.callout.azure .callout-title{color:var(--accent-blue)}.callout.tip{border-color:var(--accent-green);color:#6ee7b7;background:#10b98114}.callout.tip .callout-title{color:var(--accent-green)}.callout.warning{border-color:var(--accent-orange);color:#fcd34d;background:#f59e0b14}.callout.warning .callout-title{color:var(--accent-orange)}.callout.info{border-color:var(--accent-purple);color:#c4b5fd;background:#8b5cf614}.callout.info .callout-title{color:var(--accent-purple)}.demo-box{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid #10b98140;margin:2rem 0;overflow:hidden}.demo-box-header{background:#10b98114;border-bottom:1px solid #10b98126;align-items:center;gap:.7rem;padding:.9rem 1.4rem;display:flex}.demo-box-header .demo-icon{font-size:1.1rem}.demo-box-header h4{color:var(--accent-green);margin:0;font-size:.95rem;font-weight:700}.demo-box-content{padding:1.4rem}.demo-box-content p{margin-bottom:.8rem}.table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border-color);margin:1.2rem 0;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.88rem}thead{background:#3b82f60f}th{text-align:left;color:var(--text-heading);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.04em;padding:.7rem 1rem;font-size:.82rem;font-weight:600}td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:.65rem 1rem}tr:last-child td{border-bottom:none}tr:hover td{background:#3b82f608}.concept-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin:1.2rem 0;display:grid}.concept-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.2rem;transition:border-color .2s}.concept-card:hover{border-color:var(--border-active)}.concept-card h4{align-items:center;gap:.5rem;margin:0 0 .4rem;font-size:.95rem;display:flex}.concept-card p{margin:0;font-size:.85rem;line-height:1.55}.step-list{counter-reset:step-counter;margin:1rem 0;padding:0;list-style:none}.step-list li{counter-increment:step-counter;border-left:2px solid var(--border-color);color:var(--text-secondary);margin-left:.9rem;padding:.8rem 0 .8rem 3rem;font-size:.92rem;position:relative}.step-list li:before{content:counter(step-counter);background:var(--bg-primary);border:2px solid var(--accent-blue);width:26px;height:26px;color:var(--accent-blue);border-radius:50%;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex;position:absolute;top:.7rem;left:-14px}.step-list li:last-child{border-left-color:#0000}.module-progress{align-items:center;gap:.4rem;margin-top:1rem;display:flex}.module-progress-dot{background:#3b82f633;border-radius:2px;width:28px;height:4px;transition:background .3s}.module-progress-dot.active{background:var(--accent-blue)}.module-progress-dot.completed{background:var(--accent-green)}.module-nav{border-top:1px solid var(--border-color);justify-content:space-between;gap:1rem;margin-top:3rem;padding-top:2rem;display:flex}.module-nav-link{border:1px solid var(--border-color);border-radius:var(--radius-md);flex-direction:column;max-width:50%;padding:1rem 1.5rem;text-decoration:none;transition:all .2s;display:flex}.module-nav-link:hover{border-color:var(--border-active);background:#3b82f60a}.module-nav-link .nav-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.2rem;font-size:.72rem;font-weight:600}.module-nav-link .nav-title{color:var(--accent-blue);font-size:.95rem;font-weight:600}.module-nav-link.next{text-align:right;margin-left:auto}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#94a3b833;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b859}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:.5s ease-out forwards fadeIn}.animate-in:first-child{animation-delay:50ms}.animate-in:nth-child(2){animation-delay:.1s}.animate-in:nth-child(3){animation-delay:.15s}.animate-in:nth-child(4){animation-delay:.2s}.animate-in:nth-child(5){animation-delay:.25s}.animate-in:nth-child(6){animation-delay:.3s}.animate-in:nth-child(7){animation-delay:.35s}.section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:1rem;font-size:.75rem;font-weight:700}ul.bullet-list{margin:.8rem 0;padding-left:1.2rem}ul.bullet-list li{color:var(--text-secondary);margin-bottom:.4rem;font-size:.92rem}ul.bullet-list li::marker{color:var(--accent-blue)}
