:root{--rust: #c2461c;--rust-bright: #d2502a;--brown: #322b27;--brown-deep: #1f1b1a;--ink: #2c2722;--muted: #8c8278;--rule: #e7e1d6;--altrow: #f4f0e8}*{box-sizing:border-box}body{margin:0;font-family:"Source Sans 3",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-size:17px;line-height:1.65;color:var(--ink);background:#fff;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.wrap{width:100%;max-width:920px;margin:0 auto;padding:0 20px;padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right))}main.wrap{flex:1 0 auto}html{background:linear-gradient(rgba(31,27,26,.79), rgba(31,27,26,.79)),url("/textures/paper.png"),#1f1b1a;background-blend-mode:normal,hard-light,normal}body::before{content:"";position:fixed;top:0;left:0;right:0;height:env(safe-area-inset-top);background:linear-gradient(rgba(31,27,26,.79), rgba(31,27,26,.79)),url("/textures/paper.png"),#1f1b1a;background-blend-mode:normal,hard-light,normal;pointer-events:none;z-index:100}body::after{content:"";position:fixed;bottom:-100vh;left:0;right:0;height:100vh;background:#fff;pointer-events:none}.site-header{position:relative;background:var(--brown-deep);border-bottom:4px solid var(--rust-bright);padding:22px 0;padding-top:calc(22px + env(safe-area-inset-top))}.site-header::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.21;mix-blend-mode:hard-light;background-image:url("/textures/paper.png")}.header-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px 16px}.brand{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}.logo{font-family:"Zilla Slab",Rockwell,"Roboto Slab",serif;font-size:27px;font-weight:700;color:#f4ede4;text-decoration:none}.logo .logo-rust{color:var(--rust-bright)}.logo .logo-tld{color:#c9bfb4}.site-nav{display:flex;align-items:center;gap:18px}.site-nav a{color:#d8cfc4;text-decoration:none;font-size:16px;font-weight:500;white-space:nowrap}.site-nav a:hover{color:#fff;text-decoration:underline}.nav-search{display:flex;align-items:center;margin:0}.nav-search input{display:block;margin:0;-webkit-appearance:none;appearance:none;background:#2e2925;border:1px solid #5a524c;border-radius:5px;color:#fff;font-size:14px;padding:5px 10px;width:140px}.nav-search input::placeholder{color:#9a918a}.nav-search input:focus{outline:2px solid #ce422b;border-color:#ce422b}.site-title{font-family:"Zilla Slab",Rockwell,"Roboto Slab",serif;font-size:34px;font-weight:700;color:var(--ink);margin:34px 0 0 0;line-height:1.2}.site-intro{margin:14px 0 28px 0;font-size:17px;line-height:1.62;color:#41382f;max-width:740px}.site-intro-more{margin:-16px 0 28px 0;max-width:740px}.site-intro-more summary{cursor:pointer;font-size:15px;color:var(--rust)}.site-intro-more summary:hover{color:var(--rust-bright)}.site-intro-more .site-intro{margin:12px 0 0 0}.chapter{margin:26px 0 0 0}.chapter-bar{position:relative;display:flex;align-items:baseline;gap:14px;background:var(--brown);color:#fff;padding:13px 20px 13px 22px;border-radius:3px 3px 0 0;border-left:6px solid var(--rust-bright)}.chapter-bar::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;opacity:.21;mix-blend-mode:hard-light;background-image:url("/textures/paper.png")}.chapter-num{font-weight:700;color:var(--rust-bright);text-transform:uppercase;font-size:13px;letter-spacing:.14em;white-space:nowrap}.chapter-name{font-family:"Zilla Slab",Rockwell,"Roboto Slab",serif;font-weight:600;font-size:19px;color:#fff;min-width:0;overflow-wrap:break-word}.lesson-list{list-style:none;margin:0;padding:0;border:1px solid var(--rule);border-top:none;border-radius:0 0 3px 3px;overflow:hidden}.lesson-row{display:grid;grid-template-columns:64px 1fr;align-items:center;min-height:45px;border-top:1px solid var(--rule)}.lesson-row:first-child{border-top:none}.lesson-row:nth-child(even){background:var(--altrow)}.lesson-row:hover{background:#fbeee6}.lesson-row .lesson-num{padding-left:22px;font-size:15px;color:var(--muted);font-variant-numeric:tabular-nums}.lesson-row a{color:var(--rust);font-size:16.5px;font-weight:500;text-decoration:none;padding:6px 16px 6px 0}.lesson-row a:hover{text-decoration:underline}.lesson-title{margin:30px 0 4px 0;font-size:30px;line-height:1.25}.lesson-title-num{color:#ce422b;margin-right:14px;font-weight:700}.lesson-meta{color:#7a736c;font-size:14px;margin:0 0 26px 0;padding-bottom:14px;border-bottom:1px solid #e5ded7}.lesson a{color:#b7410e}.lesson a:hover{color:#9c3217}.lesson h2{font-size:23px;margin-top:36px}.lesson h3{font-size:19px;margin-top:28px}.lesson blockquote{margin:1em 0;padding:2px 18px;border-left:4px solid #e5ded7;color:#7a736c}.lesson table{border-collapse:collapse;margin:1em 0}.lesson table th,.lesson table td{border:1px solid #e5ded7;padding:6px 12px}.lesson table th{background:#f6f2ee}.lesson img{max-width:100%}code{font-family:ui-monospace,"SF Mono","Cascadia Code",Menlo,Consolas,monospace;font-size:.92em}:not(pre)>code{background:#f6f2ee;border:1px solid #e5ded7;border-radius:4px;padding:1px 5px}pre{padding:14px 16px;border-radius:6px;border:1px solid #e5ded7;overflow-x:auto;line-height:1.5}pre code{font-size:14px}.giallo-l{display:inline-block;min-height:1lh;width:100%}.giallo-ln{display:inline-block;user-select:none;margin-right:.4em;padding:.4em;min-width:3ch;text-align:right;opacity:.8}.callout{position:relative;border:1px solid;border-left-width:5px;border-radius:6px;padding:12px 18px;margin:1.2em 0}.callout::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;opacity:.685;mix-blend-mode:multiply;background-image:url("/textures/paper.png")}.callout .callout-title{font-weight:700;margin:0 0 4px 0}.callout p:last-child{margin-bottom:0}.callout-note{border-color:#9db7cf;background:#f2f7fb}.callout-note .callout-title{color:#2b5d8c}.callout-tip{border-color:#9fc9b8;background:#f1faf6}.callout-tip .callout-title{color:#1e7a55}.callout-best{border-color:#8fbf8f;background:#f2f9f0}.callout-best .callout-title{color:#2e7d32}.callout-warning{border-color:#e0a37e;background:#fdf3ec}.callout-warning .callout-title{color:#b34700}.callout-advanced{border-color:#b3a4cf;background:#f7f4fb}.callout-advanced .callout-title{color:#5e4b8b}.callout-author{border-color:#d2c3a5;background:#faf6ec}.callout-author .callout-title{color:#7a6233}details.solution{position:relative;margin:1em 0;border:1px solid #e5ded7;border-radius:6px;padding:10px 16px;background:#f6f2ee}details.solution::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;opacity:.685;mix-blend-mode:multiply;background-image:url("/textures/paper.png")}details.solution summary{cursor:pointer;font-weight:600;color:#b7410e}details.solution[open] summary{margin-bottom:8px}.lesson-nav{display:flex;flex-wrap:wrap;gap:10px;margin:34px 0 10px 0}.btn{display:inline-flex;flex-direction:column;gap:1px;padding:9px 16px;border-radius:6px;text-decoration:none;font-size:14px;line-height:1.35;border:1px solid #ce422b}.btn strong{font-size:14px}.btn span{font-size:13px;opacity:.9}.btn-next{background:#ce422b;color:#fff}.btn-next:hover{background:#9c3217;border-color:#9c3217}.btn-prev,.btn-toc{color:#b7410e;background:#fff;justify-content:center}.btn-prev:hover,.btn-toc:hover{background:#f6f2ee}.btn-disabled{color:#7a736c;border-color:#e5ded7;justify-content:center}.site-footer{margin-top:50px;border-top:1px solid #e5ded7;color:#7a736c;font-size:14px;padding:18px 0}.search-input{width:100%;font-size:17px;padding:10px 14px;border:1px solid #e5ded7;border-radius:6px;margin:4px 0 18px 0}.search-input:focus{outline:2px solid #ce422b}.search-results{list-style:none;margin:0;padding:0}.search-results li{padding:12px 0;border-bottom:1px solid #e5ded7}.search-results li a{color:#b7410e;font-weight:600;text-decoration:none}.search-results li a:hover{text-decoration:underline}.search-results li p{margin:4px 0 0 0;color:#7a736c;font-size:15px}.search-results .no-results{color:#7a736c}@media (max-width: 600px){body{font-size:16px}.lesson-title{font-size:24px}.lesson-nav{flex-direction:column}.site-header{padding:14px 0 12px}.site-nav{width:100%;gap:14px}.nav-search{flex:1;min-width:0}.nav-search input{width:100%;font-size:16px;}}