.code-love-landing{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#fff;color:#222;min-height:100vh;display:flex;flex-direction:column}.cl-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 6vw;border-bottom:1px solid #f0f0f0}.cl-logo{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.25rem}.cl-logo-heart{font-size:1.1rem}.cl-logo-text{letter-spacing:.03em}.cl-nav{display:flex;gap:1.5rem;font-size:.95rem}.cl-nav a{text-decoration:none;color:#555}.cl-nav a:hover{text-decoration:underline}.cl-main{flex:1}.cl-hero{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:3rem;padding:4rem 6vw;align-items:center}.cl-hero-text h1{font-size:2.8rem;margin-bottom:1rem}.cl-hero-text p{margin-bottom:.9rem;line-height:1.6}.cl-cta-group{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.cl-btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:999px;border:1px solid #222222;font-size:.95rem;text-decoration:none;cursor:pointer}.cl-btn-primary{background:#222;color:#fff}.cl-btn-primary:hover{opacity:.9}.cl-btn-ghost{background:#fff;color:#222}.cl-btn-ghost:hover{background:#f5f5f5}.cl-hero-characters{display:flex;flex-direction:column;gap:1.5rem}.cl-character-card{position:relative;padding:1rem 1rem 1.5rem;border-radius:1.25rem;border:1px solid #f0f0f0;box-shadow:0 10px 30px #0000000a;background:#fff}.cl-character-img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid #eeeeee}.cl-speech-bubble{margin-top:.75rem;padding:.75rem 1rem;border-radius:1rem;background:#fafafa;border:1px solid #eeeeee;font-size:.85rem;position:relative}.cl-speech-bubble.jean pre{margin:0;font-family:Fira Code,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.8rem;white-space:pre-wrap}.cl-speech-bubble.patrick p{margin:0}.cl-tag{margin-top:.5rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:#888}.cl-section{padding:3rem 6vw 4rem;border-top:1px solid #f5f5f5}.cl-section h2{text-align:center;font-size:1.9rem;margin-bottom:2rem}.cl-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;max-width:900px;margin:0 auto}.cl-card{padding:1.5rem;border-radius:1.25rem;border:1px solid #f3f3f3;background:#fff;box-shadow:0 6px 20px #00000008}.cl-card h3{margin-bottom:.5rem;font-size:1.1rem}.cl-card p{font-size:.95rem;line-height:1.6}.cl-bottom-cta{margin-top:2.5rem;display:flex;justify-content:center}.cl-footer{padding:1.25rem 6vw 1.75rem;text-align:center;font-size:.8rem;color:#888;border-top:1px solid #f5f5f5}.cl-footer-code{font-family:Fira Code,Menlo,Monaco,Consolas,Courier New,monospace}@media(max-width:900px){.cl-hero{grid-template-columns:minmax(0,1fr);padding-top:3rem}.cl-hero-characters{flex-direction:row;flex-wrap:wrap}}@media(max-width:720px){.cl-header{flex-direction:column;gap:.5rem}.cl-nav{gap:1rem}.cl-hero{padding:2.5rem 5vw}.cl-grid{grid-template-columns:minmax(0,1fr)}}.chapters-shell{padding:3rem 6vw;max-width:1100px;margin:0 auto;color:#111827;background:#fff}.chapters-header{margin-bottom:1.75rem}.chapters-back{display:inline-block;margin-bottom:1rem;font-size:.9rem;color:#2563eb;text-decoration:none}.chapters-back:hover{text-decoration:underline}.chapters-title{font-size:2rem;margin:0 0 .35rem}.chapters-subtitle{margin:0;color:#4b5563;font-size:.98rem}.chapters-grid{margin-top:1.5rem;display:grid;gap:1rem}.chapter-card{display:block;padding:1.25rem 1.4rem;border-radius:14px;text-decoration:none;background:#f9fafb;border:1px solid #e5e7eb;color:inherit;box-shadow:0 4px 10px #0f172a0a;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background-color .18s ease}.chapter-card:hover{transform:translateY(-2px);background:#fff;border-color:#cbd5e1;box-shadow:0 10px 24px #0f172a14}.chapter-card-top{margin-bottom:.4rem}.chapter-pill{display:inline-block;padding:.18rem .65rem;border-radius:999px;font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;background:#e5edff;color:#1d4ed8;border:1px solid #bfdbfe}.chapter-card-title{margin:.5rem 0 .35rem;font-size:1.25rem;color:#111827}.chapter-card-summary{margin:0;font-size:.96rem;line-height:1.6;color:#4b5563}.chapter-card-footer{margin-top:.75rem;display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;font-size:.85rem}.chapter-card-concept{color:#6b7280}.chapter-card-cta{color:#2563eb;font-weight:500;white-space:nowrap}.chapter-card:hover .chapter-card-cta{text-decoration:underline}@media(max-width:640px){.chapters-shell{padding:2.2rem 5vw}.chapter-card{padding:1.1rem 1.15rem}.chapter-card-footer{flex-direction:column;align-items:flex-start}}.chapter-detail{padding:3rem 6vw;max-width:1100px;margin:0 auto}.cd-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:2rem}.cd-chapter-number{text-transform:uppercase;font-size:.8rem;letter-spacing:.16em;color:#888;margin-bottom:.25rem}.cd-title{font-size:2rem;margin:0 0 .5rem}.cd-concept{margin:0;color:#555}.cd-link{text-decoration:none;font-size:.9rem;color:#2563eb}.cd-link:hover{text-decoration:underline}.cd-layout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:2.5rem}.cd-story{font-size:1rem;line-height:1.7}.cd-hero-image{width:100%;border-radius:1.25rem;margin-bottom:1.5rem}.cd-narration{margin-bottom:1rem}.cd-dialogue-row{display:flex;margin-bottom:.9rem}.cd-dialogue-row.jean{justify-content:flex-start}.cd-dialogue-row.patrick{justify-content:flex-end}.cd-dialogue-bubble{max-width:80%;padding:.75rem 1rem;border-radius:1rem;background:#f4f4f4;border:1px solid #e5e5e5;font-size:.95rem;color:#1f2933}.cd-dialogue-row.jean .cd-dialogue-bubble{background:#fff3c4;border-color:#facc6b}.cd-dialogue-row.patrick .cd-dialogue-bubble{background:#dbeafe;border-color:#93c5fd}.cd-dialogue-name{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;color:#374151;margin-bottom:.2rem}.cd-code-panel{padding:1.25rem;border-radius:1.25rem;border:1px solid #f0f0f0;background:#fafafa;font-size:.9rem;height:fit-content}.cd-code-panel h2{margin-top:0;margin-bottom:.75rem}.cd-code-block{background:#111827;color:#e5e7eb;border-radius:.75rem;padding:.9rem 1rem;overflow-x:auto;font-family:Fira Code,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.85rem;margin-bottom:1rem}.cd-explanation-list{padding-left:1.1rem}.cd-explanation-list li{margin-bottom:.4rem}.cd-footer{margin-top:2.5rem;display:flex;justify-content:space-between}@media(max-width:900px){.cd-layout{grid-template-columns:minmax(0,1fr)}.cd-footer{flex-direction:column;gap:.75rem;align-items:flex-start}}.cd-story,.cd-narration{color:#111827}.chapter-detail{background:#fff}.cd-code-panel{background:#f9fafb;border-radius:1.25rem;border:1px solid #e5e7eb;padding:1.25rem;font-size:.9rem;color:#111827}.cd-code-panel h2{margin-top:0;margin-bottom:.75rem;font-size:1rem;font-weight:600;color:#111827!important}.cd-code-block{background:#111827;color:#e5e7eb;border-radius:.75rem;padding:.9rem 1rem;font-family:Fira Code,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.85rem;margin-bottom:1rem;white-space:pre-wrap;word-break:break-word;overflow-x:auto}.cd-explanation-list{padding-left:1.1rem;margin:0}.cd-explanation-list li{margin-bottom:.4rem;color:#374151!important}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{background:#fff!important}
