*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}:root{--paper:#f4efe6;--paper-dark:#e8e1d4;--paper-light:#faf7f2;--ink:#1e1e1e;--ink-light:#4a4a4a;--ink-faint:#8a8580;--ink-faintest:#b8b3ae;--accent-blue:#2d5fa8;--accent-red:#b83232;--accent-green:#2a6e48;--accent-orange:#c4680a;--accent-purple:#5e3d8a;--highlight:#fff59d;--highlight-blue:#d6e8ff;--highlight-green:#d4edda;--font-hand:"Architects Daughter",cursive;--font-header:"Permanent Marker",cursive;--font-accent:"Caveat",cursive;--font-body:"Patrick Hand",cursive;--font-light:"Shadows Into Light",cursive;--sketch-radius:255px 15px 225px 15px/15px 225px 15px 255px;--sketch-radius-alt:15px 225px 15px 255px/255px 15px 225px 15px;--sketch-radius-sm:42px 8px 38px 8px/8px 38px 8px 42px}body{font-family:var(--font-body);background:var(--paper);color:var(--ink);line-height:1.6;overflow-x:hidden;position:relative;min-height:100vh}body:before{z-index:9999;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.06'/%3E%3C/svg%3E");opacity:.25}body:after,body:before{content:"";position:fixed;inset:0;pointer-events:none}body:after{z-index:9998;background-image:repeating-linear-gradient(180deg,transparent,transparent 27px,rgba(160,180,220,.12) 0,rgba(160,180,220,.12) 28px)}svg.defs-only{position:absolute;width:0;height:0;overflow:hidden}h1{font-size:2.2rem}h1,h2{font-family:var(--font-header)}h2{font-size:1.7rem}h3{font-family:var(--font-accent);font-size:1.45rem;font-weight:700}h4{font-family:var(--font-hand);font-size:1.05rem}a{color:var(--accent-blue);text-decoration:none}a:hover{color:var(--accent-red)}.container{max-width:1240px;margin:0 auto;padding:0 24px}.sketch-box{border:2px solid var(--ink);border-radius:var(--sketch-radius);position:relative}.sketch-box-sm{border:1.5px solid var(--ink-light);border-radius:var(--sketch-radius-sm)}.sketch-underline{position:relative;display:inline-block}.sketch-underline:after{content:"";position:absolute;bottom:-5px;left:-2px;width:calc(100% + 4px);height:3px;background:var(--ink);border-radius:40% 60% 50% 40%;transform:rotate(-.5deg)}.highlight{background:var(--highlight);padding:1px 5px;border-radius:3px 8px 5px 10px}@keyframes boil{0%{transform:translate(0) rotate(0)}25%{transform:translate(.4px,-.4px) rotate(.25deg)}50%{transform:translate(-.3px,.3px) rotate(-.15deg)}75%{transform:translate(.3px,.4px) rotate(.1deg)}to{transform:translate(0) rotate(0)}}.boil{animation:boil .15s infinite}.boil-slow{animation:boil .45s infinite}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.anim-in{animation:fadeInUp .45s ease forwards;opacity:0}.anim-delay-1{animation-delay:.08s}.anim-delay-2{animation-delay:.16s}.anim-delay-3{animation-delay:.24s}.anim-delay-4{animation-delay:.32s}.anim-delay-5{animation-delay:.4s}.topbar{background:var(--ink);color:var(--paper);font-family:var(--font-light);font-size:.82rem;letter-spacing:1.5px;text-align:center;padding:6px 0}.navbar{position:-webkit-sticky;position:sticky;top:0;z-index:500;background:var(--paper);border-bottom:2.5px solid var(--ink);padding:10px 0;box-shadow:0 2px 0 rgba(0,0,0,.04)}.navbar .container{display:flex;align-items:center;justify-content:space-between;gap:16px}.navbar-brand{gap:10px;cursor:pointer}.brand-logo,.navbar-brand{display:flex;align-items:center}.brand-logo{width:40px;height:40px;border:2.5px solid var(--ink);border-radius:var(--sketch-radius-sm);justify-content:center;font-family:var(--font-header);font-size:1.3rem;background:var(--paper);position:relative;flex-shrink:0}.brand-logo canvas{position:absolute;top:0;left:0;pointer-events:none}.brand-text{font-family:var(--font-header);font-size:1.25rem;letter-spacing:.5px;white-space:nowrap}.brand-text span{color:var(--accent-red)}.nav-links{display:flex;align-items:center;gap:2px;list-style:none}.nav-links a{font-family:var(--font-hand);font-size:.95rem;padding:5px 14px;border-radius:var(--sketch-radius-sm);color:var(--ink);border:1.5px solid transparent;transition:all .18s;display:block;cursor:pointer}.nav-links a.active,.nav-links a:hover{border-color:var(--ink);background:var(--highlight);transform:rotate(-1deg);color:var(--ink)}.nav-links a:after{display:none}.nav-actions{display:flex;align-items:center;gap:10px}.nav-submit-btn{padding:6px 18px;border:2px solid var(--accent-green);border-radius:var(--sketch-radius-sm);background:transparent;color:var(--accent-green);cursor:pointer;transition:all .18s;white-space:nowrap}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px}.nav-toggle svg{width:26px;height:26px}.location-bar{background:var(--paper-dark);border-bottom:1.5px dashed var(--ink-faint);padding:7px 0;font-family:var(--font-light);font-size:.88rem}.location-bar .container{display:flex;align-items:center;gap:10px}.loc-badge{font-family:var(--font-hand);font-size:.75rem;color:var(--ink-faint);border:1px solid var(--ink-faintest);border-radius:var(--sketch-radius-sm);padding:2px 8px;white-space:nowrap}.loc-input{flex:1 1;background:var(--paper-light);border:1.5px solid var(--ink-faintest);border-radius:var(--sketch-radius-sm);padding:4px 12px;font-family:var(--font-body);font-size:.88rem;color:var(--ink-light);outline:none;transition:border-color .2s}.loc-input:focus{border-color:var(--ink)}.section{display:none;padding:36px 0 60px;min-height:70vh}.section.active{display:block}.section-header{text-align:center;margin-bottom:36px}.section-header p{font-family:var(--font-accent);font-size:1.1rem;color:var(--ink-light);margin-top:6px}.archive-layout{display:grid;grid-template-columns:260px 1fr;grid-gap:32px;gap:32px;align-items:start}.sidebar{position:-webkit-sticky;position:sticky;top:90px}.sidebar-section{margin-bottom:20px}.sidebar-section h4{margin-bottom:8px;padding-bottom:5px;border-bottom:1.5px dashed var(--ink-faint);font-family:var(--font-accent);font-size:1.1rem}.sidebar-stats{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;margin-bottom:12px}.stat-card{text-align:center;padding:10px 6px;border:1.5px solid var(--ink-light);border-radius:var(--sketch-radius-sm);background:var(--paper-light)}.stat-card .stat-num{font-family:var(--font-header);font-size:1.5rem;display:block;line-height:1.2}.stat-card .stat-label{font-family:var(--font-light);font-size:.72rem;color:var(--ink-faint)}.search-box{position:relative;margin-bottom:14px}.search-box input{width:100%;padding:9px 14px 9px 38px;border:2px solid var(--ink);border-radius:var(--sketch-radius);background:var(--paper-light);font-family:var(--font-body);font-size:.95rem;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}.search-box input:focus{border-color:var(--accent-blue);box-shadow:0 2px 8px rgba(45,95,168,.1)}.search-icon-abs{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--ink-faint)}.type-pills{display:flex;flex-wrap:wrap;gap:5px}.type-pill{font-family:var(--font-hand);font-size:.8rem;padding:3px 11px;border:1.5px solid;border-radius:var(--sketch-radius-sm);cursor:pointer;transition:all .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.type-pill.paper{border-color:rgba(94,61,138,.4);color:var(--accent-purple)}.type-pill.paper.on{background:rgba(94,61,138,.12);border-color:var(--accent-purple)}.type-pill.code{border-color:rgba(42,110,72,.4);color:var(--accent-green)}.type-pill.code.on{background:rgba(42,110,72,.12);border-color:var(--accent-green)}.type-pill.dataset{border-color:rgba(196,104,10,.4);color:var(--accent-orange)}.type-pill.dataset.on{background:rgba(196,104,10,.12);border-color:var(--accent-orange)}.type-pill.blog{border-color:rgba(45,95,168,.4);color:var(--accent-blue)}.type-pill.blog.on{background:rgba(45,95,168,.12);border-color:var(--accent-blue)}.level-pill{font-family:var(--font-hand);font-size:.8rem;padding:3px 11px;border:1.5px solid var(--ink-faintest);border-radius:var(--sketch-radius-sm);cursor:pointer;transition:all .15s;color:var(--ink-light);-webkit-user-select:none;-moz-user-select:none;user-select:none}.level-pill.on{border-color:var(--ink);color:var(--ink);background:var(--highlight)}.topic-list{list-style:none}.topic-list li{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;border-bottom:1px dashed var(--ink-faintest);cursor:pointer;font-size:.9rem;transition:all .15s;border-radius:3px}.topic-list li:hover{background:rgba(255,245,157,.5);transform:translateX(3px)}.topic-list li.active{background:var(--highlight);font-weight:700}.topic-list li .count{font-family:var(--font-accent);font-size:.95rem;color:var(--ink-faint);min-width:28px;text-align:right}.archive-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;padding-bottom:12px;border-bottom:1.5px dashed var(--ink-faint);gap:12px;flex-wrap:wrap}.toolbar-info{font-family:var(--font-accent);font-size:1.05rem;color:var(--ink-light)}.toolbar-info strong{color:var(--ink)}.toolbar-actions{display:flex;gap:7px;align-items:center}.sort-btn{font-family:var(--font-hand);font-size:.82rem;border:1.5px solid var(--ink-faint);border-radius:var(--sketch-radius-sm);padding:4px 12px;background:var(--paper);cursor:pointer;transition:all .15s;color:var(--ink-light)}.sort-btn.active,.sort-btn:hover{border-color:var(--ink);background:var(--highlight);color:var(--ink)}.resource-grid{display:grid;grid-gap:14px;gap:14px}.resource-card{border:2px solid var(--ink-light);border-radius:var(--sketch-radius);padding:16px 18px 14px;background:var(--paper-light);display:grid;grid-template-columns:1fr auto;grid-gap:12px;gap:12px;align-items:start;transition:all .2s;position:relative;cursor:pointer}.resource-card:hover{border-color:var(--ink);transform:translateY(-2px) rotate(-.25deg);box-shadow:3px 5px 0 var(--ink-faintest)}.rc-type-badge{position:absolute;top:-10px;left:16px;font-family:var(--font-accent);font-size:.75rem;background:var(--paper-light);padding:1px 10px;border:1.5px solid;border-radius:4px;font-weight:600}.rc-type-badge.paper{color:var(--accent-purple);border-color:var(--accent-purple)}.rc-type-badge.code{color:var(--accent-green);border-color:var(--accent-green)}.rc-type-badge.dataset{color:var(--accent-orange);border-color:var(--accent-orange)}.rc-type-badge.blog{color:var(--accent-blue);border-color:var(--accent-blue)}.rc-body h4{font-family:var(--font-hand);font-size:1.05rem;margin-bottom:5px;line-height:1.3}.rc-body .rc-desc{font-size:.88rem;color:var(--ink-light);margin-bottom:9px;line-height:1.45}.rc-tags{display:flex;flex-wrap:wrap;gap:4px}.rc-tag{font-family:var(--font-light);font-size:.7rem;padding:2px 8px;border:1px solid var(--ink-faintest);border-radius:20px;color:var(--ink-faint)}.rc-meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px;min-width:90px}.rc-level{font-family:var(--font-light);font-size:.72rem;padding:2px 10px;border-radius:20px;white-space:nowrap}.rc-level.beginner{background:#d4edda;color:#155724}.rc-level.intermediate{background:#fff3cd;color:#856404}.rc-level.advanced{background:#f8d7da;color:#721c24}.rc-year{font-family:var(--font-accent);font-size:.9rem}.rc-venue,.rc-year{color:var(--ink-faint)}.rc-venue{font-family:var(--font-light);font-size:.72rem;text-align:right}.rc-open-link{font-family:var(--font-accent);font-size:.88rem;color:var(--accent-blue);margin-top:2px}.resource-card:hover .rc-open-link{color:var(--accent-red)}.empty-state{padding:60px 20px;text-align:center;border:2px dashed var(--ink-faint);border-radius:var(--sketch-radius);color:var(--ink-light)}.empty-state h3{margin-bottom:8px}.roadmap-top{display:grid;grid-template-columns:1fr 1fr;grid-gap:28px;gap:28px;margin-bottom:32px}.roadmap-progress-card{border:2px solid var(--ink);border-radius:var(--sketch-radius);padding:24px;background:var(--paper-light);text-align:center}.roadmap-progress-card h3{margin-bottom:18px}.progress-ring-wrap{display:flex;align-items:center;justify-content:center;gap:24px}.progress-ring-wrap canvas{display:block}.progress-stats{text-align:left}.progress-stat{margin-bottom:8px}.progress-stat .ps-num{font-family:var(--font-header);font-size:1.8rem;display:block;line-height:1}.progress-stat .ps-label{font-family:var(--font-light);font-size:.78rem;color:var(--ink-faint)}.learning-curve-card{border:2px solid var(--ink);border-radius:var(--sketch-radius);padding:20px;background:var(--paper-light)}.learning-curve-card h3{margin-bottom:12px;text-align:center}.learning-curve-card canvas{width:100%;max-width:100%}.chart-caption{font-family:var(--font-light);font-size:.78rem;color:var(--ink-faint);text-align:center;margin-top:6px}.mastery-section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.mastery-section-hdr h3{font-family:var(--font-header)}.mastery-summary{font-family:var(--font-accent);font-size:1.05rem;color:var(--ink-light);border:1.5px dashed var(--ink-faint);padding:3px 14px;border-radius:var(--sketch-radius-sm)}.mastery-table{width:100%;border-collapse:separate;border-spacing:0;border:2px solid var(--ink);border-radius:12px;overflow:hidden}.mastery-table thead th{background:var(--paper-dark);font-family:var(--font-hand);font-size:.9rem;padding:10px 14px;text-align:left;border-bottom:2px solid var(--ink);letter-spacing:.02em}.mastery-table tbody td{padding:10px 14px;border-bottom:1px dashed var(--ink-faintest);font-size:.88rem;vertical-align:middle}.mastery-table tbody tr:last-child td{border-bottom:none}.mastery-table tbody tr:hover{background:rgba(255,245,157,.4)}.mastery-table tbody tr.mastered td{background:rgba(212,237,218,.3)}.priority-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:middle}.priority-dot.high{background:var(--accent-red)}.priority-dot.medium{background:var(--accent-orange)}.priority-dot.low{background:var(--accent-green)}.mastery-progress-bar{width:90px;height:12px;border:1.5px solid var(--ink-light);border-radius:var(--sketch-radius-sm);overflow:hidden;background:var(--paper);cursor:pointer}.mastery-progress-fill{height:100%;background:repeating-linear-gradient(-45deg,var(--accent-blue) 0,var(--accent-blue) 4px,var(--paper) 4px,var(--paper) 8px);transition:width .35s ease}.mastery-check-btn{font-family:var(--font-hand);font-size:.78rem;border:1px solid var(--ink-faint);border-radius:var(--sketch-radius-sm);padding:2px 10px;background:var(--paper);cursor:pointer;transition:all .15s;color:var(--ink-light)}.mastery-check-btn:hover{border-color:var(--accent-green);color:var(--accent-green)}.mastery-check-btn.done{background:var(--accent-green);color:var(--paper);border-color:var(--accent-green)}.shelf-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px}.shelf-card{border:2px solid var(--ink);border-radius:var(--sketch-radius);padding:22px 20px;background:var(--paper-light);position:relative;transition:all .22s}.shelf-card:hover{transform:translateY(-4px) rotate(-.4deg);box-shadow:5px 5px 0 var(--ink-faintest)}.shelf-card-corner{position:absolute;top:-1px;right:-1px;width:30px;height:30px;overflow:hidden}.shelf-card-corner:before{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 30px 30px 0;border-color:transparent var(--paper-dark) transparent transparent}.shelf-icon{width:52px;height:52px;margin-bottom:12px}.shelf-card h3{margin-bottom:6px;font-family:var(--font-header);font-size:1.1rem}.shelf-card p{font-size:.88rem;color:var(--ink-light);margin-bottom:12px}.shelf-list{list-style:none}.shelf-list li{padding:7px 0;border-bottom:1px dashed var(--ink-faintest);font-size:.88rem;display:flex;align-items:flex-start;gap:8px}.shelf-list li:last-child{border-bottom:none}.shelf-bullet{width:6px;height:6px;border:1.5px solid var(--ink);border-radius:50%;flex-shrink:0;margin-top:5px}.shelf-list a{color:var(--ink);transition:color .15s;line-height:1.35}.shelf-list a:hover{color:var(--accent-blue)}.videos-header{text-align:center;margin-bottom:28px}.videos-header h2{margin-bottom:4px}.videos-header .subtitle{font-family:var(--font-accent);font-size:1.1rem;color:var(--ink-light)}.videos-stats-row{display:flex;justify-content:center;gap:36px;margin:16px 0}.vs-item{text-align:center}.vs-num{font-family:var(--font-header);font-size:1.7rem;display:block}.vs-label{font-family:var(--font-light);font-size:.78rem;color:var(--ink-faint)}.video-filters{display:flex;justify-content:center;gap:7px;margin-bottom:28px;flex-wrap:wrap}.vf-btn{font-family:var(--font-hand);font-size:.88rem;padding:5px 16px;border:1.5px solid var(--ink-faintest);border-radius:var(--sketch-radius-sm);background:var(--paper);cursor:pointer;transition:all .15s;color:var(--ink-light)}.vf-btn.active,.vf-btn:hover{border-color:var(--ink);color:var(--ink)}.vf-btn.active{background:var(--highlight);transform:rotate(-1deg)}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:20px;gap:20px}.video-card{border:2px solid var(--ink-light);border-radius:var(--sketch-radius);overflow:hidden;background:var(--paper-light);transition:all .22s;cursor:pointer}.video-card:hover{border-color:var(--ink);transform:translateY(-3px) rotate(-.25deg);box-shadow:4px 4px 0 var(--ink-faintest)}.video-thumb-wrap{position:relative;width:100%;padding-bottom:56.25%;background:var(--paper-dark);border-bottom:1.5px dashed var(--ink-faint);overflow:hidden}.video-thumb-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .3s}.video-card:hover .video-thumb-wrap img{transform:scale(1.04)}.video-thumb-shimmer{position:absolute;inset:0;background:linear-gradient(90deg,var(--paper-dark) 25%,var(--paper) 50%,var(--paper-dark) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.video-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:transparent;transition:background .2s}.video-card:hover .video-play-overlay{background:rgba(0,0,0,.22)}.play-circle{width:52px;height:52px;background:var(--paper);border:2px solid var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.7);transition:all .2s}.video-card:hover .play-circle{opacity:1;transform:scale(1)}.play-circle svg{fill:var(--ink);margin-left:3px}.video-duration-badge{position:absolute;bottom:7px;right:8px;background:rgba(30,30,30,.82);color:var(--paper);font-family:var(--font-hand);font-size:.72rem;padding:2px 7px;border-radius:3px}.video-new-badge{left:8px;background:var(--accent-red);letter-spacing:.05em}.video-new-badge,.video-own-badge{position:absolute;top:8px;color:var(--paper);font-family:var(--font-hand);font-size:.7rem;padding:2px 8px;border-radius:var(--sketch-radius-sm);font-weight:700}.video-own-badge{right:8px;background:var(--accent-green)}.video-card-body{padding:14px 15px}.video-card-topic{font-family:var(--font-accent);font-size:.82rem;color:var(--ink-faint);letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase}.video-card-title{font-family:var(--font-hand);font-size:1rem;margin-bottom:6px;line-height:1.35}.video-card-author{display:flex;align-items:center;gap:6px;font-family:var(--font-light);font-size:.8rem;color:var(--ink-faint);margin-bottom:4px}.author-badge{font-family:var(--font-hand);font-size:.68rem;padding:1px 7px;border-radius:3px;font-weight:700}.author-badge.own{background:var(--accent-green);color:var(--paper)}.author-badge.ext{background:var(--paper-dark);color:var(--ink-faint);border:1px solid var(--ink-faintest)}.video-card-meta{font-family:var(--font-light);font-size:.78rem;color:var(--ink-faint)}.video-empty-state{text-align:center;padding:56px 20px;border:2px dashed var(--ink-faint);border-radius:var(--sketch-radius);color:var(--ink-light)}.video-empty-state h3{margin-bottom:8px}.video-empty-state p{font-size:.92rem;max-width:480px;margin:0 auto}.video-modal{display:none;position:fixed;inset:0;z-index:9000;background:rgba(30,20,10,.75);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:24px}.video-modal.open{display:flex}.video-modal-box{background:var(--paper-light);border:2.5px solid var(--ink);border-radius:var(--sketch-radius);width:min(860px,100%);overflow:hidden;box-shadow:6px 8px 0 rgba(30,30,30,.15)}.video-modal-hdr{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--paper-dark);border-bottom:1.5px solid var(--ink-faint)}.video-modal-close{width:22px;height:22px;background:var(--accent-red);border:none;border-radius:50%;cursor:pointer;font-size:12px;font-weight:700;color:hsla(0,0%,100%,.8);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s}.video-modal-close:hover{opacity:.8}.video-modal-title{font-family:var(--font-hand);font-size:1rem;flex:1 1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-embed-wrap{position:relative;padding-bottom:56.25%;background:#000}.video-embed-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none}.video-modal-info{padding:14px 18px;border-top:1.5px dashed var(--ink-faint)}.video-modal-desc{font-size:.9rem;color:var(--ink-light);font-family:var(--font-body);line-height:1.5}.papers-grid{display:grid;grid-gap:12px;gap:12px}.paper-item{border:2px solid var(--ink-light);border-radius:var(--sketch-radius);padding:15px 18px;display:flex;align-items:flex-start;gap:16px;background:var(--paper-light);transition:all .2s;cursor:pointer}.paper-item:hover{border-color:var(--ink);transform:translateY(-2px) rotate(-.2deg);box-shadow:3px 3px 0 var(--ink-faintest)}.paper-num{font-family:var(--font-header);font-size:1.3rem;color:var(--ink-faintest);min-width:30px;line-height:1.2}.paper-body h4{margin-bottom:3px;line-height:1.35}.paper-body .paper-authors{font-size:.86rem;color:var(--ink-light);margin-bottom:3px}.paper-body .paper-meta{font-family:var(--font-light);font-size:.76rem;color:var(--ink-faint)}.paper-link{margin-left:auto;font-family:var(--font-accent);font-size:1.1rem;color:var(--accent-blue);flex-shrink:0;padding:2px 8px;border:1px solid var(--accent-blue);border-radius:var(--sketch-radius-sm);transition:all .15s}.paper-item:hover .paper-link{background:var(--accent-blue);color:var(--paper)}.submit-wrap{max-width:640px;margin:0 auto}.submit-form{border:2px solid var(--ink);border-radius:var(--sketch-radius);padding:30px 28px;background:var(--paper-light)}.form-group{margin-bottom:18px}.form-group label{display:block;font-family:var(--font-hand);font-size:.98rem;margin-bottom:6px}.form-group label .req{color:var(--accent-red)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:9px 14px;border:2px solid var(--ink-faint);border-radius:var(--sketch-radius-sm);background:var(--paper);font-family:var(--font-body);font-size:.95rem;color:var(--ink);outline:none;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent-blue)}.form-group textarea{resize:vertical;min-height:84px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:22px}.btn-cancel{font-family:var(--font-hand);font-size:.95rem;padding:8px 22px;border:2px solid var(--ink-faint);border-radius:var(--sketch-radius-sm);background:transparent;color:var(--ink-light);cursor:pointer;transition:all .18s}.btn-cancel:hover{border-color:var(--ink);color:var(--ink)}.btn-submit{font-family:var(--font-hand);font-size:.95rem;padding:8px 28px;border:2px solid var(--ink);border-radius:var(--sketch-radius-sm);background:var(--ink);color:var(--paper);cursor:pointer;transition:all .18s}.btn-submit:hover{background:var(--accent-blue);border-color:var(--accent-blue);transform:rotate(-1deg) scale(1.03)}.submit-success{display:none;text-align:center;padding:40px 20px;border:2px solid var(--accent-green);border-radius:var(--sketch-radius);background:rgba(42,110,72,.06)}.submit-success h3{color:var(--accent-green);margin-bottom:8px}.footer{border-top:2.5px solid var(--ink);padding:22px 0;margin-top:60px;background:var(--paper-dark)}.footer .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.footer-brand{display:flex;align-items:center;gap:10px}.footer-brand .brand-logo-sm{width:32px;height:32px;border:2px solid var(--ink);border-radius:var(--sketch-radius-sm);display:flex;align-items:center;justify-content:center;font-family:var(--font-header);font-size:1rem}.footer-brand span{font-family:var(--font-header);font-size:.95rem}.footer-links{display:flex;gap:18px;list-style:none}.footer-links a{font-family:var(--font-hand);font-size:.88rem;color:var(--ink-light)}.footer-links a:hover{color:var(--ink)}.footer-copy{font-family:var(--font-light);font-size:.78rem;color:var(--ink-faint);text-align:center;margin-top:14px;padding-top:12px;border-top:1px dashed var(--ink-faintest)}wired-combo,wired-input,wired-textarea{--wired-item-selected-bg:rgba(255,245,157,.6);font-family:var(--font-body);font-size:.95rem;width:100%;display:block}wired-button{font-family:var(--font-hand);font-size:.9rem}wired-checkbox{font-family:var(--font-body);font-size:.88rem}wired-progress{--wired-progress-color:#2a6e48;width:100%;height:16px}wired-slider{width:100%}wired-search-input{font-family:var(--font-body);width:100%}wired-button.nav-wired{margin:0}.loading-pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-accent);font-size:1rem;color:var(--ink-light);padding:10px 20px;border:1.5px dashed var(--ink-faint);border-radius:var(--sketch-radius-sm)}.loading-dot{width:7px;height:7px;background:var(--ink-light);border-radius:50%;animation:loadingBounce .7s infinite alternate}.loading-dot:nth-child(2){animation-delay:.15s}.loading-dot:nth-child(3){animation-delay:.3s}@keyframes loadingBounce{0%{opacity:.2;transform:translateY(0)}to{opacity:1;transform:translateY(-4px)}}@media (max-width:960px){.archive-layout{grid-template-columns:1fr}.sidebar{position:static}.roadmap-top{grid-template-columns:1fr}.shelf-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){.nav-links{display:none}.nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--paper);border-bottom:2px solid var(--ink);padding:12px;z-index:200}.nav-toggle{display:block}.shelf-grid{grid-template-columns:1fr}h1{font-size:1.6rem}h2{font-size:1.3rem}.footer .container{flex-direction:column;text-align:center}.resource-card{grid-template-columns:1fr}.rc-meta{flex-direction:row;align-items:center;justify-content:flex-start}}.papers-table{width:100%;border-collapse:collapse;font-family:var(--font-body)}.papers-table th{font-family:var(--font-hand);font-size:.85rem;font-weight:700;padding:10px 12px;border-bottom:2px solid var(--ink);text-align:left;color:var(--ink-light)}.papers-table td{padding:11px 12px;border-bottom:1px solid var(--ink-faintest);vertical-align:top;font-size:.9rem}.papers-table tr:hover td{background:var(--hover-bg)}.venue-badge{font-family:var(--font-accent);font-size:.76rem;background:var(--highlight);padding:2px 8px;border-radius:4px;white-space:nowrap}.topic-badge{font-family:var(--font-hand);font-size:.76rem;padding:2px 9px;border:1px solid var(--ink-faint);border-radius:5px}.paper-link-btn{font-family:var(--font-hand);font-size:.82rem;padding:4px 10px;border:1.5px solid var(--ink-faint);border-radius:5px;color:var(--ink);text-decoration:none;transition:all .15s;white-space:nowrap;display:inline-block}.paper-link-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.nav-submit-btn{font-family:var(--font-hand);font-size:.9rem;padding:6px 16px;border:1.5px solid var(--ink);border-radius:6px;background:var(--paper);color:var(--ink);cursor:pointer!important;transition:all .15s}.nav-submit-btn:hover{background:var(--accent-green);color:var(--paper);border-color:var(--accent-green);transform:rotate(-1deg)}.loc-go-btn{font-family:var(--font-hand);font-size:.82rem;padding:3px 14px;border:1.5px solid var(--ink);border-radius:5px;background:var(--ink);color:var(--paper);cursor:pointer;transition:all .15s;flex-shrink:0}.loc-go-btn:hover{background:#333;border-color:#333}.mastery-filters{display:flex;align-items:center;gap:8px;margin-bottom:18px;flex-wrap:wrap}.mf-label{font-family:var(--font-accent);font-size:.88rem;margin-right:4px}.mf-btn,.mf-label{color:var(--ink-light)}.mf-btn{font-family:var(--font-hand);font-size:.82rem;padding:5px 14px;border:1.5px solid #bbb;border-radius:6px;background:var(--paper);cursor:pointer;transition:all .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mf-btn.active,.mf-btn:hover{border-color:var(--ink);color:var(--ink)}.mf-btn.active{background:#f0ebe0;font-weight:700}.mf-btn[data-diff=beginner].active{background:#d4edda;border-color:#2a6e48;color:#2a6e48}.mf-btn[data-diff=intermediate].active{background:#fff8d6;border-color:#b08a00;color:#7a6000}.mf-btn[data-diff=advanced].active{background:#f8d7da;border-color:#b83232;color:#b83232}.diff-badge{display:inline-block;font-family:var(--font-hand);font-size:.73rem;padding:2px 9px;border-radius:5px;border:1px solid;white-space:nowrap;text-transform:capitalize}.diff-badge.beginner{color:#2a6e48;border-color:#2a6e48;background:#d4edda}.diff-badge.intermediate{color:#7a6000;border-color:#b08a00;background:#fff8d6}.diff-badge.advanced{color:#b83232;border-color:#b83232;background:#f8d7da}.prog-bar-wrap{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.prog-bar-track{flex:1 1;height:9px;background:#e8e1d4;border-radius:99px;overflow:hidden;border:1px solid #ddd}.prog-bar-fill{height:100%;border-radius:99px;transition:width .3s,background .3s}.prog-bar-pct{font-family:var(--font-accent);min-width:30px;text-align:right}.mastery-done-btn,.prog-bar-pct{font-size:.79rem;color:var(--ink-light)}.mastery-done-btn{font-family:var(--font-hand);padding:4px 11px;border:1.5px solid #bbb;border-radius:6px;background:var(--paper);cursor:pointer;transition:all .15s;white-space:nowrap}.mastery-done-btn:hover{border-color:var(--ink);color:var(--ink)}.mastery-done-btn.done{background:#d4edda;border-color:#2a6e48;color:#2a6e48;font-weight:700}.cat-cell{font-family:var(--font-hand);font-weight:700;white-space:nowrap;font-size:.86rem;color:var(--ink)}.problem-link{color:var(--ink);text-decoration:none;font-size:.9rem;line-height:1.4;transition:color .15s}.problem-link:hover{color:#2d5fa8;text-decoration:underline}.pla{font-size:.8em;opacity:.35;margin-left:2px}.problem-link:hover .pla{opacity:.9}.sf-input,.sf-select,.sf-textarea{width:100%;padding:10px 12px;font-family:var(--font-body);font-size:.95rem;background:var(--paper);color:var(--ink);border:1.5px solid #bbb;border-radius:6px;outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.sf-input:focus,.sf-select:focus,.sf-textarea:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(30,30,30,.07)}.sf-select{cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.sf-textarea{resize:vertical;min-height:80px}.sf-row{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:16px;gap:16px}@media(max-width:640px){.sf-row{grid-template-columns:1fr}}.sf-hint{color:var(--ink-faint);font-size:.8rem;font-weight:400}.sf-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px;padding:10px 14px;font-family:var(--font-body);font-size:.9rem;margin-top:4px}.sf-btn-cancel{font-family:var(--font-hand);font-size:.95rem;padding:10px 22px;border:1.5px solid #bbb;border-radius:6px;background:var(--paper);cursor:pointer;color:var(--ink-light);transition:all .15s}.sf-btn-cancel:hover{border-color:var(--ink);color:var(--ink)}.sf-btn-submit{font-family:var(--font-hand);font-size:.95rem;padding:10px 26px;border:1.5px solid var(--ink);border-radius:6px;background:var(--ink);cursor:pointer;color:var(--paper);transition:all .15s;font-weight:700}.sf-btn-submit:hover{background:#333;border-color:#333;transform:rotate(-1deg) scale(1.02)}.sf-btn-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}