@font-face{font-display:block;font-family:KaTeX_AMS;font-style:normal;font-weight:400;src:url(/assets/KaTeX_AMS-Regular-BQhdFMY1.woff2)format("woff2"),url(/assets/KaTeX_AMS-Regular-DMm9YOAa.woff)format("woff"),url(/assets/KaTeX_AMS-Regular-DRggAlZN.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Caligraphic-Bold-Dq_IR9rO.woff2)format("woff2"),url(/assets/KaTeX_Caligraphic-Bold-BEiXGLvX.woff)format("woff"),url(/assets/KaTeX_Caligraphic-Bold-ATXxdsX0.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Caligraphic-Regular-Di6jR-x-.woff2)format("woff2"),url(/assets/KaTeX_Caligraphic-Regular-CTRA-rTL.woff)format("woff"),url(/assets/KaTeX_Caligraphic-Regular-wX97UBjC.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Fraktur-Bold-CL6g_b3V.woff2)format("woff2"),url(/assets/KaTeX_Fraktur-Bold-BsDP51OF.woff)format("woff"),url(/assets/KaTeX_Fraktur-Bold-BdnERNNW.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Fraktur-Regular-CTYiF6lA.woff2)format("woff2"),url(/assets/KaTeX_Fraktur-Regular-Dxdc4cR9.woff)format("woff"),url(/assets/KaTeX_Fraktur-Regular-CB_wures.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Main-Bold-Cx986IdX.woff2)format("woff2"),url(/assets/KaTeX_Main-Bold-Jm3AIy58.woff)format("woff"),url(/assets/KaTeX_Main-Bold-waoOVXN0.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Main-BoldItalic-DxDJ3AOS.woff2)format("woff2"),url(/assets/KaTeX_Main-BoldItalic-SpSLRI95.woff)format("woff"),url(/assets/KaTeX_Main-BoldItalic-DzxPMmG6.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Main-Italic-NWA7e6Wa.woff2)format("woff2"),url(/assets/KaTeX_Main-Italic-BMLOBm91.woff)format("woff"),url(/assets/KaTeX_Main-Italic-3WenGoN9.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Main-Regular-B22Nviop.woff2)format("woff2"),url(/assets/KaTeX_Main-Regular-Dr94JaBh.woff)format("woff"),url(/assets/KaTeX_Main-Regular-ypZvNtVU.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Math-BoldItalic-CZnvNsCZ.woff2)format("woff2"),url(/assets/KaTeX_Math-BoldItalic-iY-2wyZ7.woff)format("woff"),url(/assets/KaTeX_Math-BoldItalic-B3XSjfu4.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Math-Italic-t53AETM-.woff2)format("woff2"),url(/assets/KaTeX_Math-Italic-DA0__PXp.woff)format("woff"),url(/assets/KaTeX_Math-Italic-flOr_0UB.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_SansSerif;font-style:normal;font-weight:700;src:url(/assets/KaTeX_SansSerif-Bold-D1sUS0GD.woff2)format("woff2"),url(/assets/KaTeX_SansSerif-Bold-DbIhKOiC.woff)format("woff"),url(/assets/KaTeX_SansSerif-Bold-CFMepnvq.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_SansSerif;font-style:italic;font-weight:400;src:url(/assets/KaTeX_SansSerif-Italic-C3H0VqGB.woff2)format("woff2"),url(/assets/KaTeX_SansSerif-Italic-DN2j7dab.woff)format("woff"),url(/assets/KaTeX_SansSerif-Italic-YYjJ1zSn.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_SansSerif;font-style:normal;font-weight:400;src:url(/assets/KaTeX_SansSerif-Regular-DDBCnlJ7.woff2)format("woff2"),url(/assets/KaTeX_SansSerif-Regular-CS6fqUqJ.woff)format("woff"),url(/assets/KaTeX_SansSerif-Regular-BNo7hRIc.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Script;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Script-Regular-D3wIWfF6.woff2)format("woff2"),url(/assets/KaTeX_Script-Regular-D5yQViql.woff)format("woff"),url(/assets/KaTeX_Script-Regular-C5JkGWo-.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size1;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size1-Regular-mCD8mA8B.woff2)format("woff2"),url(/assets/KaTeX_Size1-Regular-C195tn64.woff)format("woff"),url(/assets/KaTeX_Size1-Regular-Dbsnue_I.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size2;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size2-Regular-Dy4dx90m.woff2)format("woff2"),url(/assets/KaTeX_Size2-Regular-oD1tc_U0.woff)format("woff"),url(/assets/KaTeX_Size2-Regular-B7gKUWhC.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size3;font-style:normal;font-weight:400;src:url(data:font/woff2;base64,d09GMgABAAAAAA4oAA4AAAAAHbQAAA3TAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAABmAAgRQIDgmcDBEICo1oijYBNgIkA14LMgAEIAWJAAeBHAyBHBvbGiMRdnO0IkRRkiYDgr9KsJ1NUAf2kILNxgUmgqIgq1P89vcbIcmsQbRps3vCcXdYOKSWEPEKgZgQkprQQsxIXUgq0DqpGKmIvrgkeVGtEQD9DzAO29fM9jYhxZEsL2FeURH2JN4MIcTdO049NCVdxQ/w9NrSYFEBKTDKpLKfNkCGDc1RwjZLQcm3vqJ2UW9Xfa3tgAHz6ivp6vgC2yD4/6352ndnN0X0TL7seypkjZlMsjmZnf0Mm5Q+JykRWQBKCVCVPbARPXWyQtb5VgLB6Biq7/Uixcj2WGqdI8tGSgkuRG+t910GKP2D7AQH0DB9FMDW/obJZ8giFI3Wg8Cvevz0M+5m0rTh7XDBlvo9Y4vm13EXmfttwI4mBo1EG15fxJhUiCLbiiyCf/ZA6MFAhg3pGIZGdGIVjtPn6UcMk9A/UUr9PhoNsCENw1APAq0gpH73e+M+0ueyHbabc3vkbcdtzcf/fiy+NxQEjf9ud/ELBHAXJ0nk4z+MXH2Ev/kWyV4k7SkvpPc9Qr38F6RPWnM9cN6DJ0AdD1BhtgABtmoRoFCvPsBAumNm6soZG2Gk5GyVTo2sJncSyp0jQTYoR6WDvTwaaEcHsxHfvuWhHA3a6bN7twRKtcGok6NsCi7jYRrM2jExsUFMxMQYuJbMhuWNOumEJy9hi29Dmg5zMp/A5+hhPG19j1vBrq8JTLr8ki5VLPmG/PynJHVul440bxg5xuymHUFPBshC+nA9I1FmwbRBTNHAcik3Oae0cxKoI3MOriM42UrPe51nsaGxJ+WfXubAsP84aabUlQSJ1IiE0iPETLUU4CATgfXSCSpuRFRmCGbO+wSpAnzaeaCYW1VNEysRtuXCEL1kUFUbbtMv3Tilt/1c11jt3Q5bbMa84cpWipp8Elw3MZhOHsOlwwVUQM3lAR35JiFQbaYCRnMF2lxAWoOg2gyoIV4PouX8HytNIfLhqpJtXB4vjiViUI8IJ7bkC4ikkQvKksnOTKICwnqWSZ9YS5f0WCxmpgjbIq7EJcM4aI2nmhLNY2JIUgOjXZFWBHb+x5oh6cwb0Tv1ackHdKi0I9OO2wE9aogIOn540CCCziyhN+IaejtgAONKznHlHyutPrHGwCx9S6B8kfS4Mfi4Eyv7OU730bT1SCBjt834cXsf43zVjPUqqJjgrjeGnBxSG4aYAKFuVbeCfkDIjAqMb6yLNIbCuvXhMH2/+k2vkNpkORhR59N1CkzoOENvneIosjYmuTxlhUzaGEJQ/iWqx4dmwpmKjrwTiTGTCVozNAYqk/zXOndWxuWSmJkQpJw3pK5KX6QrLt5LATMqpmPAQhkhK6PUjzHUn7E0gHE0kPE0iKkolgkUx9SZmVAdDgpffdyJKg3k7VmzYGCwVXGz/tXmkOIp+vcWs+EMuhhvN0h9uhfzWJziBQmCREGSIFmQIkgVpAnSBRmC//6hkLZwaVhwxlrJSOdqlFtOYxlau9F2QN5Y98xmIAsiM1HVp2VFX+DHHGg6Ecjh3vmqtidX3qHI2qycTk/iwxSt5UzTmEP92ZBnEWTk4Mx8Mpl78ZDokxg/KWb+Q0QkvdKVmq3TMW+RXEgrsziSAfNXFMhDc60N5N9jQzjfO0kBKpUZl0ZmwJ41j/B9Hz6wmRaJB84niNmQrzp9eSlQCDDzazGDdVi3P36VZQ+Jy4f9UBNp+3zTjqI4abaFAm+GShVaXlsGdF3FYzZcDI6cori4kMxUECl9IjJZpzkvitAoxKue+90pDMvcKRxLl53TmOKCmV/xRolNKSqqUxc6LStOETmFOiLZZptlZepcKiAzteG8PEdpnQpbOMNcMsR4RR2Bs0cKFEvSmIjAFcnarqwUL4lDhHmnVkwu1IwshbiCcgvOheZuYyOteufZZwlcTlLgnZ3o/WcYdzZHW/WGaqaVfmTZ1aWCceJjkbZqsfbkOtcFlUZM/jy+hXHDbaUobWqqXaeWobbLO99yG5N3U4wxco0rQGGcOLASFMXeJoham8M+/x6O2WywK2l4HGbq1CoUyC/IZikQhdq3SiuNrvAEj0AVu9x2x3lp/xWzahaxidezFVtdcb5uEnzyl0ZmYiuKI0exvCd4Xc9CV1KB0db00z92wDPde0kukbvZIWN6jUWFTmPIC/Y4UPCm8UfDTFZpZNon1qLFTkBhxzB+FjQRA2Q/YRJT8pQigslMaUpFyAG8TMlXigiqmAZX4xgijKjRlGpLE0GdplRfCaJo0JQaSxNBk6ZmMzcya0FmrcisDdn0Q3HI2sWSppYigmlM1XT/kLQZSNpMJG0WkjYbSZuDpM1F0uYhFc1HxU4m1QJjDK6iL0S5uSj5rgXc3RejEigtcRBtqYPQsiTskmO5vosV+q4VGIKbOkDg0jtRrq+Em1YloaTFar3EGr1EUC8R0kus1Uus00usL97ABr2BjXoDm/QGNhuWtMVBKOwg/i78lT7hBsAvDmwHc/ao3vmUbBmhjeYySZNWvGkfZAgISDSaDo1SVpzGDsAEkF8B+gEapViUoZgUWXcRIGFZNm6gWbAKk0bp0k1MHG9fLYtV4iS2SmLEQFARzRcnf9PUS0LVn05/J9MiRRBU3v2IrvW974v4N00L7ZMk0wXP1409CHo/an8zTRHD3eSJ6m8D4YMkZNl3M79sqeuAsr/m3f+8/yl7A50aiAEJgeBeMWzu7ui9UfUBCe2TIqZIoOd/3/udRBOQidQZUERzb2/VwZN1H/Sju82ew2H2Wfr6qvfVf3hqwDvAIpkQVFy4B9Pe9e4/XvPeceu7h3dvO56iJPf0+A6cqA2ip18ER+iFgggiuOkvj24bby0N9j2UHIkgqIt+sVgfodC4YghLSMjSZbH0VR/6dMDrYJeKHilKTemt6v6kvzvn3/RrdWtr0GoN/xL+Sex/cPYLUpepx9cz/D46UPU5KXgAQa+NDps1v6J3xP1i2HtaDB0M9aX2deA7SYff//+gUCovMmIK/qfsFcOk+4Y5ZN97XlG6zebqtMbKgeRFi51vnxTQYBUik2rS/Cn6PC8ADR8FGxsRPB82dzfND90gIcshOcYUkfjherBz53odpm6TP8txlwOZ71xmfHHOvq053qFF/MRlS3jP0ELudrf2OeN8DHvp6ZceLe8qKYvWz/7yp0u4dKPfli3CYq0O13Ih71mylJ80tOi10On8wi+F4+LWgDPeJ30msSQt9/vkmHq9/Lvo2b461mP801v3W4xTcs6CbvF9UDdrSt+A8OUbpSh55qAUFXWznBBfdeJ8a4d7ugT5tvxUza3h9m4H7ptTqiG4z0g5dc0X29OcGlhpGFMpQo9ytTS+NViZpNdvU4kWx+LKxNY10kQ1yqGXrhe4/1nvP7E+nd5A92TtaRplbHSqoIdOqtRWti+fkB5/n1+/VvCmz12pG1kpQWsfi1ftlBobm0bpngs16CHkbIwdLnParxtTV3QYRlfJ0KFskH7pdN/YDn+yRuSd7sNH3aO0DYPggk6uWuXrfOc+fa3VTxFVvKaNxHsiHmsXyCLIE5yuOeN3/Jdf8HBL/5M6shjyhxHx9BjB1O0+4NLOnjLLSxwO7ukN4jMbOIcD879KLSi6Pk61Oqm2377n8079PXEEQ7cy7OKEC9nbpet118fxweTafpt69x/Bt8UqGzNQt7aelpc44dn5cqhwf71+qKp/Zf/+a0zcizOUWpl/iBcSXip0pplkatCchoH5c5aUM8I7/dWxAej8WicPL1URFZ9BDJelUwEwTkGqUhgSlydVes95YdXvhh9Gfz/aeFWvgVb4tuLbcv4+wLdutVZv/cUonwBD/6eDlE0aSiKK/uoH3+J1wDE/jMVqY2ysGufN84oIXB0sPzy8ollX/LegY74DgJXJR57sn+VGza0x3DnuIgABFM15LmajjjsNlYj+JEZGbuRYcAMOWxFkPN2w6Wd46xo4gVWQR/X4lyI/R6K/YK0110GzudPRW7Y+UOBGTfNNzHeYT0fiH0taunBpq9HEW8OKSaBGj21L0MqenEmNRWBAWDWAk4CpNoEZJ2tTaPFgbQYj8HxtFilErs3BTRwT8uO1NXQaWfIotchmPkAF5mMBAliEmZiOGVgCG9LgRzpscMAOOwowlT3JhusdazXGSC/hxR3UlmWVwWHpOIKheqONvjyhSiTHIkVUco5bnji8m//zL7PKaT1Vl5I6UE609f+gkr6MZKVyKc7zJRmCahLsdlyA5fdQkRSan9LgnnLEyGSkaKJCJog0wAgvepWBt80+1yKln1bMVtCljfNWDueKLsWwaEbBSfSPTEmVRsUcYYMnEjcjeyCZzBXK9E9BYBXLKjOSpUDR+nEV3TFSUdQaz+ot98QxgXwx0GQ+EEUAKB2qZPkQQ0GqFD8UPFMqyaCHM24BZmSGic9EYMagKizOw9Hz50DMrDLrqqLkTAhplMictiCAx5S3BIUQdeJeLnBy2CNtMfz6cV4u8XKoFZQesbf9YZiIERiHjaNodDW6LgcirX/mPnJIkBGDUpTBhSa0EIr38D5hCIszhCM8URGBqImoWjpvpt1ebu/v3Gl3qJfMnNM+9V+kiRFyROTPHQWOcs1dNW94/ukKMPZBvDi55i5CttdeJz84DLngLqjcdwEZ87bFFR8CIG35OAkDVN6VRDZ7aq67NteYqZ2lpT8oYB2CytoBd6VuAx4WgiAsnuj3WohG+LugzXiQRDeM3XYXlULv4dp5VFYC)format("woff2"),url(/assets/KaTeX_Size3-Regular-CTq5MqoE.woff)format("woff"),url(/assets/KaTeX_Size3-Regular-DgpXs0kz.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size4;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size4-Regular-Dl5lxZxV.woff2)format("woff2"),url(/assets/KaTeX_Size4-Regular-BF-4gkZK.woff)format("woff"),url(/assets/KaTeX_Size4-Regular-DWFBv043.ttf)format("truetype")}@font-face{font-display:block;font-family:KaTeX_Typewriter;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Typewriter-Regular-CO6r4hn1.woff2)format("woff2"),url(/assets/KaTeX_Typewriter-Regular-C0xS9mPB.woff)format("woff"),url(/assets/KaTeX_Typewriter-Regular-D3Ib7_Hf.ttf)format("truetype")}.katex{text-indent:0;text-rendering:auto;font:1.21em/1.2 KaTeX_Main,Times New Roman,serif;position:relative}.katex *{border-color:currentColor;-ms-high-contrast-adjust:none!important}.katex .katex-version:after{content:"0.16.45"}.katex .katex-mathml{clip:rect(1px,1px,1px,1px);border:0;width:1px;height:1px;padding:0;position:absolute;overflow:hidden}.katex .katex-html>.newline{display:block}.katex .base{white-space:nowrap;width:min-content;position:relative}.katex .base,.katex .strut{display:inline-block}.katex .textbf{font-weight:700}.katex .textit{font-style:italic}.katex .textrm{font-family:KaTeX_Main}.katex .textsf{font-family:KaTeX_SansSerif}.katex .texttt{font-family:KaTeX_Typewriter}.katex .mathnormal{font-family:KaTeX_Math;font-style:italic}.katex .mathit{font-family:KaTeX_Main;font-style:italic}.katex .mathrm{font-style:normal}.katex .mathbf{font-family:KaTeX_Main;font-weight:700}.katex .boldsymbol{font-family:KaTeX_Math;font-style:italic;font-weight:700}.katex .amsrm,.katex .mathbb,.katex .textbb{font-family:KaTeX_AMS}.katex .mathcal{font-family:KaTeX_Caligraphic}.katex .mathfrak,.katex .textfrak{font-family:KaTeX_Fraktur}.katex .mathboldfrak,.katex .textboldfrak{font-family:KaTeX_Fraktur;font-weight:700}.katex .mathtt{font-family:KaTeX_Typewriter}.katex .mathscr,.katex .textscr{font-family:KaTeX_Script}.katex .mathsf,.katex .textsf{font-family:KaTeX_SansSerif}.katex .mathboldsf,.katex .textboldsf{font-family:KaTeX_SansSerif;font-weight:700}.katex .mathitsf,.katex .mathsfit,.katex .textitsf{font-family:KaTeX_SansSerif;font-style:italic}.katex .mainrm{font-family:KaTeX_Main;font-style:normal}.katex .vlist-t{border-collapse:collapse;table-layout:fixed;display:inline-table}.katex .vlist-r{display:table-row}.katex .vlist{vertical-align:bottom;display:table-cell;position:relative}.katex .vlist>span{height:0;display:block;position:relative}.katex .vlist>span>span{display:inline-block}.katex .vlist>span>.pstrut{width:0;overflow:hidden}.katex .vlist-t2{margin-right:-2px}.katex .vlist-s{vertical-align:bottom;width:2px;min-width:2px;font-size:1px;display:table-cell}.katex .vbox{flex-direction:column;align-items:baseline;display:inline-flex}.katex .hbox{width:100%}.katex .hbox,.katex .thinbox{flex-direction:row;display:inline-flex}.katex .thinbox{width:0;max-width:0}.katex .msupsub{text-align:left}.katex .mfrac>span>span{text-align:center}.katex .mfrac .frac-line{border-bottom-style:solid;width:100%;display:inline-block}.katex .hdashline,.katex .hline,.katex .mfrac .frac-line,.katex .overline .overline-line,.katex .rule,.katex .underline .underline-line{min-height:1px}.katex .mspace{display:inline-block}.katex .smash{line-height:0;display:inline}.katex .clap,.katex .llap,.katex .rlap{width:0;position:relative}.katex .clap>.inner,.katex .llap>.inner,.katex .rlap>.inner{position:absolute}.katex .clap>.fix,.katex .llap>.fix,.katex .rlap>.fix{display:inline-block}.katex .llap>.inner{right:0}.katex .clap>.inner,.katex .rlap>.inner{left:0}.katex .clap>.inner>span{margin-left:-50%;margin-right:50%}.katex .rule{border:0 solid;display:inline-block;position:relative}.katex .hline,.katex .overline .overline-line,.katex .underline .underline-line{border-bottom-style:solid;width:100%;display:inline-block}.katex .hdashline{border-bottom-style:dashed;width:100%;display:inline-block}.katex .sqrt>.root{margin-left:.277778em;margin-right:-.555556em}.katex .fontsize-ensurer.reset-size1.size1,.katex .sizing.reset-size1.size1{font-size:1em}.katex .fontsize-ensurer.reset-size1.size2,.katex .sizing.reset-size1.size2{font-size:1.2em}.katex .fontsize-ensurer.reset-size1.size3,.katex .sizing.reset-size1.size3{font-size:1.4em}.katex .fontsize-ensurer.reset-size1.size4,.katex .sizing.reset-size1.size4{font-size:1.6em}.katex .fontsize-ensurer.reset-size1.size5,.katex .sizing.reset-size1.size5{font-size:1.8em}.katex .fontsize-ensurer.reset-size1.size6,.katex .sizing.reset-size1.size6{font-size:2em}.katex .fontsize-ensurer.reset-size1.size7,.katex .sizing.reset-size1.size7{font-size:2.4em}.katex .fontsize-ensurer.reset-size1.size8,.katex .sizing.reset-size1.size8{font-size:2.88em}.katex .fontsize-ensurer.reset-size1.size9,.katex .sizing.reset-size1.size9{font-size:3.456em}.katex .fontsize-ensurer.reset-size1.size10,.katex .sizing.reset-size1.size10{font-size:4.148em}.katex .fontsize-ensurer.reset-size1.size11,.katex .sizing.reset-size1.size11{font-size:4.976em}.katex .fontsize-ensurer.reset-size2.size1,.katex .sizing.reset-size2.size1{font-size:.833333em}.katex .fontsize-ensurer.reset-size2.size2,.katex .sizing.reset-size2.size2{font-size:1em}.katex .fontsize-ensurer.reset-size2.size3,.katex .sizing.reset-size2.size3{font-size:1.16667em}.katex .fontsize-ensurer.reset-size2.size4,.katex .sizing.reset-size2.size4{font-size:1.33333em}.katex .fontsize-ensurer.reset-size2.size5,.katex .sizing.reset-size2.size5{font-size:1.5em}.katex .fontsize-ensurer.reset-size2.size6,.katex .sizing.reset-size2.size6{font-size:1.66667em}.katex .fontsize-ensurer.reset-size2.size7,.katex .sizing.reset-size2.size7{font-size:2em}.katex .fontsize-ensurer.reset-size2.size8,.katex .sizing.reset-size2.size8{font-size:2.4em}.katex .fontsize-ensurer.reset-size2.size9,.katex .sizing.reset-size2.size9{font-size:2.88em}.katex .fontsize-ensurer.reset-size2.size10,.katex .sizing.reset-size2.size10{font-size:3.45667em}.katex .fontsize-ensurer.reset-size2.size11,.katex .sizing.reset-size2.size11{font-size:4.14667em}.katex .fontsize-ensurer.reset-size3.size1,.katex .sizing.reset-size3.size1{font-size:.714286em}.katex .fontsize-ensurer.reset-size3.size2,.katex .sizing.reset-size3.size2{font-size:.857143em}.katex .fontsize-ensurer.reset-size3.size3,.katex .sizing.reset-size3.size3{font-size:1em}.katex .fontsize-ensurer.reset-size3.size4,.katex .sizing.reset-size3.size4{font-size:1.14286em}.katex .fontsize-ensurer.reset-size3.size5,.katex .sizing.reset-size3.size5{font-size:1.28571em}.katex .fontsize-ensurer.reset-size3.size6,.katex .sizing.reset-size3.size6{font-size:1.42857em}.katex .fontsize-ensurer.reset-size3.size7,.katex .sizing.reset-size3.size7{font-size:1.71429em}.katex .fontsize-ensurer.reset-size3.size8,.katex .sizing.reset-size3.size8{font-size:2.05714em}.katex .fontsize-ensurer.reset-size3.size9,.katex .sizing.reset-size3.size9{font-size:2.46857em}.katex .fontsize-ensurer.reset-size3.size10,.katex .sizing.reset-size3.size10{font-size:2.96286em}.katex .fontsize-ensurer.reset-size3.size11,.katex .sizing.reset-size3.size11{font-size:3.55429em}.katex .fontsize-ensurer.reset-size4.size1,.katex .sizing.reset-size4.size1{font-size:.625em}.katex .fontsize-ensurer.reset-size4.size2,.katex .sizing.reset-size4.size2{font-size:.75em}.katex .fontsize-ensurer.reset-size4.size3,.katex .sizing.reset-size4.size3{font-size:.875em}.katex .fontsize-ensurer.reset-size4.size4,.katex .sizing.reset-size4.size4{font-size:1em}.katex .fontsize-ensurer.reset-size4.size5,.katex .sizing.reset-size4.size5{font-size:1.125em}.katex .fontsize-ensurer.reset-size4.size6,.katex .sizing.reset-size4.size6{font-size:1.25em}.katex .fontsize-ensurer.reset-size4.size7,.katex .sizing.reset-size4.size7{font-size:1.5em}.katex .fontsize-ensurer.reset-size4.size8,.katex .sizing.reset-size4.size8{font-size:1.8em}.katex .fontsize-ensurer.reset-size4.size9,.katex .sizing.reset-size4.size9{font-size:2.16em}.katex .fontsize-ensurer.reset-size4.size10,.katex .sizing.reset-size4.size10{font-size:2.5925em}.katex .fontsize-ensurer.reset-size4.size11,.katex .sizing.reset-size4.size11{font-size:3.11em}.katex .fontsize-ensurer.reset-size5.size1,.katex .sizing.reset-size5.size1{font-size:.555556em}.katex .fontsize-ensurer.reset-size5.size2,.katex .sizing.reset-size5.size2{font-size:.666667em}.katex .fontsize-ensurer.reset-size5.size3,.katex .sizing.reset-size5.size3{font-size:.777778em}.katex .fontsize-ensurer.reset-size5.size4,.katex .sizing.reset-size5.size4{font-size:.888889em}.katex .fontsize-ensurer.reset-size5.size5,.katex .sizing.reset-size5.size5{font-size:1em}.katex .fontsize-ensurer.reset-size5.size6,.katex .sizing.reset-size5.size6{font-size:1.11111em}.katex .fontsize-ensurer.reset-size5.size7,.katex .sizing.reset-size5.size7{font-size:1.33333em}.katex .fontsize-ensurer.reset-size5.size8,.katex .sizing.reset-size5.size8{font-size:1.6em}.katex .fontsize-ensurer.reset-size5.size9,.katex .sizing.reset-size5.size9{font-size:1.92em}.katex .fontsize-ensurer.reset-size5.size10,.katex .sizing.reset-size5.size10{font-size:2.30444em}.katex .fontsize-ensurer.reset-size5.size11,.katex .sizing.reset-size5.size11{font-size:2.76444em}.katex .fontsize-ensurer.reset-size6.size1,.katex .sizing.reset-size6.size1{font-size:.5em}.katex .fontsize-ensurer.reset-size6.size2,.katex .sizing.reset-size6.size2{font-size:.6em}.katex .fontsize-ensurer.reset-size6.size3,.katex .sizing.reset-size6.size3{font-size:.7em}.katex .fontsize-ensurer.reset-size6.size4,.katex .sizing.reset-size6.size4{font-size:.8em}.katex .fontsize-ensurer.reset-size6.size5,.katex .sizing.reset-size6.size5{font-size:.9em}.katex .fontsize-ensurer.reset-size6.size6,.katex .sizing.reset-size6.size6{font-size:1em}.katex .fontsize-ensurer.reset-size6.size7,.katex .sizing.reset-size6.size7{font-size:1.2em}.katex .fontsize-ensurer.reset-size6.size8,.katex .sizing.reset-size6.size8{font-size:1.44em}.katex .fontsize-ensurer.reset-size6.size9,.katex .sizing.reset-size6.size9{font-size:1.728em}.katex .fontsize-ensurer.reset-size6.size10,.katex .sizing.reset-size6.size10{font-size:2.074em}.katex .fontsize-ensurer.reset-size6.size11,.katex .sizing.reset-size6.size11{font-size:2.488em}.katex .fontsize-ensurer.reset-size7.size1,.katex .sizing.reset-size7.size1{font-size:.416667em}.katex .fontsize-ensurer.reset-size7.size2,.katex .sizing.reset-size7.size2{font-size:.5em}.katex .fontsize-ensurer.reset-size7.size3,.katex .sizing.reset-size7.size3{font-size:.583333em}.katex .fontsize-ensurer.reset-size7.size4,.katex .sizing.reset-size7.size4{font-size:.666667em}.katex .fontsize-ensurer.reset-size7.size5,.katex .sizing.reset-size7.size5{font-size:.75em}.katex .fontsize-ensurer.reset-size7.size6,.katex .sizing.reset-size7.size6{font-size:.833333em}.katex .fontsize-ensurer.reset-size7.size7,.katex .sizing.reset-size7.size7{font-size:1em}.katex .fontsize-ensurer.reset-size7.size8,.katex .sizing.reset-size7.size8{font-size:1.2em}.katex .fontsize-ensurer.reset-size7.size9,.katex .sizing.reset-size7.size9{font-size:1.44em}.katex .fontsize-ensurer.reset-size7.size10,.katex .sizing.reset-size7.size10{font-size:1.72833em}.katex .fontsize-ensurer.reset-size7.size11,.katex .sizing.reset-size7.size11{font-size:2.07333em}.katex .fontsize-ensurer.reset-size8.size1,.katex .sizing.reset-size8.size1{font-size:.347222em}.katex .fontsize-ensurer.reset-size8.size2,.katex .sizing.reset-size8.size2{font-size:.416667em}.katex .fontsize-ensurer.reset-size8.size3,.katex .sizing.reset-size8.size3{font-size:.486111em}.katex .fontsize-ensurer.reset-size8.size4,.katex .sizing.reset-size8.size4{font-size:.555556em}.katex .fontsize-ensurer.reset-size8.size5,.katex .sizing.reset-size8.size5{font-size:.625em}.katex .fontsize-ensurer.reset-size8.size6,.katex .sizing.reset-size8.size6{font-size:.694444em}.katex .fontsize-ensurer.reset-size8.size7,.katex .sizing.reset-size8.size7{font-size:.833333em}.katex .fontsize-ensurer.reset-size8.size8,.katex .sizing.reset-size8.size8{font-size:1em}.katex .fontsize-ensurer.reset-size8.size9,.katex .sizing.reset-size8.size9{font-size:1.2em}.katex .fontsize-ensurer.reset-size8.size10,.katex .sizing.reset-size8.size10{font-size:1.44028em}.katex .fontsize-ensurer.reset-size8.size11,.katex .sizing.reset-size8.size11{font-size:1.72778em}.katex .fontsize-ensurer.reset-size9.size1,.katex .sizing.reset-size9.size1{font-size:.289352em}.katex .fontsize-ensurer.reset-size9.size2,.katex .sizing.reset-size9.size2{font-size:.347222em}.katex .fontsize-ensurer.reset-size9.size3,.katex .sizing.reset-size9.size3{font-size:.405093em}.katex .fontsize-ensurer.reset-size9.size4,.katex .sizing.reset-size9.size4{font-size:.462963em}.katex .fontsize-ensurer.reset-size9.size5,.katex .sizing.reset-size9.size5{font-size:.520833em}.katex .fontsize-ensurer.reset-size9.size6,.katex .sizing.reset-size9.size6{font-size:.578704em}.katex .fontsize-ensurer.reset-size9.size7,.katex .sizing.reset-size9.size7{font-size:.694444em}.katex .fontsize-ensurer.reset-size9.size8,.katex .sizing.reset-size9.size8{font-size:.833333em}.katex .fontsize-ensurer.reset-size9.size9,.katex .sizing.reset-size9.size9{font-size:1em}.katex .fontsize-ensurer.reset-size9.size10,.katex .sizing.reset-size9.size10{font-size:1.20023em}.katex .fontsize-ensurer.reset-size9.size11,.katex .sizing.reset-size9.size11{font-size:1.43981em}.katex .fontsize-ensurer.reset-size10.size1,.katex .sizing.reset-size10.size1{font-size:.24108em}.katex .fontsize-ensurer.reset-size10.size2,.katex .sizing.reset-size10.size2{font-size:.289296em}.katex .fontsize-ensurer.reset-size10.size3,.katex .sizing.reset-size10.size3{font-size:.337512em}.katex .fontsize-ensurer.reset-size10.size4,.katex .sizing.reset-size10.size4{font-size:.385728em}.katex .fontsize-ensurer.reset-size10.size5,.katex .sizing.reset-size10.size5{font-size:.433944em}.katex .fontsize-ensurer.reset-size10.size6,.katex .sizing.reset-size10.size6{font-size:.48216em}.katex .fontsize-ensurer.reset-size10.size7,.katex .sizing.reset-size10.size7{font-size:.578592em}.katex .fontsize-ensurer.reset-size10.size8,.katex .sizing.reset-size10.size8{font-size:.694311em}.katex .fontsize-ensurer.reset-size10.size9,.katex .sizing.reset-size10.size9{font-size:.833173em}.katex .fontsize-ensurer.reset-size10.size10,.katex .sizing.reset-size10.size10{font-size:1em}.katex .fontsize-ensurer.reset-size10.size11,.katex .sizing.reset-size10.size11{font-size:1.19961em}.katex .fontsize-ensurer.reset-size11.size1,.katex .sizing.reset-size11.size1{font-size:.200965em}.katex .fontsize-ensurer.reset-size11.size2,.katex .sizing.reset-size11.size2{font-size:.241158em}.katex .fontsize-ensurer.reset-size11.size3,.katex .sizing.reset-size11.size3{font-size:.281351em}.katex .fontsize-ensurer.reset-size11.size4,.katex .sizing.reset-size11.size4{font-size:.321543em}.katex .fontsize-ensurer.reset-size11.size5,.katex .sizing.reset-size11.size5{font-size:.361736em}.katex .fontsize-ensurer.reset-size11.size6,.katex .sizing.reset-size11.size6{font-size:.401929em}.katex .fontsize-ensurer.reset-size11.size7,.katex .sizing.reset-size11.size7{font-size:.482315em}.katex .fontsize-ensurer.reset-size11.size8,.katex .sizing.reset-size11.size8{font-size:.578778em}.katex .fontsize-ensurer.reset-size11.size9,.katex .sizing.reset-size11.size9{font-size:.694534em}.katex .fontsize-ensurer.reset-size11.size10,.katex .sizing.reset-size11.size10{font-size:.833601em}.katex .fontsize-ensurer.reset-size11.size11,.katex .sizing.reset-size11.size11{font-size:1em}.katex .delimsizing.size1{font-family:KaTeX_Size1}.katex .delimsizing.size2{font-family:KaTeX_Size2}.katex .delimsizing.size3{font-family:KaTeX_Size3}.katex .delimsizing.size4{font-family:KaTeX_Size4}.katex .delimsizing.mult .delim-size1>span{font-family:KaTeX_Size1}.katex .delimsizing.mult .delim-size4>span{font-family:KaTeX_Size4}.katex .nulldelimiter{width:.12em;display:inline-block}.katex .delimcenter,.katex .op-symbol{position:relative}.katex .op-symbol.small-op{font-family:KaTeX_Size1}.katex .op-symbol.large-op{font-family:KaTeX_Size2}.katex .accent>.vlist-t,.katex .op-limits>.vlist-t{text-align:center}.katex .accent .accent-body{position:relative}.katex .accent .accent-body:not(.accent-full){width:0}.katex .overlay{display:block}.katex .mtable .vertical-separator{min-width:1px;display:inline-block}.katex .mtable .arraycolsep{display:inline-block}.katex .mtable .col-align-c>.vlist-t{text-align:center}.katex .mtable .col-align-l>.vlist-t{text-align:left}.katex .mtable .col-align-r>.vlist-t{text-align:right}.katex .svg-align{text-align:left}.katex svg{fill:currentColor;stroke:currentColor;height:inherit;width:100%;display:block;position:absolute}.katex svg path{stroke:none}.katex svg{fill-rule:nonzero;fill-opacity:1;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1}.katex img{border-style:none;min-width:0;max-width:none;min-height:0;max-height:none}.katex .stretchy{width:100%;display:block;position:relative;overflow:hidden}.katex .stretchy:after,.katex .stretchy:before{content:""}.katex .hide-tail{width:100%;position:relative;overflow:hidden}.katex .halfarrow-left{width:50.2%;position:absolute;left:0;overflow:hidden}.katex .halfarrow-right{width:50.2%;position:absolute;right:0;overflow:hidden}.katex .brace-left{width:25.1%;position:absolute;left:0;overflow:hidden}.katex .brace-center{width:50%;position:absolute;left:25%;overflow:hidden}.katex .brace-right{width:25.1%;position:absolute;right:0;overflow:hidden}.katex .x-arrow-pad{padding:0 .5em}.katex .cd-arrow-pad{padding:0 .55556em 0 .27778em}.katex .mover,.katex .munder,.katex .x-arrow{text-align:center}.katex .boxpad{padding:0 .3em}.katex .fbox,.katex .fcolorbox{box-sizing:border-box;border:.04em solid}.katex .cancel-pad{padding:0 .2em}.katex .cancel-lap{margin-left:-.2em;margin-right:-.2em}.katex .sout{border-bottom-style:solid;border-bottom-width:.08em}.katex .angl{box-sizing:border-box;border-top:.049em solid;border-right:.049em solid;margin-right:.03889em}.katex .anglpad{padding:0 .03889em}.katex .eqn-num:before{content:"(" counter(katexEqnNo) ")";counter-increment:katexEqnNo}.katex .mml-eqn-num:before{content:"(" counter(mmlEqnNo) ")";counter-increment:mmlEqnNo}.katex .mtr-glue{width:50%}.katex .cd-vert-arrow{display:inline-block;position:relative}.katex .cd-label-left{text-align:left;display:inline-block;position:absolute;right:calc(50% + .3em)}.katex .cd-label-right{text-align:right;display:inline-block;position:absolute;left:calc(50% + .3em)}.katex-display{text-align:center;margin:1em 0;display:block}.katex-display>.katex{text-align:center;white-space:nowrap;display:block}.katex-display>.katex>.katex-html{display:block;position:relative}.katex-display>.katex>.katex-html>.tag{position:absolute;right:0}.katex-display.leqno>.katex>.katex-html>.tag{left:0;right:auto}.katex-display.fleqn>.katex{text-align:left;padding-left:2em}body{counter-reset:katexEqnNo mmlEqnNo}:root{--primary:#004ac6;--primary-light:#dce4ff;--primary-container:#3770e0;--primary-hover:#003da6;--primary-fixed:#b8caff;--secondary:#515f74;--secondary-light:#e8ecf1;--tertiary:#632ecd;--tertiary-light:#f0e8ff;--tertiary-container:#632ecd14;--on-tertiary-container:#4a1da6;--success:#10b981;--success-light:#ecfdf5;--warning:#f59e0b;--warning-light:#fffbeb;--error:#ef4444;--error-light:#fef2f2;--surface:#f5f6fa;--surface-container-lowest:#fff;--surface-container-low:#f0f1f6;--surface-container:#eaebf2;--surface-container-high:#e2e4ec;--surface-container-highest:#fff;--on-surface:#1a1c23;--on-surface-variant:#44474f;--outline-variant:#44474f26;--editor-bg:#0f172a;--shadow-sm:0 2px 8px #1a1c230a;--shadow:0 4px 20px #1a1c230f;--shadow-lg:0 8px 40px #1a1c2314;--shadow-ai:0 4px 24px #632ecd1a;--shadow-primary:0 4px 20px #004ac626;--shadow-float:0 8px 40px #1a1c230f, 0 2px 8px #1a1c230a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-display:"Manrope", sans-serif;--font-body:"Plus Jakarta Sans", sans-serif;--font-code:"JetBrains Mono", monospace;--border-card:1px;--border-card-color:var(--outline-variant);--border-inner:1px;--border-inner-color:var(--outline-variant);--border-text:0px;--border-text-color:transparent;--ease:cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);color:var(--on-surface);background:var(--surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.6}a{color:inherit;text-decoration:none}*{scrollbar-width:thin;scrollbar-color:#0000002e transparent}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0;border-radius:3px}::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:#00000047}::-webkit-scrollbar-corner{background:0 0}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.02em}.app-shell{min-height:100vh;display:flex}.sidebar{background:var(--surface-container-lowest);z-index:200;flex-direction:column;width:260px;padding:28px 0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{margin-bottom:12px;padding:0 14px}.sidebar-brand-name{font-family:var(--font-display);color:var(--primary);letter-spacing:-.03em;font-size:24px;font-weight:800}.sidebar-brand-sub{color:var(--secondary);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-size:11px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:20px 14px;display:flex}.sidebar-link{border-radius:var(--radius-md);color:var(--on-surface-variant);transition:all .15s var(--ease);cursor:pointer;width:100%;font-size:14px;font-weight:500;font-family:var(--font-body);text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:11px 18px;display:flex}.sidebar-link:hover{background:var(--surface-container-low);color:var(--on-surface)}.sidebar-link.active{background:var(--primary-light);color:var(--primary);font-weight:600}.sidebar-link-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.sidebar-ai-btn{background:linear-gradient(135deg, var(--tertiary), var(--tertiary-light,#8b5cf6));color:var(--surface-container-lowest);border-radius:var(--radius-md);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all .2s var(--ease);box-shadow:var(--shadow-ai);border:none;align-items:center;gap:8px;margin:16px 14px;padding:13px 18px;display:flex}.sidebar-ai-btn:hover{transform:translateY(-1px);box-shadow:0 6px 28px #632ecd2e}.sidebar-bottom{flex-direction:column;gap:2px;padding:12px 14px;display:flex}.main-area{z-index:1;flex-direction:column;flex:1;min-height:100vh;margin-left:260px;display:flex;position:relative}.topnav{background:var(--surface-container-lowest);z-index:100;justify-content:space-between;align-items:center;height:64px;padding:0 36px;display:flex;position:sticky;top:0}.topnav-left{align-items:center;gap:16px;display:flex}.topnav-tabs{gap:4px;display:flex}.topnav-tab{border-radius:var(--radius-full);color:var(--on-surface-variant);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-body);transition:all .15s var(--ease);background:0 0;border:none;padding:7px 16px}.topnav-tab:hover{background:var(--surface-container-low)}.topnav-tab.active{background:var(--primary);color:var(--surface-container-lowest)}.topnav-ask-ai{background:linear-gradient(135deg, var(--tertiary), var(--tertiary-light,#8b5cf6));color:var(--surface-container-lowest);border-radius:var(--radius-full);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-body);box-shadow:var(--shadow-ai);transition:all .2s var(--ease);border:none;align-items:center;gap:6px;padding:8px 18px;display:flex}.topnav-ask-ai:hover{transform:translateY(-1px)}.topnav-avatar{background:var(--primary-light);width:36px;height:36px;color:var(--primary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.content{max-width:1200px;padding:40px}.page-title{letter-spacing:-.03em;margin-bottom:8px;font-size:2rem;font-weight:800}.page-subtitle{color:var(--on-surface-variant);margin-bottom:32px;font-size:15px;line-height:1.6}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.section-title{margin-bottom:16px;font-size:1.125rem;font-weight:700}.btn{border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all .2s var(--ease);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 22px;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-container));color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px #004ac640}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:var(--surface-container-high);color:var(--on-surface);border:var(--border-inner) solid var(--border-inner-color)}.btn-secondary:hover{background:var(--surface-container);border-color:var(--primary)}.btn-ghost{color:var(--on-surface-variant);background:0 0}.btn-ai{background:var(--tertiary-container);color:var(--tertiary);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-ai)}.btn-ai:hover{background:#632ecd24;box-shadow:0 6px 28px #632ecd26}.btn-lg{border-radius:var(--radius-md);padding:14px 40px;font-size:16px}.input{background:var(--surface-container-highest);border:var(--border-inner) solid var(--border-inner-color);border-radius:var(--radius-sm);width:100%;font-size:14px;font-family:var(--font-body);color:var(--on-surface);transition:all .2s var(--ease);outline:none;padding:13px 18px}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #004ac61a}.input::placeholder{color:var(--secondary)}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23515F74' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}textarea.input{resize:vertical;min-height:80px}.card{background:var(--surface-container-lowest);border-radius:var(--radius-xl);border:var(--border-card) solid var(--border-card-color);transition:all .25s var(--ease);margin-bottom:20px;padding:28px}.card:hover{box-shadow:var(--shadow)}.course-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.course-card{cursor:pointer;position:relative}.course-card:after{content:"";background:linear-gradient(90deg, var(--primary), var(--tertiary));border-radius:0 0 var(--radius-xl) var(--radius-xl);opacity:0;height:3px;transition:opacity .25s var(--ease);position:absolute;bottom:0;left:0;right:0}.course-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.course-card:hover:after{opacity:1}.course-card h3{margin-bottom:6px;font-size:17px;font-weight:700}.course-card>p{color:var(--on-surface-variant);margin-bottom:14px;font-size:14px}.course-meta{flex-wrap:wrap;gap:8px;display:flex}.course-card-banner{aspect-ratio:3;border-radius:var(--radius-xl) var(--radius-xl) 0 0;background-position:50%;background-size:100% 100%;margin:-28px -28px 16px}.banner-preset-grid{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.banner-preset-item{cursor:pointer;height:40px;transition:all .15s var(--ease);border:2px solid #0000;border-radius:8px}.banner-preset-item:hover{box-shadow:var(--shadow);transform:scale(1.08)}.banner-preset-item.active{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary);transform:scale(1.05)}.course-info-btn{background:var(--surface);border:1px solid var(--outline-variant);width:28px;height:28px;color:var(--on-surface-variant);cursor:pointer;opacity:0;transition:opacity .15s var(--ease), background .15s;z-index:3;letter-spacing:1px;border-radius:50%;justify-content:center;align-items:center;font-size:16px;font-weight:700;line-height:1;display:flex;position:absolute;top:8px;right:42px}.course-card:hover .course-info-btn{opacity:1}.course-info-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.course-info-modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#00000073;justify-content:center;align-items:center;padding:24px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.course-info-modal{background:var(--surface);border-radius:var(--radius-xl);flex-direction:column;width:100%;max-width:480px;max-height:80vh;animation:.2s slideUp;display:flex;overflow:hidden;box-shadow:0 24px 80px #00000040}.course-info-modal-header{justify-content:space-between;align-items:center;gap:12px;padding:24px 28px 0;display:flex}.course-info-modal-header h3{color:var(--on-surface);flex:1;margin:0;font-size:20px;font-weight:800;line-height:1.3}.course-info-modal-close{background:var(--surface-variant);width:32px;height:32px;color:var(--on-surface-variant);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.course-info-modal-close:hover{background:var(--error);color:#fff}.course-info-modal-body{flex:1;padding:20px 28px 28px;overflow-y:auto}.course-info-modal-body .info-stats{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px;display:grid}.course-info-modal-body .info-stat-card{background:var(--surface-variant);text-align:center;border-radius:12px;padding:14px 12px}.course-info-modal-body .info-stat-value{color:var(--primary);font-size:22px;font-weight:800;line-height:1}.course-info-modal-body .info-stat-label{color:var(--on-surface-variant);letter-spacing:.3px;margin-top:4px;font-size:11px;font-weight:600}.course-info-modal-body .info-section{margin-bottom:16px}.course-info-modal-body .info-section-label{text-transform:uppercase;letter-spacing:.5px;color:var(--on-surface-variant);margin-bottom:6px;font-size:11px;font-weight:700}.course-info-modal-body .info-section-value{color:var(--on-surface);word-break:break-word;font-size:14px;line-height:1.6}.course-info-modal-body .info-section-value.mono{letter-spacing:1px;color:var(--primary);background:var(--surface-variant);border-radius:6px;padding:4px 12px;font-family:SF Mono,Cascadia Code,Consolas,monospace;font-size:15px;font-weight:700;display:inline-block}.course-info-modal-body .info-divider{background:var(--outline-variant);height:1px;margin:16px 0}.course-info-modal-body .info-objectives-list{color:var(--on-surface);margin:0;padding-left:0;font-size:14px;list-style:none}.course-info-modal-body .info-objectives-list li{padding:8px 0 8px 20px;line-height:1.5;position:relative}.course-info-modal-body .info-objectives-list li:before{content:"";background:var(--primary);opacity:.6;border-radius:50%;width:8px;height:8px;position:absolute;top:14px;left:0}.course-info-modal-body .info-objectives-list li+li{border-top:1px solid var(--outline-variant)}.course-detail-info-btn{background:var(--surface-variant);border:1px solid var(--outline-variant);width:32px;height:32px;color:var(--on-surface-variant);cursor:pointer;letter-spacing:1px;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;line-height:1;transition:background .15s,color .15s;display:flex}.course-detail-info-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.banner-edit-btn{background:var(--surface);border:1px solid var(--outline-variant);width:28px;height:28px;color:var(--on-surface-variant);cursor:pointer;opacity:0;transition:opacity .15s var(--ease), background .15s;z-index:3;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:8px;right:8px}.course-card:hover .banner-edit-btn{opacity:1}.banner-edit-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.banner-hide-btn{background:var(--surface);border:1px solid var(--outline-variant);width:28px;height:28px;color:var(--on-surface-variant);cursor:pointer;opacity:0;transition:opacity .15s var(--ease), background .15s;z-index:3;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:8px;left:8px}.course-card:hover .banner-hide-btn{opacity:1}.banner-hide-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.course-card-link{color:inherit;text-decoration:none;display:block;position:static}.course-card-link:after{content:"";z-index:1;position:absolute;inset:0}.course-card-link h3{margin-bottom:6px;font-size:17px;font-weight:700}.course-card-link>p{color:var(--on-surface-variant);margin-bottom:14px;font-size:14px}.banner-picker-backdrop{z-index:9000;background:#00000059;position:fixed;inset:0}.banner-picker-dropdown{background:var(--surface);border:1px solid var(--outline-variant);border-radius:var(--radius-md);z-index:9001;width:min(340px,90vw);max-height:80vh;box-shadow:var(--shadow-lg);min-width:260px;padding:16px;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%)}.banner-picker-title{color:var(--on-surface-variant);margin-bottom:8px;font-size:13px;font-weight:600}.create-form{background:var(--surface-container-lowest);flex-direction:column;gap:14px;margin-bottom:28px;display:flex;position:relative;overflow:hidden}.create-form:before{content:"";background:linear-gradient(180deg, var(--primary), var(--primary-container));border-radius:4px 0 0 4px;width:4px;position:absolute;top:0;bottom:0;left:0}.create-form h2,.create-form h3{font-size:17px;font-weight:700}.form-actions{gap:10px;margin-top:4px;display:flex}.form-row{gap:12px;display:flex}.badge{border-radius:var(--radius-full);background:var(--surface-container);color:var(--on-surface-variant);border:var(--border-inner) solid var(--border-inner-color);align-items:center;padding:5px 14px;font-size:12px;font-weight:600;display:inline-flex}.badge-invite{background:var(--primary-light);color:var(--primary);font-family:var(--font-code);letter-spacing:.06em;font-size:12px}.badge-policy{background:var(--tertiary-light);color:var(--tertiary)}.badge-high{background:var(--error-light);color:var(--error)}.badge-medium{background:var(--warning-light);color:var(--warning)}.badge-low{background:var(--success-light);color:var(--success)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--surface-container-lowest);border-radius:var(--radius-xl);text-align:center;padding:32px}.stat-label{color:var(--secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;font-size:12px;font-weight:600}.stat-value{font-family:var(--font-display);color:var(--primary);letter-spacing:-.03em;font-size:2.25rem;font-weight:800}.stat-warning .stat-value{color:var(--error)}.table{border-collapse:separate;border-spacing:0 4px;width:100%}.table th{color:var(--secondary);text-transform:uppercase;letter-spacing:.08em;text-align:left;background:var(--surface-container-low);padding:12px 16px;font-size:11px;font-weight:700}.table th:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.table th:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.table td{text-align:left;padding:14px 16px;font-size:14px}.table tbody tr{transition:background .15s var(--ease);border-radius:var(--radius-sm)}.table tbody tr:hover{background:var(--surface-container-low)}.course-detail-banner{aspect-ratio:3;border-radius:var(--radius-xl);background-position:50%;background-size:100% 100%;margin-bottom:20px}.course-info{position:relative;overflow:hidden}.course-info:before{content:"";background:linear-gradient(90deg, var(--primary), var(--tertiary));border-radius:var(--radius-xl) var(--radius-xl) 0 0;height:4px;position:absolute;top:0;left:0;right:0}.course-info h2{margin-bottom:8px;font-size:1.5rem;font-weight:800}.course-info>p{color:var(--on-surface-variant)}.course-objectives{margin-top:20px}.course-objectives strong{color:var(--secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;font-size:11px;display:block}.course-objectives ul{flex-wrap:wrap;gap:8px;list-style:none;display:flex}.course-objectives li{background:var(--surface-container-low);border-radius:var(--radius-full);color:var(--on-surface-variant);padding:7px 18px;font-size:13px}.landing{background:var(--surface-container-lowest);min-height:100vh}.landing-header{justify-content:space-between;align-items:center;padding:24px 48px;display:flex}.landing-hero{text-align:center;background:linear-gradient(180deg, var(--surface-container-lowest) 0%, var(--surface) 100%);flex-direction:column;align-items:center;padding:100px 24px 120px;display:flex}.landing-hero h1{font-family:var(--font-display);letter-spacing:-.03em;color:var(--on-surface);margin-bottom:24px;font-size:3.25rem;font-weight:800;line-height:1.12}.landing-hero h1 span{background:linear-gradient(135deg, var(--primary), var(--tertiary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-sub{color:var(--on-surface-variant);max-width:500px;margin-bottom:44px;font-size:18px;line-height:1.7}.admin-login-toggle{margin-top:20px}.admin-login-form{flex-direction:column;gap:10px;width:100%;max-width:340px;margin-top:16px;display:flex}.admin-login-error{color:var(--error);text-align:center;margin:0;font-size:13px}.landing-features{grid-template-columns:repeat(3,1fr);gap:24px;width:100%;max-width:920px;margin-top:80px;display:grid}.feature-card{border-radius:var(--radius-xl);background:var(--surface-container-lowest);text-align:left;box-shadow:var(--shadow-sm);transition:all .3s var(--ease);padding:36px 28px}.feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.feature-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:22px;font-size:24px;display:flex}.feature-icon-blue{background:var(--primary-light)}.feature-icon-purple{background:var(--tertiary-light)}.feature-icon-green{background:var(--success-light)}.feature-card h3{margin-bottom:10px;font-size:17px;font-weight:700}.feature-card p{color:var(--on-surface-variant);font-size:14px;line-height:1.7}.page-center{background:var(--surface);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;padding:40px 24px;display:flex}.page-center h1{font-family:var(--font-display);font-size:2rem;font-weight:800}.page-center>p{color:var(--on-surface-variant);font-size:16px}.role-cards{gap:28px;margin-top:40px;display:flex}.role-card{background:var(--surface-container-lowest);border-radius:var(--radius-xl);cursor:pointer;text-align:center;width:260px;font-family:var(--font-body);transition:all .3s var(--ease);box-shadow:var(--shadow-sm);border:none;padding:44px 28px}.role-card:hover{box-shadow:var(--shadow-lg);background:var(--primary-light);transform:translateY(-4px)}.role-icon{margin-bottom:18px;font-size:48px;line-height:1}.role-card h2{font-family:var(--font-display);margin-bottom:10px;font-size:20px;font-weight:700}.role-card p{color:var(--on-surface-variant);font-size:13px;line-height:1.6}.editor-page{background:var(--surface-container-lowest);flex-direction:column;height:100vh;display:flex}.editor-topbar{background:var(--surface-container-high);height:54px;color:var(--on-surface);border-bottom:1px solid var(--outline-variant);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 20px;display:flex}.editor-topbar .topbar-left{align-items:center;gap:12px;display:flex}.editor-topbar .btn-ghost{color:var(--on-surface-variant)}.editor-topbar .btn-ghost:hover{color:var(--on-surface);background:var(--surface-container)}.editor-topbar-title{font-family:var(--font-display);font-size:15px;font-weight:600}.editor-topbar .topbar-right{align-items:center;gap:6px;display:flex}.editor-topbar .topbar-saved{color:var(--on-surface-variant);padding:0 4px;font-size:12px}.editor-topbar .topbar-action{border:1px solid var(--outline-variant);background:var(--surface-container-low);color:var(--on-surface);cursor:pointer;white-space:nowrap;font-size:12px;font-weight:600;font-family:var(--font-body);border-radius:6px;align-items:center;gap:5px;padding:5px 12px;transition:all .12s;display:flex}.editor-topbar .topbar-action:hover{background:var(--surface-container);color:var(--on-surface)}.editor-topbar .topbar-action.primary{background:var(--primary);border-color:var(--primary);color:var(--surface-container-lowest)}.editor-topbar .topbar-action.primary:hover{background:var(--primary-hover)}.editor-topbar .topbar-action.ai{background:var(--tertiary-light,#632ecd26);border-color:var(--tertiary-container,#632ecd33);color:var(--tertiary)}.editor-topbar .topbar-action.ai:hover{background:var(--tertiary-container,#632ecd40)}.editor-topbar .topbar-action:disabled{opacity:.4;cursor:not-allowed}.editor-topbar .topbar-icon-btn{width:30px;height:30px;color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .12s;display:flex}.editor-topbar .topbar-icon-btn:hover{background:var(--surface-container);color:var(--on-surface)}.editor-layout{flex:1;display:flex;overflow:hidden}.material-panel{background:var(--surface-container-lowest);border-right:1px solid var(--outline-variant);flex-direction:column;flex-shrink:0;width:420px;min-width:320px;max-width:50vw;display:flex}.material-panel-header{border-bottom:1px solid var(--outline-variant);background:var(--surface-container-low);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.material-panel-title{color:var(--on-surface);font-size:13px;font-weight:700}.material-panel-list{flex-direction:column;flex:1;gap:4px;padding:8px;display:flex;overflow-y:auto}.material-panel-viewer{flex-direction:column;flex:1;display:flex;overflow:hidden}.material-panel-viewer-header{border-bottom:1px solid var(--outline-variant);background:var(--surface-container-low);flex-shrink:0;align-items:center;gap:8px;padding:6px 10px;display:flex}.doc-embed-bar{border-top:1px solid var(--outline-variant);background:var(--surface-container-low);flex-shrink:0;justify-content:flex-end;align-items:center;padding:4px 8px;display:flex}.editor-main{background:var(--editor-bg);flex:1;position:relative;overflow:auto}.editor-sidebar{background:var(--surface-container-lowest);border-left:1px solid var(--outline-variant);flex-direction:column;width:420px;display:flex;overflow-y:auto}.sidebar-tabs{background:var(--surface-container-low);border-bottom:1px solid var(--outline-variant);flex-shrink:0;display:flex}.sidebar-tab{font-size:13px;font-weight:600;font-family:var(--font-body);color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 0;transition:all .12s}.sidebar-tab:hover{color:var(--on-surface);background:var(--surface-container)}.sidebar-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--surface-container-lowest)}.sidebar-tab-content{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.sidebar-ai-tab{overflow-y:auto}.sidebar-material-list{flex-direction:column;flex:1;gap:4px;padding:8px;display:flex;overflow-y:auto}.sidebar-material-viewer{flex-direction:column;flex:1;display:flex;overflow:hidden}.sidebar-material-viewer-bar{border-bottom:1px solid var(--outline-variant);background:var(--surface-container-low);flex-shrink:0;align-items:center;gap:8px;padding:6px 10px;display:flex}.sidebar-material-viewer-title{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.sidebar-section{padding:24px}.sidebar-section+.sidebar-section{background:var(--surface-container-low)}.sidebar-section:nth-child(odd){background:0 0}.sidebar-section h3{font-family:var(--font-display);color:var(--secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;font-size:12px;font-weight:700}.problem-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.problem-header h3{margin:0}.problem-nav{gap:4px;display:flex}.btn-sm{padding:4px 10px!important;font-size:12px!important}.problem-desc{color:var(--on-surface-variant);font-size:14px;line-height:1.75}.editor-sidebar .problem-desc,.problem-desc.markdown-body,.editor-sidebar .markdown-body{color:var(--on-surface)}.editor-sidebar .markdown-body p{margin:.4em 0}.editor-sidebar .markdown-body code{background:var(--surface-container-high);color:var(--primary);border-radius:4px;padding:1px 5px;font-size:.9em}.editor-sidebar .markdown-body pre{background:var(--surface-container-high);border-radius:6px;max-height:200px;padding:8px;font-size:12px;overflow:auto}.editor-sidebar .markdown-body ul,.editor-sidebar .markdown-body ol{margin:.4em 0;padding-left:1.4em}.editor-sidebar .markdown-body strong{color:var(--on-surface);font-weight:700}.editor-sidebar .markdown-body h1,.editor-sidebar .markdown-body h2,.editor-sidebar .markdown-body h3{color:var(--on-surface);margin:.6em 0 .3em;font-size:1.05em}.problem-hints{color:var(--on-surface-variant);margin-top:12px;font-size:13px}.problem-hints summary{cursor:pointer;color:var(--primary);margin-bottom:6px;font-weight:600}.problem-hints ul{margin:0;padding-left:20px}.problem-hints li{margin-bottom:4px;line-height:1.6}.sidebar-actions{padding:20px 24px}.sidebar-actions .btn{width:100%;padding:14px}.editor-footer{height:34px;font-size:12px;font-family:var(--font-code);color:#fff6;background:var(--on-surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 20px;display:flex}.editor-main-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}.editor-main-wrapper .editor-main{flex:1;min-height:0}.run-panel{background:#1a1a2e;flex-direction:column;flex-shrink:0;height:200px;display:flex}.run-panel-header{background:#141428;justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.run-panel-tabs{gap:4px;display:flex}.run-panel-tab{color:#ffffff80;font-size:12px;font-weight:600;font-family:var(--font-code);border-radius:6px;padding:4px 10px}.run-panel-tab.active{color:#fff;background:#ffffff14}.stdin-input{color:#fff;font-family:var(--font-code);width:160px;transition:all .15s var(--ease);background:#ffffff0f;border:none;border-radius:6px;outline:none;padding:5px 12px;font-size:12px}.stdin-input:focus{background:#ffffff1a;box-shadow:0 0 0 2px #004ac64d}.stdin-input::placeholder{color:#ffffff4d}.btn-run{background:var(--success);color:#fff;font-size:12px;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:all .15s var(--ease);white-space:nowrap;border:none;border-radius:6px;padding:5px 16px}.btn-run:hover{background:#059669}.btn-run:disabled{opacity:.5;cursor:not-allowed}.run-output{font-family:var(--font-code);color:#e2e8f0;white-space:pre-wrap;background:0 0;flex:1;margin:0;padding:12px 16px;font-size:13px;line-height:1.6;overflow-y:auto}.run-error{color:#f87171}.tutor-chat{flex-direction:column;flex:1;display:flex;background:0 0!important}.chat-messages{flex-direction:column;flex:1;gap:12px;max-height:340px;margin-bottom:14px;padding-right:4px;display:flex;overflow-y:auto}.chat-empty{text-align:center;color:var(--secondary);padding:28px 0;font-size:13px;line-height:1.6}.chat-bubble{white-space:pre-wrap;border-radius:18px;max-width:85%;padding:12px 16px;font-size:14px;line-height:1.55}.chat-user{background:linear-gradient(135deg, var(--primary), var(--primary-container));color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.chat-ai{background:var(--tertiary-light);color:var(--on-surface);box-shadow:var(--shadow-ai);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom-left-radius:4px;align-self:flex-start}.chat-input-row{gap:8px;display:flex}.chat-input-row .input{border-radius:var(--radius-full);background:var(--surface-container-low);padding:10px 18px}.chat-input-row .btn{background:linear-gradient(135deg, var(--tertiary), #8b5cf6);color:#fff;width:40px;height:40px;box-shadow:var(--shadow-ai);border-radius:50%;flex-shrink:0;padding:0;font-size:16px}.note-title-input{max-width:500px;font-family:var(--font-display);color:var(--on-surface);background:0 0;border:none;outline:none;font-size:20px;font-weight:700}.note-title-input::placeholder{color:var(--on-surface-variant)}.note-title-input:focus{box-shadow:none}.note-editor{padding:44px 52px 44px 80px;overflow-y:auto;background:var(--surface-container-lowest)!important}.note-editor .tiptap{min-height:400px;font-size:16px;line-height:1.85;font-family:var(--font-body);color:var(--on-surface);outline:none}.note-editor .tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--secondary);pointer-events:none;float:left;height:0}.note-editor .tiptap h1{font-family:var(--font-display);letter-spacing:-.02em;margin:28px 0 12px;font-size:1.75rem;font-weight:800}.note-editor .tiptap h2{font-family:var(--font-display);letter-spacing:-.02em;margin:24px 0 10px;font-size:1.375rem;font-weight:700}.note-editor .tiptap h3{font-family:var(--font-display);margin:20px 0 8px;font-size:1.125rem;font-weight:700}.note-editor .tiptap p{margin-bottom:8px}.note-editor .tiptap ul,.note-editor .tiptap ol{margin-bottom:8px;padding-left:24px}.note-editor .tiptap li{margin-bottom:4px}.note-editor .tiptap blockquote{border-left:3px solid var(--primary);color:var(--on-surface-variant);margin:12px 0;padding-left:16px;font-style:italic}.note-editor .tiptap .citation-block{border-left:4px solid var(--tertiary,#7c68ee);background:var(--surface-container-low);counter-increment:citation;border-radius:0 8px 8px 0;margin:16px 0;padding:14px 18px 10px;font-style:italic;position:relative}.note-editor .tiptap .citation-block:before{content:counter(citation);background:var(--tertiary,#7c68ee);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-style:normal;font-weight:700;line-height:1;display:flex;position:absolute;top:-8px;left:-14px}.note-editor .tiptap .citation-block .citation-content{color:var(--on-surface);margin-bottom:6px;font-style:italic}.note-editor .tiptap .citation-block .citation-source{color:var(--on-surface-variant);border-top:1px solid var(--outline-variant);margin-top:8px;padding-top:6px;font-size:12px;font-style:normal}.note-editor .tiptap .citation-block .citation-source a{color:var(--primary);text-decoration:underline}.note-editor .tiptap{counter-reset:citation}.citation-input-popup{background:var(--surface-container);border:1px solid var(--outline-variant);border-radius:10px;flex-direction:column;gap:4px;padding:14px;display:flex;box-shadow:0 4px 20px #0000001f}.note-editor .tiptap .ProseMirror-yjs-cursor{word-break:normal;pointer-events:none;border-left:2px solid orange;margin-left:-1px;margin-right:-1px;position:relative}.note-editor .tiptap .ProseMirror-yjs-cursor>div{color:#fff;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;border-radius:4px 4px 4px 0;padding:1px 6px;font-size:10px;font-style:normal;font-weight:600;line-height:1.5;position:absolute;top:-1.5em;left:-2px}.note-editor .tiptap .yRemoteSelection{opacity:.3}.note-editor .tiptap code{font-family:var(--font-code);background:var(--surface-container);color:var(--tertiary);border-radius:4px;padding:2px 6px;font-size:.875rem}.note-editor .tiptap pre{color:#cdd6f4;border-radius:var(--radius-md);font-family:var(--font-code);background:#1e1e2e;margin:12px 0;padding:18px 22px;font-size:.875rem;line-height:1.6;overflow-x:auto}.note-editor .tiptap pre code{color:inherit;font-size:inherit;background:0 0;padding:0}.note-editor .tiptap hr{background:var(--surface-container);border:none;border-radius:1px;height:2px;margin:28px 0}.note-editor .tiptap strong{font-weight:700}.note-editor .tiptap em{font-style:italic}.note-editor .tiptap sup{vertical-align:super;font-size:.75em;line-height:0}.note-editor .tiptap sub{vertical-align:sub;font-size:.75em;line-height:0}.note-editor .tiptap a{color:var(--primary);text-decoration:underline}.note-toolbar{background:var(--surface-container-low);border-radius:var(--radius-md) var(--radius-md) 0 0;border-bottom:1px solid var(--outline-variant);z-index:10;flex-wrap:wrap;align-items:center;gap:2px;padding:8px 12px;display:flex;position:sticky;top:0}.toolbar-group{align-items:center;gap:1px;display:flex;position:relative}.toolbar-group-label{color:var(--on-surface-variant);letter-spacing:.5px;text-transform:uppercase;opacity:.6;-webkit-user-select:none;user-select:none;align-self:center;padding:0 4px 0 6px;font-size:9px}.toolbar-btn{border-radius:var(--radius-sm);cursor:pointer;width:34px;height:34px;font-size:13px;font-weight:600;font-family:var(--font-body);color:var(--on-surface-variant);transition:all .15s var(--ease);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.toolbar-btn:hover{background:var(--surface-container);color:var(--on-surface)}.toolbar-btn.active{background:var(--primary-light);color:var(--primary)}.toolbar-divider{background:var(--outline-variant);width:1px;height:20px;margin:0 4px}.note-toolbar.compact{gap:3px;padding:6px 12px}.toolbar-drop{position:relative}.toolbar-drop-btn{border-radius:var(--radius-sm);cursor:pointer;color:var(--on-surface-variant);font-size:12px;font-weight:600;font-family:var(--font-body);white-space:nowrap;background:0 0;border:none;align-items:center;gap:3px;padding:4px 10px;transition:all .12s;display:flex}.toolbar-drop-btn:hover,.toolbar-drop-btn.open{background:var(--surface-container);color:var(--on-surface)}.toolbar-drop-panel{z-index:100;background:var(--surface-container-lowest);border:1px solid var(--outline-variant);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:170px;padding:4px;animation:.1s ease-out slashFadeIn;position:absolute;top:calc(100% + 4px);left:0}.drop-row{cursor:pointer;width:100%;font-size:13px;font-family:var(--font-body);color:var(--on-surface);text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:7px 10px;transition:background .1s;display:flex}.drop-row:hover,.drop-row.active{background:var(--primary-light)}.drop-row.active{color:var(--primary);font-weight:600}.drop-row-icon{flex-shrink:0;justify-content:center;align-items:center;width:24px;font-size:12px;font-weight:700;display:flex}.toolbar-btn.color-pick{cursor:pointer;position:relative}.toolbar-popup{z-index:100;background:var(--surface);border:1px solid var(--outline-variant);border-radius:var(--radius-md);box-shadow:var(--shadow-md);white-space:nowrap;align-items:center;gap:8px;padding:10px;display:flex;position:absolute;top:calc(100% + 6px);left:0}.note-editor .tiptap table{border-collapse:collapse;width:100%;margin:16px 0;font-size:14px}.note-editor .tiptap table td,.note-editor .tiptap table th{border:1px solid var(--outline-variant);vertical-align:top;min-width:60px;padding:8px 12px;position:relative}.note-editor .tiptap table th{background:var(--surface-variant);text-align:left;font-weight:600}.note-editor .tiptap table .selectedCell:after{content:"";pointer-events:none;background:#004ac614;position:absolute;inset:0}.note-editor .tiptap ul[data-type=taskList]{padding-left:4px;list-style:none}.note-editor .tiptap ul[data-type=taskList] li{align-items:flex-start;gap:8px;margin-bottom:6px;display:flex}.note-editor .tiptap ul[data-type=taskList] li>label{flex-shrink:0;margin-top:2px}.note-editor .tiptap ul[data-type=taskList] li>label input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--primary)}.note-editor .tiptap ul[data-type=taskList] li[data-checked=true]>div{color:var(--on-surface-variant);text-decoration:line-through}.note-editor .tiptap .note-image{border-radius:var(--radius-md);max-width:100%;margin:12px 0;display:block}.note-editor .tiptap img.ProseMirror-selectednode{outline:2px solid var(--primary);border-radius:var(--radius-md)}.note-editor .tiptap a.note-link{color:var(--primary);cursor:pointer;text-decoration:underline}.note-editor .tiptap mark{border-radius:3px;padding:0 2px}.bubble-menu{background:var(--surface-container-highest,var(--surface-container-high));border:1px solid var(--outline-variant);border-radius:var(--radius-md);box-shadow:var(--shadow);align-items:center;gap:2px;padding:4px 6px;display:flex}.bubble-btn{cursor:pointer;width:30px;height:30px;color:var(--on-surface);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:13px;font-weight:600;transition:background .12s;display:flex}.bubble-btn:hover{background:var(--surface-container)}.bubble-btn.active{background:var(--primary-light);color:var(--primary)}.bubble-divider{background:var(--outline-variant);width:1px;height:18px;margin:0 3px}.drawing-overlay{z-index:9000;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.drawing-modal{background:var(--surface);border-radius:var(--radius-lg);flex-direction:column;width:92vw;height:88vh;display:flex;overflow:hidden;box-shadow:0 24px 80px #00000040}.drawing-header{border-bottom:1px solid var(--outline-variant);background:var(--surface-container-low);flex-shrink:0;align-items:center;gap:16px;padding:12px 20px;display:flex}.drawing-canvas-wrap{flex:1;min-height:0}.drawing-canvas-wrap .excalidraw,.drawing-canvas-wrap .excalidraw-wrapper{height:100%}.ex-drag-handle{width:18px;height:28px;color:var(--on-surface-variant);opacity:.4;cursor:grab;-webkit-user-select:none;user-select:none;border-radius:4px;justify-content:center;align-items:center;font-size:16px;display:none;position:absolute;top:50%;left:-22px;transform:translateY(-50%)}.ex-drag-handle:hover{opacity:.9;background:var(--surface-3,#444)}[data-node-view-wrapper]:hover .ex-drag-handle{display:flex}.excalidraw-node{border-radius:var(--radius-md);cursor:default;-webkit-user-select:none;user-select:none;box-sizing:border-box;border:2px solid #0000;transition:border-color .15s;display:block;overflow:visible}.excalidraw-node:hover,.excalidraw-node.selected{border-color:var(--primary)}.excalidraw-preview{border-radius:calc(var(--radius-md) - 2px);background:var(--surface-container-low,#fafafa);pointer-events:none;width:100%;height:auto;display:block}.ex-overlay-toolbar{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:var(--radius-md) var(--radius-md) 0 0;opacity:0;pointer-events:none;z-index:100;white-space:nowrap;background:#0f172ae0;flex-wrap:nowrap;align-items:center;gap:2px;min-width:max-content;margin-bottom:2px;padding:5px 8px;transition:opacity .15s;display:flex;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.excalidraw-node:hover .ex-overlay-toolbar,.excalidraw-node.selected .ex-overlay-toolbar{opacity:1;pointer-events:all}.ex-tbar-label{color:#ffffff73;-webkit-user-select:none;user-select:none;margin:0 3px 0 6px;font-size:10px}.ex-tbar-label:first-child{margin-left:0}.ex-tbar-btn{color:#ffffffbf;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:28px;height:26px;padding:0 5px;font-size:11px;font-weight:600;transition:background .1s,color .1s;display:flex}.ex-tbar-btn:hover{color:#fff;background:#ffffff24}.ex-tbar-btn.active{color:#fff;background:#63a2ff59}.ex-tbar-btn.danger:hover{background:#ef444499}.ex-tbar-sep{background:#ffffff2e;flex-shrink:0;width:1px;height:16px;margin:0 3px}.rh{border:2px solid var(--primary);opacity:0;z-index:15;background:#fff;border-radius:50%;width:10px;height:10px;transition:opacity .15s;position:absolute;box-shadow:0 1px 4px #00000040}.excalidraw-node:hover .rh,.excalidraw-node.selected .rh{opacity:1}.rh-TL{top:-5px;left:-5px}.rh-TR{top:-5px;right:-5px}.rh-BR{bottom:-5px;right:-5px}.rh-BL{bottom:-5px;left:-5px}.rh-T{top:-5px;left:50%;transform:translate(-50%)}.rh-B{bottom:-5px;left:50%;transform:translate(-50%)}.rh-L{top:50%;left:-5px;transform:translateY(-50%)}.rh-R{top:50%;right:-5px;transform:translateY(-50%)}.ex-text-overlay{cursor:move;z-index:20;align-items:flex-start;gap:2px;min-width:40px;max-width:60%;display:flex;position:absolute}.ex-text-overlay-text{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;white-space:pre-wrap;word-break:break-word;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0 1px 2px #0006;background:#0f172ab8;border-radius:6px;padding:3px 7px;font-size:13px;line-height:1.4;display:inline-block}.ex-text-overlay-del{color:#fff;cursor:pointer;background:#ef4444d9;border:none;border-radius:50%;flex-shrink:0;width:16px;height:16px;margin-top:2px;padding:0;font-size:12px;line-height:1;display:none}.ex-text-overlay:hover .ex-text-overlay-del{justify-content:center;align-items:center;display:flex}.ex-text-overlay-input{border:1.5px solid var(--primary);color:#fff;resize:both;cursor:text;background:#0f172ae6;border-radius:6px;outline:none;min-width:80px;max-width:200px;padding:3px 7px;font-size:13px;line-height:1.4}.ex-caption{color:var(--on-surface-variant);text-align:center;cursor:default;-webkit-user-select:text;user-select:text;padding:4px 6px;font-size:12px;font-style:italic}.ex-caption:hover{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.ex-caption-edit{align-items:center;gap:6px;padding:4px 2px;display:flex}.ex-caption-input{border:1px solid var(--primary);background:var(--surface-2);color:var(--on-surface);border-radius:4px;outline:none;flex:1;padding:3px 6px;font-size:12px;font-style:italic}.ex-caption-save,.ex-caption-cancel{border:1px solid var(--border);cursor:pointer;background:var(--surface-2);color:var(--on-surface);border-radius:4px;padding:2px 8px;font-size:11px}.ex-caption-save{border-color:var(--primary);color:var(--primary)}.ex-caption-save:hover{background:var(--primary);color:#fff}.ex-caption-cancel:hover{background:var(--surface-3,#444)}.drawing-canvas-wrap{flex:1;min-height:0;position:relative}.drawing-canvas-wrap>div,.drawing-canvas-wrap .excalidraw,.drawing-canvas-wrap .excalidraw-container{height:100%!important}.chat-sidebar-section{border-bottom:1px solid var(--outline-variant);flex-direction:column;height:480px;display:flex}.chat-sidebar-header{flex-shrink:0;align-items:center;gap:8px;padding:14px 18px 10px;display:flex}.chat-sidebar-icon{font-size:16px}.chat-sidebar-title{color:var(--on-surface);letter-spacing:.02em;text-transform:uppercase;flex:1;font-size:13px;font-weight:700}.chat-clear-btn{color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:16px;line-height:1}.chat-clear-btn:hover{background:var(--surface-variant);color:var(--on-surface)}.chat-messages{scrollbar-width:thin;scrollbar-color:var(--outline-variant) transparent;flex-direction:column;flex:1;gap:14px;min-height:0;padding:8px 14px 12px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:var(--outline-variant);border-radius:4px}.chat-empty{color:var(--on-surface-variant);text-align:center;flex-direction:column;align-items:center;gap:10px;padding:28px 16px 8px;font-size:13px;line-height:1.65;display:flex}.chat-empty-icon{opacity:.6;font-size:28px}.chat-bubble-wrap{align-items:flex-end;gap:8px;display:flex}.chat-bubble-wrap-user{flex-direction:row-reverse}.chat-bubble-wrap-ai{flex-direction:row}.chat-avatar{color:#fff;letter-spacing:0;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:9px;font-weight:700;display:flex}.chat-bubble{word-break:break-word;max-width:82%;padding:9px 13px;font-size:13px;line-height:1.6}.chat-bubble-user{background:var(--primary);color:#fff;border-radius:18px 18px 4px}.chat-bubble-ai{background:var(--surface-container-low);color:var(--on-surface);border:1px solid var(--outline-variant);border-radius:18px 18px 18px 4px}.chat-bubble-ai .rendered-markdown{color:var(--on-surface);font-size:13px}.chat-bubble-ai .rendered-markdown p:first-child{margin-top:0}.chat-bubble-ai .rendered-markdown p:last-child{margin-bottom:0}.chat-bubble-ai .rendered-markdown ul,.chat-bubble-ai .rendered-markdown ol{margin:6px 0;padding-left:18px}.chat-bubble-ai .rendered-markdown code{background:var(--surface-container);color:var(--on-surface);border-radius:4px;padding:1px 5px;font-size:12px}.chat-bubble-loading{padding:12px 16px}.chat-dots{align-items:center;gap:5px;display:flex}.chat-dots span{background:var(--on-surface-variant);opacity:.6;border-radius:50%;width:7px;height:7px;animation:1.3s ease-in-out infinite chat-bounce}.chat-dots span:first-child{animation-delay:0s}.chat-dots span:nth-child(2){animation-delay:.22s}.chat-dots span:nth-child(3){animation-delay:.44s}@keyframes chat-bounce{0%,70%,to{opacity:.4;transform:translateY(0)}35%{opacity:1;transform:translateY(-5px)}}.chat-input-row{border-top:1px solid var(--outline-variant);background:var(--surface-container-lowest);flex-shrink:0;align-items:center;gap:8px;padding:10px 14px 14px;display:flex}.chat-input{background:var(--surface-container-lowest);border:1.5px solid var(--outline-variant);color:var(--on-surface);border-radius:22px;outline:none;flex:1;min-height:38px;padding:9px 16px;font-size:13px;transition:border-color .15s}.chat-input::placeholder{color:var(--on-surface-variant);opacity:.7}.chat-send-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:background .15s,transform .1s,box-shadow .15s;display:flex}.chat-send-btn:hover:not(:disabled){background:var(--primary-dark,#3b5bdb);transform:scale(1.06);box-shadow:0 3px 10px #6366f166}.ai-polished-block{display:block}.show-ai-marks .ai-polished-block{border-radius:0 var(--radius-md) var(--radius-md) 0;background:#8b5cf60a;border-left:3px solid #8b5cf6;margin:6px 0;padding-left:14px;position:relative}.show-ai-marks .ai-polished-block:before{content:"✨ AI 다듬기";color:#7c3aed;letter-spacing:.03em;pointer-events:none;background:#8b5cf61f;border:1px solid #8b5cf640;border-radius:10px;padding:1px 8px;font-size:10px;font-weight:700;position:absolute;top:-11px;right:0}.btn-polish{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;font-weight:600}.btn-polish:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%);transform:translateY(-1px);box-shadow:0 4px 12px #6366f159}.btn-polish:disabled{opacity:.55;cursor:not-allowed}.polish-panel{border-radius:var(--radius-lg);border:1.5px solid #6366f1;margin-top:24px;animation:.25s polish-slide-in;overflow:hidden}@keyframes polish-slide-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.polish-panel-header{background:linear-gradient(135deg,#6366f11f 0%,#8b5cf614 100%);border-bottom:1px solid #6366f133;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.polish-panel-title{align-items:center;gap:8px;font-size:14px;display:flex}.polish-panel-hint{color:var(--on-surface-variant);font-size:12px;font-weight:400}.polish-toggle{border:1px solid var(--outline-variant);border-radius:6px;padding:3px 12px;font-size:12px}.polish-toggle.active{background:var(--primary);color:#fff;border-color:var(--primary)}.polish-panel-body{background:var(--surface);min-height:120px;max-height:60vh;overflow-y:auto}.polish-preview{padding:20px 24px;font-size:14px;line-height:1.75}.polish-textarea{width:100%;min-height:200px;max-height:60vh;font-family:var(--font-mono);background:var(--surface-2,#1e2330);color:var(--on-surface);resize:vertical;box-sizing:border-box;border:none;outline:none;padding:20px 24px;font-size:13px;line-height:1.7;display:block}.polish-panel-actions{background:var(--surface-2,#1e2330);border-top:1px solid var(--outline-variant);flex-wrap:wrap;align-items:center;gap:8px;padding:12px 16px;display:flex}.polish-action-hint{color:var(--on-surface-variant);margin-left:auto;font-size:12px}.shortcuts-overlay{z-index:9000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.shortcuts-modal{background:var(--surface);border-radius:var(--radius-lg);width:90%;max-width:400px;box-shadow:var(--shadow-lg);max-height:80vh;padding:28px 32px;overflow-y:auto}.shortcut-key{background:var(--surface-variant);border:1px solid var(--outline-variant);font-size:12px;font-family:var(--font-mono);color:var(--on-surface);white-space:nowrap;border-radius:6px;padding:2px 8px;display:inline-block}.ai-comment{border-radius:var(--radius-md);margin-bottom:10px;padding:16px 18px;font-size:13px;line-height:1.65}.ai-comment.correct{background:var(--success-light)}.ai-comment.incorrect{background:var(--error-light)}.comment-target{color:var(--secondary);margin-bottom:6px;font-size:12px;font-style:italic}.understanding-score{font-family:var(--font-display);color:var(--tertiary);text-align:center;letter-spacing:-.03em;margin:16px 0;font-size:3rem;font-weight:800}.insights-card{background:var(--tertiary-container);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:relative;overflow:hidden}.insights-card:before{content:"";background:linear-gradient(180deg, var(--tertiary), #8b5cf6);border-radius:4px 0 0 4px;width:4px;position:absolute;top:0;bottom:0;left:0}.insights-card h2{color:var(--tertiary);margin-bottom:14px;font-size:17px;font-weight:700}.insights-card h3{color:var(--on-surface);margin-top:16px;margin-bottom:8px;font-size:14px;font-weight:600}.insights-card p{color:var(--on-surface-variant);margin-bottom:4px;font-size:14px;line-height:1.65}.insights-card ul{color:var(--on-surface-variant);padding-left:18px;font-size:14px}.feedback{background:var(--surface-container-low)}.feedback-text{color:var(--on-surface-variant);word-break:break-word;font-size:13px;line-height:1.7}.feedback-cursor{color:var(--primary);animation:1s step-end infinite blink}@keyframes blink{50%{opacity:0}}.detail-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;animation:.2s fadeIn;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.detail-panel{background:var(--surface);border-radius:var(--radius-xl) 0 0 var(--radius-xl);z-index:1001;flex-direction:column;height:100vh;animation:.25s slideIn;display:flex;position:fixed;top:0;left:260px;right:0;box-shadow:-8px 0 60px #1a1c2326}.detail-panel-header{background:var(--surface-container-lowest);border-radius:var(--radius-xl) 0 0 0;flex-shrink:0;padding:20px 28px 0}.detail-panel-title-row{align-items:center;gap:12px;margin-bottom:14px;display:flex}.detail-panel-title-row h2{flex:1;margin:0;font-size:18px;font-weight:700}.detail-score-badge{color:#fff;background:linear-gradient(135deg, var(--primary), var(--primary-container));white-space:nowrap;border-radius:20px;padding:5px 16px;font-size:15px;font-weight:700}.detail-tabs{gap:0;display:flex}.detail-tab{color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 20px;font-size:13px;font-weight:600;transition:all .15s}.detail-tab:hover{color:var(--on-surface)}.detail-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.detail-panel-body{flex:1;display:flex;overflow:hidden}.detail-panel-left{background:var(--surface-container-lowest);flex:3;overflow:auto}.detail-panel-right{background:var(--surface-container-low);flex:2;overflow:auto}.detail-code{font-family:var(--font-code);white-space:pre;color:#cdd6f4;background:#1e1e2e;min-height:100%;margin:0;padding:0;font-size:13px;line-height:1.7}.code-line{padding:0 16px 0 0;display:flex}.code-line:hover{background:#ffffff0a}.code-line-num{text-align:right;color:#585b70;-webkit-user-select:none;user-select:none;background:#0000001f;flex-shrink:0;width:52px;margin-right:16px;padding-right:16px}.code-line-text{flex:1}.detail-note-body{color:var(--on-surface);padding:32px 36px;font-size:15px;line-height:1.8}.detail-note-body p{margin:0 0 4px}.detail-note-body .empty-line{height:12px}.detail-feedback-full{padding:28px}.detail-feedback-full h3{color:var(--on-surface);background:linear-gradient(90deg, var(--surface-container), transparent) no-repeat bottom;background-size:100% 1px;margin:0 0 16px;padding-bottom:12px;font-size:14px;font-weight:700}.detail-feedback-body{color:var(--on-surface-variant);word-break:break-word;font-size:14px;line-height:1.8}.detail-feedback-body h4{color:var(--on-surface);margin:0 0 8px;font-size:13px;font-weight:700}.detail-feedback-body ul{margin:0 0 8px;padding-left:20px}.detail-feedback-body li{margin-bottom:6px;line-height:1.6}.detail-feedback-body p{margin:0 0 12px}.diff-view{background:#1e1e2e;min-height:100%}.diff-line{min-height:22px;line-height:22px;display:flex}.diff-num{text-align:right;color:#585b70;-webkit-user-select:none;user-select:none;flex-shrink:0;width:44px;padding-right:8px;font-size:12px}.diff-num-old{background:#0000001a}.diff-num-new{background:#0000000f}.diff-marker{text-align:center;-webkit-user-select:none;user-select:none;color:#585b70;flex-shrink:0;width:24px;font-weight:600}.diff-content{flex:1;padding-right:16px}.diff-line.diff-add{background:#a6e3a11a}.diff-line.diff-add .diff-content,.diff-line.diff-add .diff-marker,.diff-line.diff-add .diff-num{color:#a6e3a1}.diff-line.diff-remove{background:#f38ba81a}.diff-line.diff-remove .diff-content,.diff-line.diff-remove .diff-marker,.diff-line.diff-remove .diff-num{color:#f38ba8}.diff-line.diff-context .diff-content{color:#cdd6f4}.diff-line.diff-paste{background:#632ecd24}.diff-line.diff-paste .diff-content{color:#c4b5fd}.diff-line.diff-paste .diff-marker,.diff-line.diff-paste .diff-num{color:#a78bfa}.code-line-paste{background:#632ecd24}.code-line-paste .code-line-text{color:#c4b5fd}.code-line-paste .code-line-num{color:#a78bfa}.diff-paste-badge{color:#fff;background:var(--tertiary);letter-spacing:.03em;border-radius:4px;flex-shrink:0;margin-left:8px;padding:1px 6px;font-size:10px;font-weight:700}.rendered-markdown h1{font-family:var(--font-display);color:var(--on-surface);margin:0 0 12px;font-size:1.5rem;font-weight:700}.rendered-markdown h2{font-family:var(--font-display);color:var(--on-surface);margin:24px 0 8px;font-size:1.25rem;font-weight:700}.rendered-markdown h3{font-family:var(--font-display);color:var(--on-surface);margin:20px 0 6px;font-size:1.06rem;font-weight:600}.rendered-markdown p{margin:0 0 10px;line-height:1.8}.rendered-markdown ul,.rendered-markdown ol{margin:0 0 12px;padding-left:24px}.rendered-markdown li{margin-bottom:4px;line-height:1.7}.rendered-markdown blockquote{border-left:3px solid var(--primary);background:var(--surface-container-low);color:var(--on-surface-variant);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:8px 0 12px;padding:10px 18px}.rendered-markdown pre{color:#cdd6f4;border-radius:var(--radius-md);font-family:var(--font-code);background:#1e1e2e;margin:8px 0 12px;padding:16px 18px;font-size:.875rem;line-height:1.6;overflow-x:auto}.rendered-markdown code{background:var(--surface-container);font-family:var(--font-code);color:var(--tertiary);border-radius:4px;padding:2px 6px;font-size:.875em}.rendered-markdown pre code{color:inherit;background:0 0;padding:0}.rendered-markdown hr{background:var(--outline-variant);border:none;height:1px;margin:24px 0}.rendered-markdown strong{font-weight:700}.rendered-markdown em{font-style:italic}.rendered-markdown s{color:var(--on-surface-variant);text-decoration:line-through}.loading-spinner{color:var(--secondary);justify-content:center;align-items:center;gap:12px;padding:80px 0;font-size:15px;display:flex}.loading-spinner:before{content:"";border:2.5px solid var(--surface-container);border-top-color:var(--primary);border-radius:50%;width:22px;height:22px;animation:.65s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty{color:var(--secondary);text-align:center;padding:80px 0;font-size:15px;line-height:1.7}.page{background:var(--surface);flex-direction:column;min-height:100vh;display:flex}.topbar{background:var(--surface-container-lowest);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-left,.topbar-right{align-items:center;gap:10px;display:flex}.topbar-right>span{color:var(--on-surface-variant);font-size:14px}.logo{font-family:var(--font-display);color:var(--primary);letter-spacing:-.03em;font-size:22px;font-weight:800}@media (width<=1024px){.main-area{margin-left:0}.detail-panel{left:0}.landing-hero h1{font-size:2.25rem}.landing-features{grid-template-columns:1fr;max-width:400px}.content{padding:24px 20px}.course-grid{grid-template-columns:1fr}}@media (width<=768px){.editor-sidebar{display:none}.role-cards{flex-direction:column;align-items:center}.stats-grid{grid-template-columns:1fr 1fr}.form-row{flex-direction:column}.topbar{padding:0 16px}.detail-panel{border-radius:0;left:0}}.material-card{align-items:center;gap:14px;display:flex;margin:0!important;padding:14px 18px!important}.material-icon{border-radius:var(--radius-sm);background:var(--primary-light);width:40px;height:40px;color:var(--primary);letter-spacing:-.5px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:800;display:flex}.material-info{flex:1;min-width:0}.material-title{color:var(--on-surface);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.material-meta{color:var(--on-surface-variant);margin-top:2px;font-size:12px}.math-inline-wrapper{cursor:pointer;vertical-align:middle;border-radius:4px;align-items:center;padding:0 2px;transition:background .15s;display:inline-flex}.math-inline-wrapper:hover,.math-inline-wrapper.selected,.math-inline-wrapper.editing{background:var(--primary-light)}.math-inline-render{display:inline}.math-inline-input{background:var(--surface-container-lowest);border:1.5px solid var(--primary);min-width:100px;color:var(--on-surface);border-radius:4px;outline:none;padding:2px 8px;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:13px}.math-block-wrapper{cursor:pointer;border-radius:var(--radius-sm);margin:16px 0;padding:4px;transition:background .15s,box-shadow .15s}.math-block-wrapper:hover,.math-block-wrapper.selected{background:var(--primary-light);box-shadow:var(--shadow-sm)}.math-block-render{text-align:center;padding:12px 16px;overflow-x:auto}.math-block-wrapper.editing{background:var(--surface-container-low);border:1.5px solid var(--primary);padding:0}.math-block-edit-container{padding:12px 16px}.math-block-label{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:11px;font-weight:600}.math-block-input{background:var(--surface-container-lowest);border:1px solid var(--outline-variant);width:100%;color:var(--on-surface);resize:none;border-radius:6px;outline:none;padding:8px 12px;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:13px;line-height:1.6}.math-block-input:focus{border-color:var(--primary)}.math-block-hint{color:var(--on-surface-variant);text-align:right;margin-top:6px;font-size:11px}.slash-menu-container{animation:.12s ease-out slashFadeIn}@keyframes slashFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.slash-menu{background:var(--surface-container-lowest);border:1px solid var(--outline-variant);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:260px;max-height:340px;padding:6px;overflow-y:auto}.slash-menu::-webkit-scrollbar{width:4px}.slash-menu::-webkit-scrollbar-thumb{background:var(--outline-variant);border-radius:2px}.slash-item{border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .1s;display:flex}.slash-item:hover,.slash-item.active{background:var(--primary-light)}.slash-item-icon{border-radius:var(--radius-sm);background:var(--surface-container);width:32px;height:32px;color:var(--on-surface);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.slash-item.active .slash-item-icon{background:var(--primary);color:var(--surface-container-lowest)}.slash-item-text{flex-direction:column;gap:1px;min-width:0;display:flex}.slash-item-label{color:var(--on-surface);font-size:13px;font-weight:600}.slash-item-desc{color:var(--on-surface-variant);font-size:11px}.slash-empty{text-align:center;color:var(--on-surface-variant);padding:16px;font-size:13px}.block-handle{opacity:0;pointer-events:auto;align-items:center;gap:2px;transition:opacity .15s;display:flex}.block-handle:hover,.note-editor:hover .block-handle{opacity:1}.block-handle-add,.block-handle-drag{background:var(--surface-container-low);cursor:pointer;width:24px;height:24px;color:var(--on-surface-variant);border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:all .12s;display:flex}.block-handle-add:hover{background:var(--primary-light);color:var(--primary)}.block-handle-drag{cursor:grab}.block-handle-drag:hover{background:var(--surface-container);color:var(--on-surface)}.block-handle-drag:active{cursor:grabbing}.block-handle-comment{border:1px solid var(--outline-variant);background:var(--surface-container-lowest);cursor:pointer;width:28px;height:28px;color:var(--primary);border-radius:6px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.block-handle-comment:hover{background:var(--primary);color:var(--surface-container-lowest);border-color:var(--primary);box-shadow:var(--shadow-primary,0 2px 8px #6366f140)}.block-dragging{opacity:.4;border-radius:6px;border:1px dashed var(--primary)!important;background:var(--primary-light,#6366f10d)!important}.block-add-menu{background:var(--surface-container-lowest,#fff);border:1px solid var(--outline-variant,#e0e0e0);border-radius:10px;width:280px;max-height:360px;animation:.12s ease-out blockMenuIn;overflow:hidden;box-shadow:0 8px 24px #0000001f,0 2px 6px #0000000f}@keyframes blockMenuIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.block-add-menu-search{border-bottom:1px solid var(--outline-variant,#e8e8e8);padding:8px 10px}.block-add-menu-search input{border:1px solid var(--outline-variant);background:var(--surface,#f5f5f5);width:100%;color:var(--on-surface);border-radius:6px;outline:none;padding:7px 10px;font-size:13px;transition:border-color .15s}.block-add-menu-search input:focus{border-color:var(--primary)}.block-add-menu-list{scrollbar-width:none;max-height:300px;padding:4px;overflow-y:auto}.block-add-menu-list::-webkit-scrollbar{display:none}.block-add-menu-empty{text-align:center;color:var(--on-surface-variant);padding:16px;font-size:13px}.block-add-menu-item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .1s;display:flex}.block-add-menu-item:hover,.block-add-menu-item.active{background:var(--surface-container,#0000000a)}.block-add-menu-icon{border:1px solid var(--outline-variant,#e0e0e0);background:var(--surface-container-lowest,#fff);width:36px;height:36px;color:var(--on-surface);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:600;display:flex}.block-add-menu-text{flex-direction:column;min-width:0;display:flex}.block-add-menu-label{color:var(--on-surface);font-size:13px;font-weight:600;line-height:1.3}.block-add-menu-desc{color:var(--on-surface-variant);font-size:11px;line-height:1.3}.note-editor .tiptap>:not(pre):hover{background:#004ac604;border-radius:4px}.note-editor .tiptap>.ProseMirror-selectednode{background:#004ac60a;border-radius:4px}.sub-note-block{margin:8px 0}.sub-note-inner{border:1px solid var(--outline-variant);border-radius:var(--radius-sm);cursor:pointer;background:var(--surface-container-lowest);align-items:center;gap:10px;padding:10px 14px;transition:all .15s;display:flex;position:relative}.sub-note-inner:hover{border-color:var(--primary);background:var(--primary-light);box-shadow:var(--shadow-sm)}.sub-note-block.selected .sub-note-inner{border-color:var(--primary);box-shadow:0 0 0 2px #004ac626}.sub-note-icon{width:28px;height:28px;color:var(--on-surface-variant);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sub-note-inner:hover .sub-note-icon{color:var(--primary)}.sub-note-title{color:var(--on-surface);flex:1;font-size:14px;font-weight:600}.sub-note-title-input{color:var(--on-surface);font-size:14px;font-weight:600;font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1}.sub-note-arrow{color:var(--on-surface-variant);font-size:18px;font-weight:300;transition:transform .15s}.sub-note-inner:hover .sub-note-arrow{color:var(--primary);transform:translate(3px)}.sub-note-delete{cursor:pointer;color:var(--on-surface-variant);opacity:0;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:12px;line-height:1;transition:opacity .15s;position:absolute;top:4px;right:4px}.sub-note-inner:hover .sub-note-delete{opacity:.6}.sub-note-delete:hover{color:var(--error);background:#dc262614;opacity:1!important}.sub-note-toast{border-radius:var(--radius-sm);background:var(--warning-light,#fff8e1);border:1px solid var(--warning,#ffc107);color:var(--on-surface);align-items:center;gap:8px;margin-top:6px;padding:10px 14px;font-size:13px;font-weight:500;animation:.25s ease-out subNoteToastIn;display:flex}.sub-note-toast svg{color:var(--warning,#f59e0b);flex-shrink:0}@keyframes subNoteToastIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.note-tree-item{flex-direction:column;display:flex}.note-card-row{flex-direction:row!important;align-items:flex-start!important;gap:0!important;display:flex!important}.note-card-body{cursor:pointer;flex:1;min-width:0}.note-expand-btn{width:28px;height:28px;color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;transition:transform .2s,color .15s,background .15s;display:flex}.note-expand-btn:hover{background:var(--surface-container-high);color:var(--on-surface)}.note-expand-btn.open{color:var(--primary);transform:rotate(90deg)}.note-delete-btn{width:30px;height:30px;color:var(--on-surface-variant);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;transition:opacity .15s,color .15s,background .15s;display:flex}.card:hover .note-delete-btn,.sub-note-card:hover .note-delete-btn{opacity:1}.note-delete-btn:hover{background:var(--error-light);color:var(--error)}.note-delete-btn.small{width:24px;height:24px;margin-top:0}.modal-overlay{z-index:9999;background:#00000073;justify-content:center;align-items:center;animation:.15s ease-out confirmFadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--surface-container-lowest);border-radius:var(--radius-lg);width:92%;max-width:560px;box-shadow:var(--shadow-lg);max-height:85vh;padding:32px;animation:.2s ease-out confirmSlideUp;overflow-y:auto}.modal-card h2{color:var(--on-surface);margin-bottom:20px;font-size:18px;font-weight:700}.form-label{color:var(--on-surface);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input{border:1px solid var(--outline-variant);border-radius:var(--radius-sm);width:100%;font-size:14px;font-family:var(--font-body);background:var(--surface-container-lowest);color:var(--on-surface);box-sizing:border-box;transition:border-color .15s var(--ease);padding:10px 14px}.form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #004ac614}.form-input::placeholder{color:var(--on-surface-variant);opacity:.6}select.form-input{cursor:pointer;appearance:auto}textarea.form-input{resize:vertical;min-height:60px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-group{flex-direction:column;gap:16px;display:flex}.form-actions{justify-content:flex-end;gap:8px;margin-top:24px;display:flex}.btn-ghost{color:var(--on-surface-variant);border:1px solid var(--outline-variant);border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all .15s var(--ease);background:0 0;padding:10px 22px}.btn-ghost:hover{background:var(--surface-container-low);color:var(--on-surface)}.type-chips{flex-wrap:wrap;gap:8px;display:flex}.type-chip{border-radius:var(--radius-full);border:var(--border-inner) solid var(--border-inner-color);background:var(--surface-container-lowest);color:var(--on-surface-variant);font-size:13px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all .15s var(--ease);padding:8px 16px}.type-chip:hover{border-color:var(--primary);color:var(--primary)}.type-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.problem-counts-section{margin-top:4px}.problem-counts-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px;display:grid}.problem-count-item{flex-direction:column;gap:6px;display:flex}.problem-count-item input{text-align:center;font-weight:600}.grading-strictness-group{display:flex}.grading-strictness-btn{border:1px solid var(--outline-variant);background:var(--surface-container-lowest);color:var(--on-surface-variant);font-family:var(--font-body);cursor:pointer;transition:all .15s var(--ease);flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 8px;display:flex}.grading-strictness-btn:not(:first-child){border-left:none}.grading-strictness-btn:hover{background:var(--surface-container-low);color:var(--on-surface)}.grading-strictness-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.grading-strictness-btn.active+.grading-strictness-btn{border-left-color:var(--primary)}.grading-strictness-label{font-size:13px;font-weight:700}.grading-strictness-desc{opacity:.75;font-size:11px}.problem-count-label{color:var(--on-surface);flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.problem-count-tag{border-radius:var(--radius-full);padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.problem-count-tag.bj{color:var(--success);background:#10b9811f}.problem-count-tag.pg{color:var(--tertiary);background:#632ecd1a}@media (width<=600px){.problem-counts-grid{grid-template-columns:1fr}}.confirm-overlay{z-index:9999;background:#00000073;justify-content:center;align-items:center;animation:.15s ease-out confirmFadeIn;display:flex;position:fixed;inset:0}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal{background:var(--surface-container-lowest);border-radius:var(--radius-lg);width:90%;max-width:380px;box-shadow:var(--shadow-lg);text-align:center;padding:32px;animation:.2s ease-out confirmSlideUp}@keyframes confirmSlideUp{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.confirm-icon{margin-bottom:16px}.confirm-title{color:var(--on-surface);margin:0 0 8px;font-size:17px;font-weight:700}.confirm-desc{color:var(--on-surface-variant);margin:0 0 24px;font-size:14px;line-height:1.6}.confirm-desc strong{color:var(--on-surface)}.confirm-actions{justify-content:center;gap:8px;display:flex}.confirm-actions .btn{min-width:100px}.btn-danger{background:var(--error);color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-body);border:none;padding:8px 20px;transition:background .12s}.btn-danger:hover{background:#dc2626}.sub-notes-list{border-left:2px solid var(--outline-variant);flex-direction:column;gap:2px;margin:-4px 0 0 28px;padding:6px 0 4px 12px;display:flex}.sub-note-card{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:8px 12px;font-size:13px;transition:background .12s;display:flex}.sub-note-card:hover{background:var(--primary-light)}.sub-note-card-icon{color:var(--on-surface-variant);flex-shrink:0;display:flex}.sub-note-card-title{color:var(--on-surface);flex:1;font-weight:500}.sub-note-card-date{color:var(--on-surface-variant);flex-shrink:0;font-size:12px}.ws-page{background:var(--surface);flex-direction:column;height:100vh;display:flex;overflow:hidden}.ws-topbar{background:var(--surface-container-lowest);border-bottom:1px solid var(--outline-variant);flex-shrink:0;align-items:center;gap:8px;height:48px;padding:8px 16px;display:flex}.ws-topbar-title{color:var(--on-surface);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.ws-container{flex:1;display:flex;overflow:hidden}.ws-pane{background:var(--surface-container-lowest);border:1px solid var(--outline-variant);border-radius:6px;flex-direction:column;flex:1;min-width:0;min-height:0;margin:2px;display:flex;overflow:hidden}.ws-pane-header{background:var(--surface-container-low);border-bottom:1px solid var(--outline-variant);flex-shrink:0;justify-content:space-between;align-items:center;min-height:36px;padding:6px 12px;display:flex}.ws-pane-title{color:var(--on-surface);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.ws-pane-actions{flex-shrink:0;align-items:center;gap:2px;display:flex}.ws-pane-btn{width:26px;height:26px;color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:16px;transition:background .15s,color .15s;display:flex}.ws-pane-btn:hover{background:var(--surface-container-high);color:var(--on-surface)}.ws-pane-body{flex:1;min-height:0;overflow:auto}.ws-resizer{z-index:10;background:0 0;flex-shrink:0;transition:background .15s}.ws-resizer:hover,.ws-resizer:active{background:var(--primary)}.ws-resizer-horizontal{cursor:col-resize;width:4px;margin:2px 0}.ws-resizer-vertical{cursor:row-resize;height:4px;margin:0 2px}.ws-list{flex-direction:column;gap:2px;padding:8px;display:flex}.ws-list-item{border:1px solid var(--outline-variant);background:var(--surface-container-lowest);cursor:pointer;text-align:left;border-radius:8px;align-items:center;gap:12px;width:100%;padding:10px 12px;transition:background .15s,border-color .15s;display:flex}.ws-list-item:hover{background:var(--primary-light);border-color:var(--primary)}.ws-list-icon{background:var(--surface-container);width:36px;height:36px;color:var(--on-surface-variant);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.ws-list-text{flex:1;min-width:0}.ws-list-title{color:var(--on-surface);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.ws-list-meta{color:var(--on-surface-variant);margin-top:2px;font-size:11px}.ws-note-editor{flex-direction:column;display:flex;overflow:hidden}.ws-note-status{border-bottom:1px solid var(--outline-variant);background:var(--surface-container-low);flex-shrink:0;justify-content:space-between;align-items:center;padding:4px 12px;display:flex}.ws-note-content{flex:1;overflow-y:auto;background:var(--surface-container-lowest)!important;padding:20px 28px!important}.ws-note-content .tiptap{outline:none;min-height:200px;font-size:15px;line-height:1.75}.graph-page{background:var(--surface-container-lowest,#0b1120);height:100vh;color:var(--on-surface,#e2e8f0);font-family:var(--font-body);flex-direction:column;display:flex}.graph-header{background:var(--surface-container-low,#0f172af2);border-bottom:1px solid var(--outline-variant,#ffffff14);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.graph-header-left{align-items:center;gap:12px;display:flex}.graph-header-left .btn{color:var(--on-surface-variant,#94a3b8)}.graph-title{color:var(--on-surface,inherit);margin:0;font-size:18px;font-weight:700}.graph-count{color:var(--on-surface-variant,#64748b);background:var(--surface-container,#ffffff0f);border-radius:99px;padding:2px 10px;font-size:12px}.graph-header-right{gap:8px;display:flex}.graph-panel-btn{border-radius:var(--radius-sm);border:1px solid var(--outline-variant,#ffffff1f);color:var(--on-surface-variant,#94a3b8);cursor:pointer;background:0 0;padding:6px 14px;font-size:13px;transition:all .15s}.graph-panel-btn:hover{background:var(--surface-container,#ffffff0f);color:var(--on-surface,#e2e8f0)}.graph-panel-btn.active{background:var(--primary);color:var(--on-primary,#fff);border-color:var(--primary)}.graph-body{flex:1;display:flex;overflow:hidden}.graph-controls{border-right:1px solid var(--outline-variant,#ffffff0d);background:var(--surface-container-low,#0b112099);flex-direction:column;flex-shrink:0;gap:14px;width:210px;padding:14px 12px;display:flex;overflow-y:auto}.graph-legend h4{text-transform:uppercase;letter-spacing:.5px;color:var(--on-surface-variant,#64748b);margin:0 0 8px;font-size:11px}.legend-row{color:var(--on-surface-variant,#94a3b8);align-items:center;gap:8px;padding:2px 0;font-size:12px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.legend-line{border-top:2px solid;flex-shrink:0;width:20px;height:0}.legend-line.solid{border-color:#06a0b4cc}.legend-line.dashed{border-style:dashed;border-color:#c88c00bf}.legend-line.similar{border:2px solid #a01eb4b3;box-shadow:0 0 4px #a01eb44d}.legend-line.dotted{border-style:dotted;border-color:var(--on-surface-variant,#96969666)}.graph-filter{flex-direction:column;gap:4px;display:flex}.graph-filter label{color:var(--on-surface-variant,#64748b);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.graph-filter input[type=range]{appearance:none;background:var(--outline-variant,#ffffff14);cursor:pointer;border-radius:2px;outline:none;width:100%;height:4px}.graph-filter input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;border:2px solid var(--surface-container-low,#0f172acc);cursor:pointer;background:#60a5fa;border-radius:50%;width:14px;height:14px;transition:box-shadow .15s,transform .15s;box-shadow:0 0 6px #60a5fa4d}.graph-filter input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 10px #60a5fa80}.graph-filter input[type=range]::-moz-range-thumb{cursor:pointer;background:#60a5fa;border:2px solid #0f172acc;border-radius:50%;width:14px;height:14px;box-shadow:0 0 6px #60a5fa4d}.graph-filter input[type=range]::-moz-range-track{background:#ffffff14;border-radius:2px;height:4px}.graph-filter select{background:var(--surface-container,#ffffff0f);border:1px solid var(--outline-variant,#ffffff1f);border-radius:var(--radius-sm);color:var(--on-surface,#e2e8f0);padding:4px 8px;font-size:12px}.graph-filter-hint{color:var(--on-surface-variant,#475569);font-size:11px}.graph-toggle-switch{color:var(--on-surface-variant,#94a3b8);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;font-size:12px;display:flex}.graph-toggle-switch input{display:none}.toggle-track{background:var(--surface-container-high,#ffffff1a);border:1px solid var(--outline-variant,#ffffff14);border-radius:10px;flex-shrink:0;width:34px;height:18px;transition:background .25s,border-color .25s;position:relative}.toggle-thumb{background:var(--on-surface-variant,#64748b);border-radius:50%;width:12px;height:12px;transition:transform .25s cubic-bezier(.4,0,.2,1),background .25s;position:absolute;top:2px;left:2px}.graph-toggle-switch input:checked+.toggle-track{background:#60a5fa40;border-color:#60a5fa66}.graph-toggle-switch input:checked+.toggle-track .toggle-thumb{background:#60a5fa;transform:translate(16px);box-shadow:0 0 6px #60a5fa66}.graph-toggle{color:var(--on-surface-variant,#94a3b8);cursor:pointer;align-items:center;gap:8px;font-size:12px;display:flex}.graph-toggle input{accent-color:var(--primary)}.graph-zoom-btns{gap:4px;display:flex}.graph-zoom-btns .btn{color:var(--on-surface-variant,#94a3b8);padding:4px 10px;font-size:11px}.graph-canvas{background-image:radial-gradient(color-mix(in srgb, var(--on-surface,#1a1c23) 15%, transparent) 1px, transparent 1px);background-position:11px 11px;background-size:22px 22px;flex:1;position:relative;overflow:hidden}.graph-canvas canvas{cursor:grab}.graph-canvas canvas:active{cursor:grabbing}.graph-tooltip{background:var(--surface-container-high,#0f172abf);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--outline-variant,#ffffff14);pointer-events:none;z-index:100;opacity:.9;border-radius:10px;min-width:120px;max-width:220px;padding:8px 12px;animation:.12s ease-out graphTipIn;position:fixed;box-shadow:0 4px 16px #00000026}@keyframes graphTipIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.graph-tooltip-title{color:var(--on-surface,#f1f5f9);margin-bottom:6px;font-size:14px;font-weight:600}.graph-tooltip-row{color:var(--on-surface,#cbd5e1);align-items:center;gap:6px;font-size:13px;display:flex}.graph-tooltip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.graph-tooltip-score{font-size:13px;font-weight:600}.graph-tooltip-tags{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.graph-tooltip-tags span,.graph-tooltip-tag{color:var(--on-surface-variant,#94a3b8);background:var(--surface-container,#ffffff0f);border-radius:4px;padding:1px 6px;font-size:11px}.graph-tooltip-date{color:var(--on-surface-variant,#64748b);margin-top:6px;font-size:11px}.graph-ctx-menu{z-index:200;background:var(--surface-container-high,#0f172af2);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--outline-variant,#ffffff1a);border-radius:12px;min-width:180px;padding:6px;animation:.1s ease-out graphTipIn;position:fixed;box-shadow:0 8px 32px #00000040}.graph-ctx-header{color:var(--on-surface,#e2e8f0);border-bottom:1px solid var(--outline-variant,#ffffff0f);align-items:center;gap:8px;margin-bottom:4px;padding:8px 10px 6px;font-size:13px;font-weight:600;display:flex}.graph-ctx-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.graph-ctx-item{width:100%;color:var(--on-surface,#cbd5e1);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;transition:background .1s,color .1s;display:flex}.graph-ctx-item:hover{background:var(--surface-container,#ffffff14);color:var(--on-surface,#f1f5f9)}.graph-ctx-item svg{opacity:.6;flex-shrink:0}.graph-ctx-item:hover svg{opacity:1}.graph-ctx-divider{background:var(--outline-variant,#ffffff0f);height:1px;margin:4px 8px}.graph-link-banner{z-index:150;background:var(--surface-container-high,#0f172af2);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid #fbbf244d;border-radius:14px;min-width:280px;padding:10px 16px;animation:.15s ease-out graphTipIn;position:absolute;top:12px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000040,0 0 20px #fbbf2414}.graph-link-banner-text{color:#fbbf24;align-items:center;gap:8px;font-size:13px;display:flex}.graph-link-banner-text strong{color:var(--on-surface,#f1f5f9)}.graph-link-banner-actions{gap:8px;margin-top:10px;display:flex}.graph-link-search-btn,.graph-link-cancel-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:5px;padding:5px 14px;font-size:12px;transition:all .15s;display:flex}.graph-link-search-btn{color:#fbbf24;background:#fbbf2426}.graph-link-search-btn:hover{background:#fbbf2440}.graph-link-cancel-btn{background:var(--surface-container,#ffffff0f);color:var(--on-surface-variant,#94a3b8)}.graph-link-cancel-btn:hover{background:var(--surface-container-high,#ffffff1f);color:var(--on-surface,#cbd5e1)}.graph-link-search-panel{border-top:1px solid var(--outline-variant,#ffffff0f);margin-top:10px;padding-top:10px}.graph-link-search-input{border:1px solid var(--outline-variant,#ffffff1a);background:var(--surface-container,#ffffff0d);width:100%;color:var(--on-surface,#f1f5f9);border-radius:8px;outline:none;padding:7px 10px;font-size:13px;transition:border-color .15s}.graph-link-search-input:focus{border-color:#fbbf2466}.graph-link-search-input::placeholder{color:var(--on-surface-variant,#475569)}.graph-link-search-results{max-height:200px;margin-top:6px;overflow-y:auto}.graph-link-search-item{width:100%;color:var(--on-surface,#cbd5e1);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:7px 8px;font-size:13px;transition:background .1s;display:flex}.graph-link-search-item:hover{background:var(--surface-container,#ffffff14);color:var(--on-surface,#f1f5f9)}.graph-link-search-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.graph-link-search-title{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.graph-link-search-score{color:var(--on-surface-variant,#64748b);flex-shrink:0;font-size:11px}.graph-link-search-empty{text-align:center;color:var(--on-surface-variant,#475569);padding:12px;font-size:12px}.edge-filter-chip{cursor:pointer;-webkit-user-select:none;user-select:none}.edge-filter-chip input{display:none}.edge-chip{border:1px solid var(--outline-variant,#ffffff1f);background:var(--surface-container-low,#ffffff0a);color:var(--on-surface-variant,#94a3b8);border-radius:20px;align-items:center;gap:6px;padding:5px 11px;font-size:11px;font-weight:600;-webkit-text-decoration:line-through #94a3b866;text-decoration:line-through #94a3b866;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex}.edge-chip:hover{background:var(--surface-container,#ffffff14)}.edge-chip-line{opacity:.4;border-top:2px solid;flex-shrink:0;width:14px;height:0;transition:border-color .3s,opacity .3s}.edge-chip-line.solid{border-color:#06a0b499}.edge-chip-line.dashed{border-style:dashed;border-color:#c88c0099}.edge-chip-line.similar{border-width:2px;border-color:#a01eb499}.edge-filter-chip input:checked+.edge-chip{color:var(--on-surface,#f1f5f9);text-decoration:none}.edge-filter-chip input:checked+.edge-chip .edge-chip-line{opacity:1}.edge-filter-chip input:checked+.edge-chip-parent{background:#06a0b41a;border-color:#06a0b466;box-shadow:0 0 10px #06a0b41f}.edge-filter-chip input:checked+.edge-chip-parent .edge-chip-line{border-color:#06a0b4e6}.edge-filter-chip input:checked+.edge-chip-link{background:#c88c001a;border-color:#c88c0066;box-shadow:0 0 10px #c88c001f}.edge-filter-chip input:checked+.edge-chip-link .edge-chip-line{border-color:#c88c00d9}.edge-filter-chip input:checked+.edge-chip-similar{background:#a01eb41a;border-color:#a01eb466;box-shadow:0 0 10px #a01eb41f}.edge-filter-chip input:checked+.edge-chip-similar .edge-chip-line{border-color:#a01eb4d9}.graph-side-panel{border-left:1px solid var(--outline-variant,#ffffff0d);background:var(--surface-container-low,#0b1120d9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-shrink:0;width:300px;padding:20px;animation:.2s ease-out graphPanelSlide;position:relative;overflow-y:auto}@keyframes graphPanelSlide{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.graph-panel-close{color:var(--on-surface-variant,#64748b);cursor:pointer;background:0 0;border:none;padding:4px;position:absolute;top:16px;right:16px}.panel-title{color:var(--on-surface,inherit);margin:0 0 4px;font-size:16px;font-weight:700}.panel-desc{color:var(--on-surface-variant,#64748b);margin:0 0 16px;font-size:12px}.panel-empty,.panel-loading{color:var(--on-surface-variant,#64748b);text-align:center;padding:40px 0;font-size:13px}.study-path-list{flex-direction:column;gap:6px;display:flex}.study-path-item{border-radius:var(--radius-sm);background:var(--surface-container,#ffffff08);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.study-path-item:hover{background:var(--surface-container-high,#ffffff14)}.study-path-num{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:flex}.priority-high .study-path-num{color:#ef4444;background:#ef444433}.priority-medium .study-path-num{color:#f59e0b;background:#f59e0b33}.priority-low .study-path-num{color:#22c55e;background:#22c55e33}.study-path-info{flex:1;min-width:0}.study-path-title{white-space:nowrap;text-overflow:ellipsis;color:var(--on-surface,inherit);font-size:13px;font-weight:600;overflow:hidden}.study-path-reason{color:var(--on-surface-variant,#64748b);font-size:11px}.study-path-score{flex-shrink:0;font-size:14px;font-weight:700}.weekly-report{flex-direction:column;gap:16px;display:flex}.report-period{color:var(--on-surface-variant,#64748b);text-align:center;background:var(--surface-container,#ffffff0a);border-radius:var(--radius-sm);padding:4px;font-size:13px}.report-stats{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.report-stat{text-align:center;background:var(--surface-container,#ffffff0a);border-radius:var(--radius-sm);padding:10px 4px}.report-stat-num{color:var(--primary);font-size:20px;font-weight:700;display:block}.report-stat-label{color:var(--on-surface-variant,#64748b);font-size:10px}.report-weak h4{color:var(--on-surface-variant,#64748b);margin:0 0 6px;font-size:12px}.report-weak-item{border-radius:var(--radius-sm);color:var(--on-surface,inherit);cursor:pointer;background:#ef44440f;justify-content:space-between;margin-bottom:4px;padding:6px 10px;font-size:12px;display:flex}.report-weak-item:hover{background:#ef44441f}.report-summary{color:var(--on-surface,#cbd5e1);background:var(--surface-container,#ffffff08);border-radius:var(--radius-sm);border-left:3px solid var(--primary);padding:12px;font-size:13px;line-height:1.6}.mini-tree-panel{flex-direction:column;gap:4px;padding:8px 0;display:flex}.mini-tree-section{margin-bottom:12px;padding:0 4px}.mini-tree-heading{text-transform:uppercase;letter-spacing:.5px;color:var(--on-surface-variant);align-items:center;gap:6px;margin:0 0 8px 8px;font-size:11px;display:flex}.mini-tree-row{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;padding:5px 8px;font-size:13px;transition:background .1s;display:flex}.mini-tree-row:hover{background:var(--primary-light)}.mini-tree-row.current{color:var(--primary);background:#004ac61a;font-weight:600}.mini-tree-toggle{cursor:pointer;color:var(--on-surface-variant);background:0 0;border:none;flex-shrink:0;width:14px;padding:0;transition:transform .15s;display:flex}.mini-tree-toggle.open{transform:rotate(90deg)}.mini-tree-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px;margin:0 4px}.mini-tree-title{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.mini-tree-score{flex-shrink:0;font-size:11px;font-weight:600}.mini-tree-empty{color:var(--on-surface-variant);text-align:center;padding:20px;font-size:13px}.mini-tree-backlink{border-radius:var(--radius-sm);cursor:pointer;color:var(--on-surface);justify-content:space-between;align-items:center;padding:5px 8px;font-size:12px;transition:background .1s;display:flex}.mini-tree-backlink:hover{background:var(--primary-light)}.mini-tree-sim{color:var(--on-surface-variant);font-size:10px}.mini-tree-graph-btn{border-radius:var(--radius-sm);border:1px dashed var(--outline-variant);color:var(--primary);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:6px;margin:12px 8px 0;padding:8px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.mini-tree-graph-btn:hover{background:var(--primary-light);border-style:solid}.note-link-inline{display:inline}.note-link-chip{color:var(--primary);cursor:pointer;vertical-align:baseline;background:#004ac614;border-radius:4px;align-items:center;gap:3px;padding:1px 8px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.note-link-chip:hover{background:#004ac629;text-decoration:underline}.note-link-chip svg{opacity:.6;flex-shrink:0}.note-link-overlay{z-index:200;background:#0000004d;justify-content:center;align-items:flex-start;padding-top:20vh;display:flex;position:fixed;inset:0}.note-link-popup{background:var(--surface);border:1px solid var(--outline-variant);border-radius:var(--radius-md);width:400px;max-height:360px;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.note-link-search-input{border:none;border-bottom:1px solid var(--outline-variant);color:var(--on-surface);font-size:14px;font-family:var(--font-body);background:0 0;outline:none;padding:12px 16px}.note-link-results{flex:1;overflow-y:auto}.note-link-result{text-align:left;width:100%;color:var(--on-surface);cursor:pointer;font-size:13px;font-family:var(--font-body);background:0 0;border:none;align-items:center;gap:10px;padding:10px 16px;transition:background .1s;display:flex}.note-link-result:hover{background:var(--primary-light)}.note-link-result svg{color:var(--on-surface-variant);flex-shrink:0}.note-link-result span{flex:1}.note-link-result-score{color:var(--on-surface-variant);font-size:11px;font-weight:600}.note-link-empty{text-align:center;color:var(--on-surface-variant);padding:20px;font-size:13px}.note-tag-bar{border-top:1px solid var(--outline-variant);background:var(--surface-container-lowest);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;padding:6px 20px;display:flex}.note-tag{color:var(--primary);background:#004ac60f;border-radius:99px;align-items:center;gap:2px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.note-tag-remove{color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1}.note-tag-remove:hover{color:var(--error)}.note-tag-input{color:var(--on-surface);min-width:80px;font-size:12px;font-family:var(--font-body);background:0 0;border:none;outline:none;padding:2px 4px}.note-tag-input::placeholder{color:var(--on-surface-variant)}.theme-picker{margin-bottom:8px}.theme-picker-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;display:grid}.theme-card{border:2px solid var(--outline-variant);border-radius:var(--radius-md);background:var(--surface-container-lowest);cursor:pointer;transition:all .25s var(--ease);flex-direction:column;align-items:center;gap:8px;padding:10px;display:flex;position:relative}.theme-card:hover{border-color:var(--primary);box-shadow:var(--shadow), 0 0 0 1px var(--primary);transform:translateY(-3px)scale(1.02)}.theme-card.active{border-color:var(--primary);background:var(--primary-light);box-shadow:var(--shadow-primary), 0 0 0 1px var(--primary)}.theme-card-preview{border-radius:var(--radius-sm);width:100%;height:68px;display:flex;overflow:hidden;box-shadow:inset 0 0 0 1px #0000000f}.theme-preview-sidebar{flex-direction:column;gap:4px;width:26%;padding:8px 5px;display:flex}.theme-preview-dot{border-radius:2px;width:100%;height:4px}.theme-preview-main{flex-direction:column;flex:1;gap:4px;padding:8px;display:flex}.theme-preview-header{border-radius:3px;width:55%;height:6px}.theme-preview-line{border-radius:2px;width:100%;height:3px}.theme-preview-line.short{width:65%}.theme-preview-accent{border-radius:4px;width:40%;height:8px;margin-top:auto}.theme-card-name{color:var(--on-surface);letter-spacing:-.01em;font-size:12px;font-weight:600}.theme-card-check{filter:drop-shadow(0 1px 3px #0003);position:absolute;top:6px;right:6px}.custom-theme-section{border-top:1px solid var(--outline-variant);margin-top:24px;padding-top:24px}.custom-theme-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.custom-theme-title{color:var(--on-surface);letter-spacing:-.01em;margin:0;font-size:15px;font-weight:800}.btn-template-download{color:var(--primary);background:var(--primary-light);border-radius:var(--radius-full);cursor:pointer;transition:all .2s var(--ease);border:none;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;display:inline-flex}.btn-template-download:hover{background:var(--primary);color:#fff;box-shadow:var(--shadow-primary)}.builtin-theme-customize,.custom-theme-delete,.custom-theme-edit{border:2px solid var(--surface-container-lowest);cursor:pointer;pointer-events:all;opacity:0;width:22px;height:22px;transition:all .2s var(--ease);z-index:2;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;transform:scale(.8)}.builtin-theme-customize{background:var(--primary);color:#fff;font-size:11px;top:-6px;right:-6px}.custom-theme-delete{background:var(--error);color:#fff;font-size:14px;line-height:1;top:-6px;right:-6px}.custom-theme-edit{background:var(--surface-container-high);color:var(--on-surface-variant);font-size:11px;top:-6px;right:18px}.theme-card:hover .builtin-theme-customize,.theme-card:hover .custom-theme-delete,.theme-card:hover .custom-theme-edit{opacity:1;transform:scale(1)}.custom-theme-upload{border:2px dashed var(--outline-variant);border-radius:var(--radius-lg);background:var(--surface-container-low);cursor:pointer;transition:all .25s var(--ease);align-items:center;gap:14px;padding:16px 20px;display:flex}.custom-theme-upload:hover{border-color:var(--primary);background:var(--primary-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.custom-theme-upload-icon{color:var(--on-surface-variant);background:var(--surface-container);width:40px;height:40px;transition:all .2s var(--ease);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.custom-theme-upload:hover .custom-theme-upload-icon{color:var(--primary);background:var(--primary-light)}.custom-theme-upload-text{flex-direction:column;gap:2px;display:flex}.custom-theme-upload-label{color:var(--on-surface);font-size:13px;font-weight:600}.custom-theme-upload-hint{color:var(--on-surface-variant);font-size:11px}.custom-theme-error{color:var(--error);background:var(--error-light);border-radius:var(--radius-md);border:1px solid #ef444426;margin-top:8px;padding:10px 14px;font-size:12px}.toggle-block{border:1px solid var(--outline-variant);border-radius:var(--radius-sm);margin:8px 0;overflow:hidden}.toggle-block[open] .toggle-summary:after{transform:rotate(90deg)}.toggle-summary{cursor:pointer;background:var(--surface-container-low);-webkit-user-select:none;user-select:none;align-items:center;padding:10px 14px;font-size:14px;font-weight:600;list-style:none;display:flex}.toggle-summary:after{content:"▶";transition:transform .2s var(--ease);margin-left:auto;font-size:10px}.toggle-summary::-webkit-details-marker{display:none}.toggle-content{padding:12px 14px}.callout{border-radius:var(--radius-sm);gap:10px;margin:8px 0;padding:14px 16px;font-size:14px;display:flex}.callout-icon{flex-shrink:0;margin-top:1px;font-size:18px}.callout-content{flex:1;min-width:0}.callout-info{background:var(--primary-light);border-left:3px solid var(--primary)}.callout-warning{background:var(--warning-light);border-left:3px solid var(--warning)}.callout-tip{background:var(--success-light);border-left:3px solid var(--success)}.callout-danger{background:var(--error-light);border-left:3px solid var(--error)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulseGlow{0%,to{box-shadow:0 0 #004ac626}50%{box-shadow:0 0 0 8px #004ac600}}.content{animation:.35s ease-out fadeInUp}.card{animation:.3s ease-out fadeInScale}.course-card:active{transition:transform .1s;transform:translateY(0)scale(.98)}.landing-hero{background:linear-gradient(135deg, var(--surface-container-lowest) 0%, var(--primary-light) 25%, var(--surface) 50%, var(--tertiary-light) 75%, var(--surface-container-lowest) 100%);background-size:400% 400%;animation:12s infinite gradientShift}.skeleton{background:linear-gradient(90deg, var(--surface-container-low) 25%, var(--surface-container) 50%, var(--surface-container-low) 75%);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-card{min-height:120px;padding:28px}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 24px;animation:.4s ease-out fadeInUp;display:flex}.empty-state-icon{opacity:.8;margin-bottom:16px;font-size:48px}.empty-state-title{color:var(--on-surface);margin-bottom:8px;font-size:18px;font-weight:700}.empty-state-desc{color:var(--on-surface-variant);max-width:360px;font-size:14px;line-height:1.6}.mobile-menu-btn{z-index:1100;border-radius:var(--radius-sm);border:1px solid var(--outline-variant);background:var(--surface-container-lowest);cursor:pointer;width:40px;height:40px;box-shadow:var(--shadow-sm);transition:all .2s var(--ease);justify-content:center;align-items:center;font-size:18px;display:none;position:fixed;top:12px;left:12px}.mobile-menu-btn:hover{background:var(--surface-container-low)}.sidebar-overlay{z-index:999;background:#0000004d;display:none;position:fixed;inset:0}@media (width<=1024px){.mobile-menu-btn{display:flex}.sidebar{z-index:1000;transition:left .3s var(--ease);box-shadow:var(--shadow-lg);position:fixed;top:0;bottom:0;left:-280px}.sidebar.open{left:0}.sidebar-overlay.open{display:block}.topnav{padding-left:56px}}.btn-primary.pulse{animation:2s ease-in-out 3 pulseGlow}.course-grid>*{animation:.35s ease-out backwards fadeInUp}.course-grid>:first-child{animation-delay:0s}.course-grid>:nth-child(2){animation-delay:50ms}.course-grid>:nth-child(3){animation-delay:.1s}.course-grid>:nth-child(4){animation-delay:.15s}.course-grid>:nth-child(5){animation-delay:.2s}.course-grid>:nth-child(6){animation-delay:.25s}.sidebar-link{transition:all .15s var(--ease)}.sidebar-link:active{transform:scale(.97)}.badge{transition:all .15s var(--ease)}.badge:hover{transform:scale(1.05)}.landing-features>.feature-card{animation:.45s ease-out backwards fadeInUp}.landing-features>.feature-card:first-child{animation-delay:.1s}.landing-features>.feature-card:nth-child(2){animation-delay:.2s}.landing-features>.feature-card:nth-child(3){animation-delay:.3s}.loading-spinner{animation:.3s ease-out fadeIn}.btn:focus-visible,.sidebar-link:focus-visible,.card:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media (width<=480px){.content{padding:20px 16px}.page-title{font-size:1.5rem}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.landing-hero h1{font-size:1.75rem}.landing-sub{font-size:15px}.landing-features{gap:16px}.feature-card{padding:24px 20px}.role-cards{gap:12px}}.sidebar-badge{background:var(--error);color:var(--surface-container-lowest);border-radius:var(--radius-full,9999px);text-align:center;min-width:18px;margin-left:auto;padding:2px 7px;font-size:11px;font-weight:700;line-height:1.3}.sidebar-tab-badge{background:var(--error);color:#fff;border-radius:var(--radius-full,9999px);justify-content:center;align-items:center;min-width:16px;margin-left:4px;padding:1px 5px;font-size:10px;font-weight:700;line-height:1.2;display:inline-flex}.messenger-page{background:var(--surface);height:calc(100vh - 64px);animation:.3s ease-out fadeInUp;display:flex}.messenger-sidebar{border-right:1px solid var(--outline-variant);background:var(--surface-container-lowest);flex-direction:column;flex-shrink:0;width:320px;display:flex}.messenger-sidebar-header{border-bottom:1px solid var(--outline-variant);padding:20px 20px 16px}.messenger-sidebar-header h3{color:var(--on-surface);margin:0;font-size:18px;font-weight:700}.messenger-main{flex-direction:column;flex:1;min-width:0;display:flex}.messenger-empty{text-align:center;color:var(--on-surface-variant);padding:40px 20px;font-size:14px}.conversation-list{flex:1;overflow-y:auto}.conversation-item{border:none;border-bottom:1px solid var(--outline-variant);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:12px;width:100%;padding:12px 20px;transition:background .15s;display:flex}.conversation-item:hover{background:var(--surface-container-low)}.conversation-item.active{background:var(--primary-light)}.conversation-avatar{background:var(--primary-light);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;overflow:hidden}.conversation-avatar img{object-fit:cover;width:100%;height:100%}.conversation-avatar span{color:var(--primary);font-size:16px;font-weight:700}.conversation-info{flex:1;min-width:0}.conversation-name{color:var(--on-surface);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.conversation-preview{color:var(--on-surface-variant);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.conversation-badge{background:var(--error);color:#fff;border-radius:var(--radius-full,9999px);text-align:center;flex-shrink:0;min-width:20px;padding:2px 7px;font-size:11px;font-weight:700}.chat-view{flex-direction:column;height:100%;display:flex}.chat-empty{height:100%;color:var(--on-surface-variant);flex-direction:column;justify-content:center;align-items:center;display:flex}.chat-empty-icon{opacity:.5;margin-bottom:12px;font-size:48px}.chat-empty-text{font-size:14px}.chat-header{border-bottom:1px solid var(--outline-variant);background:var(--surface-container-lowest);align-items:center;gap:12px;padding:16px 24px;display:flex}.chat-header-avatar{background:var(--primary-light);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex;overflow:hidden}.chat-header-avatar img{object-fit:cover;width:100%;height:100%}.chat-header-avatar span{color:var(--primary);font-size:14px;font-weight:700}.chat-header-name{color:var(--on-surface);font-size:15px;font-weight:600}.chat-messages{flex-direction:column;flex:1;gap:8px;padding:20px 24px;display:flex;overflow-y:auto}.chat-messages-empty{text-align:center;color:var(--on-surface-variant);padding:40px 0;font-size:14px}.chat-bubble-wrap{display:flex}.chat-bubble-wrap.mine{justify-content:flex-end}.chat-bubble-wrap.theirs{justify-content:flex-start}.chat-bubble{word-break:break-word;border-radius:16px;max-width:70%;padding:10px 14px;font-size:14px;line-height:1.5}.chat-bubble.mine{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.chat-bubble.theirs{background:var(--surface-container-high);color:var(--on-surface);border-bottom-left-radius:4px}.chat-bubble-text{white-space:pre-wrap}.chat-bubble-time{opacity:.7;text-align:right;margin-top:4px;font-size:11px}.chat-read-status{color:var(--on-surface-variant);font-size:12px;transition:color .2s}.chat-read-status.read{color:var(--success,#22c55e)}.chat-input-area{border-top:1px solid var(--outline-variant);background:var(--surface-container-lowest);align-items:flex-end;gap:8px;padding:12px 24px;display:flex}.chat-input{resize:none;border:1px solid var(--outline-variant);font-size:14px;font-family:var(--font-body);background:var(--surface);color:var(--on-surface);border-radius:12px;outline:none;flex:1;max-height:120px;padding:10px 14px;transition:border-color .15s}.chat-input:focus{border-color:var(--primary)}.chat-send-btn{background:var(--primary);color:var(--surface-container-lowest);cursor:pointer;white-space:nowrap;border:none;border-radius:12px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .15s}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn:hover:not(:disabled){opacity:.9}@media (width<=768px){.messenger-sidebar{width:100%}.messenger-page{flex-direction:column}}.student-notes-page{max-width:900px;margin:0 auto;padding:32px}.student-notes-header h2{color:var(--on-surface);margin:0 0 4px;font-size:22px;font-weight:700}.student-notes-desc{color:var(--on-surface-variant);margin:0 0 24px;font-size:14px}.student-notes-loading,.student-notes-empty{text-align:center;color:var(--on-surface-variant);padding:60px 20px;font-size:14px}.student-notes-list{flex-direction:column;gap:8px;display:flex}.student-notes-card{border:1px solid var(--outline-variant);border-radius:var(--radius-md);background:var(--surface-container-lowest);overflow:hidden}.student-notes-card-header{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:14px 18px;transition:background .15s;display:flex}.student-notes-card-header:hover{background:var(--surface-container-low)}.student-notes-avatar{background:var(--primary-light);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;overflow:hidden}.student-notes-avatar img{object-fit:cover;width:100%;height:100%}.student-notes-avatar span{color:var(--primary);font-size:14px;font-weight:700}.student-notes-info{flex:1}.student-notes-name{color:var(--on-surface);font-size:15px;font-weight:600}.student-notes-count{color:var(--on-surface-variant);margin-left:8px;font-size:12px}.student-notes-chevron{color:var(--on-surface-variant);font-size:12px;transition:transform .2s}.student-notes-chevron.open{transform:rotate(90deg)}.student-notes-note-list{border-top:1px solid var(--outline-variant)}.student-notes-no-notes{color:var(--on-surface-variant);padding:16px 18px;font-size:13px}.student-notes-note-item{border:none;border-bottom:1px solid var(--outline-variant);cursor:pointer;text-align:left;background:0 0;justify-content:space-between;align-items:center;width:100%;padding:12px 18px 12px 48px;transition:background .15s;display:flex}.student-notes-note-item:last-child{border-bottom:none}.student-notes-note-item:hover{background:var(--surface-container-low)}.student-notes-note-title{color:var(--on-surface);font-size:14px;font-weight:500}.student-notes-note-meta{color:var(--on-surface-variant);flex-shrink:0;align-items:center;gap:10px;font-size:12px;display:flex}.student-notes-score{background:var(--primary-light);color:var(--primary);border-radius:var(--radius-full);padding:2px 8px;font-weight:600}.student-notes-comments{font-weight:500}.comments-panel{flex-direction:column;gap:0;height:100%;display:flex}.comments-panel-header{border-bottom:1px solid var(--outline-variant);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.comments-panel-header h4{color:var(--on-surface);margin:0;font-size:15px;font-weight:700}.comments-count{color:var(--on-surface-variant);font-size:12px}.comments-filter{border-bottom:1px solid var(--outline-variant);flex-wrap:wrap;gap:4px;padding:8px 14px;display:flex}.comments-filter-btn{border:1px solid var(--outline-variant);border-radius:var(--radius-full);color:var(--on-surface-variant);cursor:pointer;background:0 0;padding:4px 10px;font-size:11px;transition:all .15s}.comments-filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.comments-list{flex:1;padding:8px 0;overflow-y:auto}.comments-empty{text-align:center;color:var(--on-surface-variant);padding:32px 14px;font-size:13px}.comments-new{border-top:1px solid var(--outline-variant);flex-direction:column;gap:8px;padding:12px 14px;display:flex}.comment-thread{border-bottom:1px solid var(--outline-variant);padding:8px 14px}.comment-replies{border-left:2px solid var(--outline-variant);margin-left:16px;padding-left:12px}.comment-reply-input{flex-direction:column;gap:6px;margin-top:8px;margin-left:16px;display:flex}.comment-reply-actions{gap:6px;display:flex}.comment-item{padding:6px 0}.comment-item.comment-reply{padding:4px 0}.comment-item.resolved{opacity:.6}.comment-item-header{align-items:center;gap:6px;margin-bottom:4px;display:flex}.comment-avatar{background:var(--surface-container-high);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex;overflow:hidden}.comment-avatar img{object-fit:cover;width:100%;height:100%}.comment-avatar span{color:var(--on-surface-variant);font-size:11px;font-weight:700}.comment-meta{flex:1;align-items:center;gap:6px;min-width:0;display:flex}.comment-author{color:var(--on-surface);white-space:nowrap;font-size:13px;font-weight:600}.comment-role-badge{border-radius:var(--radius-full);padding:1px 6px;font-size:10px;font-weight:600}.comment-role-badge.professor{background:var(--tertiary-light,#f0ebff);color:var(--tertiary,#632ecd)}.comment-role-badge.student{background:var(--primary-light);color:var(--primary)}.comment-time{color:var(--on-surface-variant);white-space:nowrap;font-size:11px}.comment-resolved-badge{border-radius:var(--radius-full);background:var(--success-light,#ecfdf5);color:var(--success);margin-left:auto;padding:1px 6px;font-size:10px;font-weight:600}.comment-content{color:var(--on-surface);white-space:pre-wrap;word-break:break-word;margin:2px 0 4px 30px;font-size:13px;line-height:1.5}.comment-actions{gap:4px;margin-left:30px;display:flex}.comment-action-btn{color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:11px;transition:all .15s}.comment-action-btn:hover{background:var(--surface-container-low);color:var(--on-surface)}.comment-action-btn.danger:hover{color:var(--error)}.comment-action-btn.resolve{color:var(--success)}.comment-action-btn.resolve-undo{color:var(--on-surface-variant)}.comment-textarea{resize:none;border:1px solid var(--outline-variant);border-radius:var(--radius-sm);width:100%;font-size:13px;font-family:var(--font-body);background:var(--surface-container-lowest);color:var(--on-surface);box-sizing:border-box;outline:none;padding:8px 10px;transition:border-color .15s}.comment-textarea:focus{border-color:var(--primary)}.comment-edit-area{flex-direction:column;gap:6px;margin:4px 0 4px 30px;display:flex}.comment-edit-input{resize:none;border:1px solid var(--primary);border-radius:var(--radius-sm);width:100%;font-size:13px;font-family:var(--font-body);background:var(--surface-container-lowest);color:var(--on-surface);box-sizing:border-box;outline:none;padding:6px 8px}.comment-edit-actions{gap:6px;display:flex}.btn-sm{border:1px solid var(--outline-variant);border-radius:var(--radius-sm);color:var(--on-surface);cursor:pointer;background:0 0;padding:4px 12px;font-size:12px;font-weight:500;transition:all .15s}.btn-sm:hover{background:var(--surface-container-low)}.btn-sm.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-sm.btn-primary:hover{opacity:.9}.btn-sm.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-sm.btn-ghost{color:var(--on-surface-variant);border-color:#0000}.review-mode-badge{border-radius:var(--radius-sm);background:var(--warning,#f59e0b);color:var(--surface-container-lowest);letter-spacing:.02em;white-space:nowrap;align-items:center;margin-left:8px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.ProseMirror>*{position:relative}.block-comment-indicator{color:var(--on-surface-variant);cursor:pointer;z-index:5;pointer-events:auto;opacity:.7;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:500;transition:all .15s;display:inline-flex;position:absolute}.block-comment-indicator:hover{background:var(--surface-container);color:var(--primary);opacity:1}.block-comment-indicator.active{background:var(--primary-light,#6366f114);color:var(--primary);opacity:1}.bci-count{font-size:11px;line-height:1}.bci-chevron{align-items:center;font-size:16px;font-weight:400;line-height:1;transition:transform .2s;display:inline-flex}.bci-chevron.open{transform:rotate(90deg)}.block-inline-comments{background:var(--surface-container-low,#f8f9fa);border:1px solid var(--outline-variant,#e0e0e0);border-radius:8px;margin:0 0 6px;padding:12px 16px}.block-inline-comments-header{color:var(--on-surface-variant);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:12px;font-weight:600;display:flex}.block-inline-comments-header .bic-close-btn{color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px;line-height:1}.block-inline-comments-header .bic-close-btn:hover{background:var(--surface-container)}.bic-item{background:var(--surface-container-lowest,#fff);border:1px solid var(--outline-variant,#e8e8e8);border-radius:8px;margin-bottom:6px;padding:10px 12px}.bic-item:last-child{margin-bottom:0}.bic-author{color:var(--on-surface);align-items:center;gap:6px;margin-bottom:4px;font-size:12px;font-weight:600;display:flex}.bic-role{background:var(--primary-container,#6366f11a);color:var(--primary);border-radius:10px;padding:1px 6px;font-size:10px;font-weight:500}.bic-content{color:var(--on-surface);font-size:13px;line-height:1.6}.bic-time{color:var(--on-surface-variant);margin-top:4px;font-size:10px}.bic-input-row{gap:8px;margin-top:10px;display:flex}.bic-input-row input{border:1px solid var(--outline-variant);background:var(--surface-container-lowest,#fff);color:var(--on-surface);border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:13px;transition:border-color .15s}.bic-input-row input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #6366f11a}.bic-input-row button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:opacity .15s}.bic-input-row button:hover{opacity:.9}.bic-input-row button:disabled{opacity:.5;cursor:not-allowed}.bic-resolve-btn{color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 8px;font-size:11px;transition:background .12s}.bic-resolve-btn:hover{background:var(--surface-container)}.bic-resolved{opacity:.5}.completed-toggle{cursor:pointer;color:var(--on-surface-variant);border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:8px;padding:8px 4px;font-size:14px;font-weight:600;transition:color .15s;display:flex}.completed-toggle:hover{color:var(--on-surface)}.completed-toggle-arrow{font-size:10px;transition:transform .2s;display:inline-block}.completed-toggle-arrow.open{transform:rotate(90deg)}.assignment-calendar{margin-top:8px}.cal-nav{justify-content:center;align-items:center;gap:16px;margin-bottom:12px;display:flex}.cal-nav-title{color:var(--on-surface);text-align:center;min-width:120px;font-size:16px;font-weight:700}.cal-header{grid-template-columns:repeat(7,1fr);gap:1px;margin-bottom:4px;display:grid}.cal-header-cell{text-align:center;color:var(--on-surface-variant);padding:6px 0;font-size:11px;font-weight:600}.cal-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.cal-cell{background:var(--surface-container-lowest);border:1px solid var(--outline-variant);border-radius:8px;min-height:80px;padding:4px 6px;overflow:hidden}.cal-cell.cal-empty{background:0 0;border:none}.cal-cell.cal-today{border-color:var(--primary);background:var(--primary-light,#6366f10a)}.cal-cell.cal-has-items{background:var(--surface-container-low)}.cal-date{color:var(--on-surface-variant);margin-bottom:4px;font-size:12px;font-weight:600}.cal-today .cal-date{color:var(--primary);font-weight:700}.cal-items{flex-direction:column;gap:3px;display:flex}.cal-item{background:var(--primary-light,#6366f114);cursor:pointer;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;transition:background .12s;display:flex;overflow:hidden}.cal-item:hover{background:var(--primary-container,#6366f126)}.cal-item.cal-overdue{background:var(--error-light,#ef444414)}.cal-item.cal-overdue:hover{background:#ef444426}.cal-cell.cal-holiday .cal-date,.cal-date.cal-date-holiday{color:var(--error)}.cal-item.cal-item-holiday{cursor:default;background:#ef44440f}.cal-item.cal-item-holiday .cal-item-title{color:var(--error);font-size:10px}.cal-item-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.cal-item-title{color:var(--on-surface);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;font-weight:600;overflow:hidden}.cal-item-time{color:var(--on-surface-variant);flex-shrink:0;font-size:10px}.conversation-item .conversation-preview-empty{color:var(--on-surface-variant);font-size:12px;font-style:italic}.note-card-badges{align-items:center;gap:6px;display:flex}.note-card-badge{border-radius:10px;align-items:center;gap:3px;padding:2px 6px;font-size:11px;font-weight:600;display:inline-flex}.note-card-badge.comments{background:var(--primary-container,#6366f11f);color:var(--primary)}.note-card-badge.unread{background:var(--error-container,#ef44441f);color:var(--error,#ef4444)}.notification-bell-wrap{position:relative}.notification-bell-btn{width:36px;height:36px;color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex;position:relative}.notification-bell-btn:hover{background:var(--surface-container);color:var(--on-surface)}.notification-bell-badge{background:var(--error,#ef4444);min-width:16px;height:16px;color:var(--surface-container-lowest);border-radius:8px;justify-content:center;align-items:center;padding:0 4px;font-size:9px;font-weight:700;line-height:1;display:flex;position:absolute;top:2px;right:2px}.notification-panel{background:var(--surface-container-lowest);border:1px solid var(--outline-variant);border-radius:var(--radius-md,12px);z-index:100;flex-direction:column;width:380px;max-height:min(480px,100vh - 80px);display:flex;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 32px #00000026}.notification-panel-header{border-bottom:1px solid var(--outline-variant);justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.notification-panel-header h4{color:var(--on-surface);margin:0;font-size:15px;font-weight:700}.notification-panel-count{color:var(--primary);background:var(--primary-container,#6366f11a);border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600}.notification-panel-body{flex:1;padding:4px 0;overflow-y:auto}.notification-empty{text-align:center;color:var(--on-surface-variant);padding:40px 20px;font-size:13px}.notification-item{cursor:pointer;text-align:left;background:0 0;border:none;gap:10px;width:100%;padding:10px 16px;transition:background .12s;display:flex}.notification-item:hover{background:var(--surface-container-low)}.notification-item-avatar{background:var(--surface-container);width:36px;height:36px;color:var(--on-surface-variant);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex;overflow:hidden}.notification-item-avatar img{object-fit:cover;width:100%;height:100%}.notification-item-content{flex:1;min-width:0}.notification-item-title{color:var(--on-surface);align-items:center;gap:6px;font-size:13px;display:flex}.notification-item-title strong{font-weight:600}.notification-item-tag{border-radius:4px;padding:1px 6px;font-size:10px;font-weight:600}.notification-item-tag.msg{background:var(--primary-container,#6366f11a);color:var(--primary)}.notification-item-tag.cmt{background:var(--warning-light,#f59e0b1f);color:var(--warning,#d97706)}.notification-item-tag.deadline{color:var(--error,#dc2626);background:#dc26261a}.notification-item-tag.material{color:var(--success,#10b981);background:#10b9811a}.notification-item-tag.unsubmitted{color:#ea580c;background:#f973161f}.notification-deadline-icon,.notification-unsubmitted-icon,.notification-material-icon{justify-content:center;align-items:center;width:100%;height:100%;font-size:18px;display:flex}.notification-item-preview{color:var(--on-surface-variant);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.notification-item-meta{color:var(--on-surface-variant);opacity:.7;gap:8px;margin-top:3px;font-size:10px;display:flex}.notification-clear-btn{background:var(--surface-variant);color:var(--on-surface-variant);cursor:pointer;border:none;border-radius:6px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;transition:background .15s,color .15s;display:flex}.notification-clear-btn:hover{background:var(--primary);color:#fff}.notification-panel-footer{border:none;border-top:1px solid var(--outline-variant);width:100%;color:var(--primary);text-align:center;cursor:pointer;background:0 0;padding:10px;font-size:12px;font-weight:600;transition:background .15s;display:block}.notification-panel-footer:hover{background:var(--surface-variant)}.topnav-right{align-items:center;gap:8px;display:flex}@media (width<=768px){.notification-panel{width:calc(100vw - 32px);right:-8px}}.notif-history-list{flex-direction:column;gap:0;display:flex}.notif-history-date{color:var(--on-surface-variant);letter-spacing:.3px;padding:16px 0 6px;font-size:12px;font-weight:700}.notif-history-item{background:var(--surface);cursor:pointer;text-align:left;border:none;border-radius:12px;align-items:flex-start;gap:12px;width:100%;padding:12px 16px;transition:background .15s;display:flex;position:relative}.notif-history-item:hover{background:var(--surface-variant)}.notif-history-item.unread{background:var(--primary-container,#6366f10f)}.notif-history-avatar{background:var(--surface-variant);width:36px;height:36px;color:var(--on-surface-variant);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex;overflow:hidden}.notif-history-avatar img{object-fit:cover;width:100%;height:100%}.notif-history-content{flex:1;min-width:0}.notif-history-top{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.notif-history-top strong{color:var(--on-surface);font-size:14px;font-weight:700}.notif-history-time{color:var(--on-surface-variant);opacity:.7;flex-shrink:0;margin-left:auto;font-size:11px}.notif-history-preview{color:var(--on-surface-variant);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:13px;overflow:hidden}.notif-history-meta{color:var(--on-surface-variant);opacity:.6;margin-top:2px;font-size:11px}.notif-history-dot{background:var(--primary);border-radius:50%;width:8px;height:8px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.notif-system-icon{justify-content:center;align-items:center;width:100%;height:100%;font-size:18px;display:flex}.global-ctx-menu{z-index:10000;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f172af2;border:1px solid #ffffff1a;border-radius:14px;min-width:200px;padding:6px;animation:.12s ease-out ctxMenuIn;position:fixed;box-shadow:0 12px 40px #00000080,inset 0 0 0 1px #ffffff0a,0 0 80px #004ac614}@keyframes ctxMenuIn{0%{opacity:0;transform:scale(.95)translateY(-4px)}to{opacity:1;transform:scale(1)translateY(0)}}.global-ctx-brand{letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;border-bottom:1px solid #ffffff0f;margin-bottom:4px;padding:8px 12px 6px;font-size:11px;font-weight:700}.global-ctx-item{color:#cbd5e1;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 10px;font-size:13px;transition:background .1s,color .1s;display:flex}.global-ctx-item:hover{color:#f1f5f9;background:#ffffff14}.global-ctx-icon{text-align:center;flex-shrink:0;width:20px;font-size:14px}.global-ctx-divider{background:#ffffff0f;height:1px;margin:4px 8px}.not-found-page{text-align:center;background:var(--surface);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.not-found-code{font-size:8rem;font-weight:900;font-family:var(--font-display);letter-spacing:-.04em;background:linear-gradient(135deg, var(--primary), var(--tertiary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:16px;line-height:1;animation:.5s ease-out fadeInScale}.not-found-title{color:var(--on-surface);margin-bottom:12px;font-size:1.5rem;font-weight:700}.not-found-desc{color:var(--on-surface-variant);max-width:400px;margin-bottom:32px;font-size:15px}.page-loading{justify-content:center;align-items:center;min-height:60vh;animation:.3s ease-out fadeIn;display:flex}.page-loading-spinner{border:3px solid var(--outline-variant);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}.error-boundary-page{text-align:center;background:var(--surface);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.error-boundary-icon{margin-bottom:16px;font-size:4rem}.error-boundary-title{color:var(--on-surface);margin-bottom:12px;font-size:1.5rem;font-weight:700}.error-boundary-desc{color:var(--on-surface-variant);max-width:400px;margin-bottom:32px;font-size:14px;line-height:1.6}.landing-nav{align-items:center;gap:16px;display:flex}.landing-nav-link{color:var(--on-surface-variant);border-radius:var(--radius-full);transition:all .2s var(--ease);padding:8px 16px;font-size:14px;font-weight:500}.landing-nav-link:hover{color:var(--on-surface);background:var(--surface-container)}.landing-stats{gap:48px;margin-top:48px;animation:.5s ease-out .3s backwards fadeInUp;display:flex}.landing-stat{text-align:center}.landing-stat-value{font-size:2rem;font-weight:800;font-family:var(--font-display);background:linear-gradient(135deg, var(--primary), var(--tertiary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-stat-label{color:var(--on-surface-variant);margin-top:4px;font-size:13px}.landing-section{max-width:1100px;margin:0 auto;padding:80px 24px}.landing-section-title{text-align:center;font-size:2rem;font-weight:800;font-family:var(--font-display);letter-spacing:-.02em;color:var(--on-surface);margin-bottom:16px}.landing-section-sub{text-align:center;color:var(--on-surface-variant);max-width:600px;margin:0 auto 48px;font-size:16px;line-height:1.6}.showcase-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.showcase-card{border-radius:var(--radius-xl);background:var(--surface-container-lowest);border:var(--border-card) solid var(--border-card-color);box-shadow:var(--shadow-sm);transition:all .3s var(--ease);padding:32px;animation:.45s ease-out backwards fadeInUp}.showcase-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}.showcase-card:first-child{animation-delay:.1s}.showcase-card:nth-child(2){animation-delay:.15s}.showcase-card:nth-child(3){animation-delay:.2s}.showcase-card:nth-child(4){animation-delay:.25s}.showcase-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:16px;font-size:22px;display:flex}.showcase-icon-blue{background:#004ac614}.showcase-icon-purple{background:#632ecd14}.showcase-icon-green{background:#10b98114}.showcase-icon-amber{background:#f59e0b14}.showcase-card h3{color:var(--on-surface);margin-bottom:8px;font-size:18px;font-weight:700}.showcase-card p{color:var(--on-surface-variant);font-size:14px;line-height:1.6}.showcase-tags{flex-wrap:wrap;gap:6px;margin-top:16px;display:flex}.showcase-tag{border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary);padding:3px 10px;font-size:11px;font-weight:600}.showcase-tag.purple{background:var(--tertiary-light);color:var(--tertiary)}.showcase-tag.green{background:var(--success-light);color:var(--success)}.steps-grid{counter-reset:step;grid-template-columns:repeat(4,1fr);gap:32px;display:grid}.step-card{text-align:center;animation:.45s ease-out backwards fadeInUp;position:relative}.step-card:first-child{animation-delay:.1s}.step-card:nth-child(2){animation-delay:.2s}.step-card:nth-child(3){animation-delay:.3s}.step-card:nth-child(4){animation-delay:.4s}.step-number{background:linear-gradient(135deg, var(--primary), var(--tertiary));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 16px;font-size:20px;font-weight:800;display:flex}.step-card h4{color:var(--on-surface);margin-bottom:8px;font-size:15px;font-weight:700}.step-card p{color:var(--on-surface-variant);font-size:13px;line-height:1.5}.landing-cta{text-align:center;background:linear-gradient(180deg, var(--surface) 0%, var(--primary-light) 100%);padding:80px 24px}.landing-cta h2{font-size:2rem;font-weight:800;font-family:var(--font-display);color:var(--on-surface);margin-bottom:16px}.landing-cta p{color:var(--on-surface-variant);margin-bottom:32px;font-size:16px}.landing-footer{border-top:1px solid var(--outline-variant);color:var(--on-surface-variant);justify-content:space-between;align-items:center;padding:32px 48px;font-size:13px;display:flex}@media (width<=768px){.showcase-grid{grid-template-columns:1fr}.steps-grid{grid-template-columns:repeat(2,1fr);gap:24px}.landing-stats{flex-wrap:wrap;justify-content:center;gap:24px}.landing-footer{text-align:center;flex-direction:column;gap:12px;padding:24px}.landing-header{padding:16px 20px}.landing-nav-link{display:none}.landing-section{padding:48px 20px}.landing-section-title{font-size:1.5rem}.landing-cta{padding:48px 20px}.landing-cta h2{font-size:1.5rem}.messenger-sidebar{border-right:none;border-bottom:1px solid var(--outline-variant);max-height:40vh}}@media (width<=480px){.steps-grid{grid-template-columns:1fr}.landing-stat-value{font-size:1.5rem}.landing-header .logo{font-size:18px}.not-found-code{font-size:5rem}}.deadline-timer{background:var(--surface-container);color:var(--on-surface);border:1px solid var(--outline-variant);border-radius:8px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;display:inline-flex}.deadline-timer.compact{border-radius:6px;padding:3px 10px;font-size:12px}.deadline-timer.urgent{color:#92400e;background:#fef3c7;border-color:#f59e0b}.deadline-timer.critical{color:#991b1b;background:#fef2f2;border-color:#ef4444;animation:1s ease-in-out infinite deadline-pulse}.deadline-timer.expired{background:var(--surface-container);color:var(--on-surface-variant);border-color:var(--outline-variant);opacity:.7}@keyframes deadline-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.03);box-shadow:0 0 12px #ef44444d}}.deadline-timer .deadline-icon{font-size:15px}.deadline-timer .deadline-text strong{font-weight:700}[data-theme=dark] .deadline-timer.urgent,.dark .deadline-timer.urgent{color:#fbbf24;background:#f59e0b26;border-color:#f59e0b66}[data-theme=dark] .deadline-timer.critical,.dark .deadline-timer.critical{color:#fca5a5;background:#ef444426;border-color:#ef444466}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}html[data-theme=spring]{--primary:#d4618c;--primary-light:#ffe8ef;--primary-container:#e8849f;--primary-hover:#bf4d78;--primary-fixed:#ffd0dd;--secondary:#8b6f65;--secondary-light:#f5ebe8;--tertiary:#8b5e3c;--tertiary-light:#fff0e5;--tertiary-container:#8b5e3c14;--on-tertiary-container:#6b4423;--success:#4caf82;--success-light:#edf8f2;--warning:#e8a030;--warning-light:#fff8eb;--error:#e05b5b;--error-light:#fff0f0;--surface:#fff8f5;--surface-container-lowest:#fff;--surface-container-low:#fff3ef;--surface-container:#ffede8;--surface-container-high:#ffe5de;--surface-container-highest:#fff;--on-surface:#3d2b1f;--on-surface-variant:#6b5549;--outline-variant:#6b554926;--editor-bg:#2d1520;--shadow-sm:0 2px 8px #d4618c0f;--shadow:0 4px 20px #d4618c14;--shadow-lg:0 8px 40px #d4618c1a;--shadow-ai:0 4px 24px #8b5e3c1a;--shadow-primary:0 4px 20px #d4618c26;--shadow-float:0 8px 40px #d4618c14, 0 2px 8px #d4618c0a}html[data-theme=summer]{--primary:#0891b2;--primary-light:#dffbff;--primary-container:#22b8cf;--primary-hover:#0e7490;--primary-fixed:#a5f3fc;--secondary:#4b6b77;--secondary-light:#e6f2f5;--tertiary:#0d9488;--tertiary-light:#e6fff9;--tertiary-container:#0d948814;--on-tertiary-container:#0f766e;--success:#059669;--success-light:#ecfdf5;--warning:#d97706;--warning-light:#fffbeb;--error:#dc2626;--error-light:#fef2f2;--surface:#f0fdfa;--surface-container-lowest:#fff;--surface-container-low:#e6faf6;--surface-container:#d5f5f0;--surface-container-high:#c4f0ea;--surface-container-highest:#fff;--on-surface:#134e4a;--on-surface-variant:#3b6b65;--outline-variant:#3b6b6526;--editor-bg:#042f2e;--shadow-sm:0 2px 8px #0891b20f;--shadow:0 4px 20px #0891b214;--shadow-lg:0 8px 40px #0891b21a;--shadow-ai:0 4px 24px #0d94881a;--shadow-primary:0 4px 20px #0891b226;--shadow-float:0 8px 40px #0891b214, 0 2px 8px #0891b20a}html[data-theme=fall]{--primary:#c2410c;--primary-light:#fff0e5;--primary-container:#ea580c;--primary-hover:#9a3412;--primary-fixed:#ffcfaa;--secondary:#78716c;--secondary-light:#f0eeec;--tertiary:#92400e;--tertiary-light:#fff8eb;--tertiary-container:#92400e14;--on-tertiary-container:#78350f;--success:#16a34a;--success-light:#f0fdf4;--warning:#ca8a04;--warning-light:#fefce8;--error:#dc2626;--error-light:#fef2f2;--surface:#fffbf5;--surface-container-lowest:#fff;--surface-container-low:#fff7ee;--surface-container:#fff2e5;--surface-container-high:#ffedda;--surface-container-highest:#fff;--on-surface:#431407;--on-surface-variant:#6b4423;--outline-variant:#6b442326;--editor-bg:#27150a;--shadow-sm:0 2px 8px #c2410c0f;--shadow:0 4px 20px #c2410c14;--shadow-lg:0 8px 40px #c2410c1a;--shadow-ai:0 4px 24px #92400e1a;--shadow-primary:0 4px 20px #c2410c26;--shadow-float:0 8px 40px #c2410c14, 0 2px 8px #c2410c0a}html[data-theme=winter]{--primary:#6366f1;--primary-light:#e8e8ff;--primary-container:#818cf8;--primary-hover:#4f46e5;--primary-fixed:#c7d2fe;--secondary:#6b7280;--secondary-light:#f0f1f3;--tertiary:#818cf8;--tertiary-light:#eef0ff;--tertiary-container:#818cf814;--on-tertiary-container:#4338ca;--success:#10b981;--success-light:#ecfdf5;--warning:#f59e0b;--warning-light:#fffbeb;--error:#ef4444;--error-light:#fef2f2;--surface:#f5f7ff;--surface-container-lowest:#fff;--surface-container-low:#eef0fc;--surface-container:#e5e8f8;--surface-container-high:#dddff4;--surface-container-highest:#fff;--on-surface:#1e1b4b;--on-surface-variant:#4338ca;--outline-variant:#4338ca1f;--editor-bg:#0f0d2e;--shadow-sm:0 2px 8px #6366f10f;--shadow:0 4px 20px #6366f114;--shadow-lg:0 8px 40px #6366f11a;--shadow-ai:0 4px 24px #818cf81a;--shadow-primary:0 4px 20px #6366f126;--shadow-float:0 8px 40px #6366f114, 0 2px 8px #6366f10a}html[data-theme=retro]{--primary:#8b6914;--primary-light:#fff5dc;--primary-container:#a67c1a;--primary-hover:#725510;--primary-fixed:#f0d68a;--secondary:#7c7062;--secondary-light:#f2ede8;--tertiary:#6b4423;--tertiary-light:#fff0e0;--tertiary-container:#6b442314;--on-tertiary-container:#5c3a1e;--success:#5d8c3e;--success-light:#f0f7eb;--warning:#c89520;--warning-light:#fff9e8;--error:#c75050;--error-light:#fff0f0;--surface:#faf6ee;--surface-container-lowest:#fefcf7;--surface-container-low:#f7f2e8;--surface-container:#f0e9db;--surface-container-high:#e8e0d0;--surface-container-highest:#fefcf7;--on-surface:#3c2415;--on-surface-variant:#6b5b48;--outline-variant:#6b5b4826;--editor-bg:#1e180e;--shadow-sm:0 2px 8px #8b69140f;--shadow:0 4px 20px #8b691414;--shadow-lg:0 8px 40px #8b69141a;--shadow-ai:0 4px 24px #6b44231a;--shadow-primary:0 4px 20px #8b691426;--shadow-float:0 8px 40px #8b691414, 0 2px 8px #8b69140a}html[data-theme=cyberpunk]{--primary:#e040fb;--primary-light:#2a0e30;--primary-container:#ab47bc;--primary-hover:#ce34e8;--primary-fixed:#f48fb1;--secondary:#78909c;--secondary-light:#1a2530;--tertiary:#00e5ff;--tertiary-light:#0a2a30;--tertiary-container:#00e5ff1a;--on-tertiary-container:#00bcd4;--success:#00e676;--success-light:#0a2a18;--warning:#ffd600;--warning-light:#2a2500;--error:#ff1744;--error-light:#2a0a10;--surface:#0d0d1a;--surface-container-lowest:#08080f;--surface-container-low:#121225;--surface-container:#1a1a35;--surface-container-high:#222245;--surface-container-highest:#12121f;--on-surface:#e0e0ff;--on-surface-variant:#a0a0cc;--outline-variant:#a0a0cc26;--editor-bg:#08080f;--shadow-sm:0 2px 8px #e040fb26;--shadow:0 4px 20px #e040fb33;--shadow-lg:0 8px 40px #e040fb40;--shadow-ai:0 4px 24px #00e5ff33;--shadow-primary:0 4px 20px #e040fb4d;--shadow-float:0 8px 40px #e040fb33, 0 2px 8px #00e5ff1a}html[data-theme=playful]{--primary:#f97316;--primary-light:#fff4e8;--primary-container:#fb923c;--primary-hover:#ea580c;--primary-fixed:#fdba74;--secondary:#78716c;--secondary-light:#f5f0ec;--tertiary:#eab308;--tertiary-light:#fffde8;--tertiary-container:#eab30814;--on-tertiary-container:#a16207;--success:#22c55e;--success-light:#f0fdf4;--warning:#f59e0b;--warning-light:#fffbeb;--error:#ef4444;--error-light:#fef2f2;--surface:#fffdf7;--surface-container-lowest:#fff;--surface-container-low:#fffbf0;--surface-container:#fff8e5;--surface-container-high:#fff3d5;--surface-container-highest:#fff;--on-surface:#422006;--on-surface-variant:#6b5030;--outline-variant:#6b503026;--editor-bg:#1c1008;--shadow-sm:0 2px 8px #f973160f;--shadow:0 4px 20px #f9731614;--shadow-lg:0 8px 40px #f973161a;--shadow-ai:0 4px 24px #eab3081a;--shadow-primary:0 4px 20px #f9731626;--shadow-float:0 8px 40px #f9731614, 0 2px 8px #f973160a}html[data-theme=flower]{--primary:#be185d;--primary-light:#ffe4ee;--primary-container:#db2777;--primary-hover:#9d174d;--primary-fixed:#fbb6ce;--secondary:#7c6b75;--secondary-light:#f5eef2;--tertiary:#a855f7;--tertiary-light:#f5e8ff;--tertiary-container:#a855f714;--on-tertiary-container:#7c3aed;--success:#10b981;--success-light:#ecfdf5;--warning:#f59e0b;--warning-light:#fffbeb;--error:#e11d48;--error-light:#fff1f2;--surface:#fff5f7;--surface-container-lowest:#fff;--surface-container-low:#fff0f3;--surface-container:#ffe8ed;--surface-container-high:#ffdde5;--surface-container-highest:#fff;--on-surface:#4a1d2e;--on-surface-variant:#7c4a60;--outline-variant:#7c4a6026;--editor-bg:#200a18;--shadow-sm:0 2px 8px #be185d0f;--shadow:0 4px 20px #be185d14;--shadow-lg:0 8px 40px #be185d1a;--shadow-ai:0 4px 24px #a855f71a;--shadow-primary:0 4px 20px #be185d26;--shadow-float:0 8px 40px #be185d14, 0 2px 8px #be185d0a}html[data-theme=coding]{--primary:#10b981;--primary-light:#0a2a18;--primary-container:#34d399;--primary-hover:#059669;--primary-fixed:#6ee7b7;--secondary:#94a3b8;--secondary-light:#1e293b;--tertiary:#3b82f6;--tertiary-light:#0c1a30;--tertiary-container:#3b82f61a;--on-tertiary-container:#60a5fa;--success:#22c55e;--success-light:#0a2a15;--warning:#fbbf24;--warning-light:#2a2005;--error:#f87171;--error-light:#2a0a0a;--surface:#0f172a;--surface-container-lowest:#020617;--surface-container-low:#1e293b;--surface-container:#243348;--surface-container-high:#334155;--surface-container-highest:#1a2332;--on-surface:#e2e8f0;--on-surface-variant:#94a3b8;--outline-variant:#94a3b826;--editor-bg:#020617;--shadow-sm:0 2px 8px #10b9811a;--shadow:0 4px 20px #10b98126;--shadow-lg:0 8px 40px #10b98133;--shadow-ai:0 4px 24px #3b82f626;--shadow-primary:0 4px 20px #10b98140;--shadow-float:0 8px 40px #10b98126, 0 2px 8px #3b82f614}html[data-theme=anime]{--primary:#8b5cf6;--primary-light:#f3eeff;--primary-container:#a78bfa;--primary-hover:#7c3aed;--primary-fixed:#c4b5fd;--secondary:#7c7090;--secondary-light:#f0ecf5;--tertiary:#ec4899;--tertiary-light:#fff0f6;--tertiary-container:#ec489914;--on-tertiary-container:#db2777;--success:#34d399;--success-light:#f0fdf4;--warning:#fbbf24;--warning-light:#fffbeb;--error:#f43f5e;--error-light:#fff1f2;--surface:#fef5ff;--surface-container-lowest:#fff;--surface-container-low:#fcf0fe;--surface-container:#f8e8fc;--surface-container-high:#f3ddfa;--surface-container-highest:#fff;--on-surface:#2e1065;--on-surface-variant:#6b4a8c;--outline-variant:#6b4a8c26;--editor-bg:#1a0a2e;--shadow-sm:0 2px 8px #8b5cf60f;--shadow:0 4px 20px #8b5cf614;--shadow-lg:0 8px 40px #8b5cf61a;--shadow-ai:0 4px 24px #ec48991a;--shadow-primary:0 4px 20px #8b5cf626;--shadow-float:0 8px 40px #8b5cf614, 0 2px 8px #8b5cf60a}.theme-bg{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.theme-bg-spring{background:radial-gradient(2px 3px,#d4618c59 50%,#0000 50%) 10% 0/80px 120px,radial-gradient(3px 2px,#ffb6ce4d 50%,#0000 50%) 30% 0/100px 90px,radial-gradient(2px 3px,#d4618c40 50%,#0000 50%) 55% 0/70px 150px,radial-gradient(3px 4px,#ffd0dd59 50%,#0000 50%) 75% 0/110px 100px,radial-gradient(2px 2px,#d4618c33 50%,#0000 50%) 90% 0/60px 130px;animation:8s linear infinite petals-fall}@keyframes petals-fall{0%{background-position-y:-20px,-40px,-10px,-30px,-50px}to{background-position-y:100vh,100vh,100vh,100vh,100vh}}.theme-bg-summer:before,.theme-bg-summer:after{content:"";border-radius:50% 50% 0 0;width:200%;height:80px;position:absolute;bottom:0;left:-50%}.theme-bg-summer:before{background:#0891b20f;animation:6s ease-in-out infinite wave1}.theme-bg-summer:after{background:#0d94880a;animation:8s ease-in-out infinite wave2;bottom:-10px}@keyframes wave1{0%,to{transform:translate(-5%)translateY(0)}50%{transform:translate(5%)translateY(-15px)}}@keyframes wave2{0%,to{transform:translate(5%)translateY(0)}50%{transform:translate(-5%)translateY(-10px)}}.theme-bg-fall{background:radial-gradient(4px 3px,#c2410c4d 50%,#0000 50%) 15% 0/90px 110px,radial-gradient(3px 4px,#ea580c40 50%,#0000 50%) 40% 0/120px 80px,radial-gradient(5px 3px,#ca8a044d 50%,#0000 50%) 65% 0/70px 140px,radial-gradient(3px 3px,#c2410c33 50%,#0000 50%) 85% 0/100px 100px;animation:10s linear infinite leaves-fall}@keyframes leaves-fall{0%{background-position-y:-30px,-60px,-15px,-45px;transform:translate(0)}25%{transform:translate(8px)}50%{transform:translate(-5px)}75%{transform:translate(6px)}to{background-position-y:100vh,100vh,100vh,100vh;transform:translate(0)}}.theme-bg-winter{background:radial-gradient(2px 2px,#ffffffb3 50%,#0000 50%) 10% 0/60px 80px,radial-gradient(3px 3px,#c7d2fe80 50%,#0000 50%) 25% 0/90px 120px,radial-gradient(1.5px 1.5px,#fff9 50%,#0000 50%) 45% 0/50px 70px,radial-gradient(2.5px 2.5px,#c7d2fe66 50%,#0000 50%) 65% 0/110px 100px,radial-gradient(2px 2px,#ffffff80 50%,#0000 50%) 80% 0/70px 90px,radial-gradient(1px 1px,#ffffff80 50%,#0000 50%) 95% 0/40px 60px;animation:12s linear infinite snow-fall}@keyframes snow-fall{0%{background-position-y:-10px,-30px,-20px,-50px,-15px,-40px}to{background-position-y:100vh,100vh,100vh,100vh,100vh,100vh}}.theme-bg-retro{background:radial-gradient(1px 1px,#8b691426 50%,#0000 50%) 0 0/30px 30px,radial-gradient(1px 1px,#6b44231a 50%,#0000 50%) 15px 15px/30px 30px;animation:20s linear infinite retro-drift}@keyframes retro-drift{0%{transform:translate(0)}50%{transform:translate(-15px,10px)}to{transform:translate(0)}}.theme-bg-cyberpunk:before{content:"";background:repeating-linear-gradient(90deg,#0000 0 98px,#e040fb08 98px 100px);animation:4s linear infinite cyber-scan;position:absolute;inset:0}.theme-bg-cyberpunk:after{content:"";background:linear-gradient(#0000 0%,#00e5ff08 50%,#0000 100%);height:200%;animation:3s linear infinite cyber-line;position:absolute;top:-100%;left:0;right:0}@keyframes cyber-scan{0%{transform:translate(0)}to{transform:translate(100px)}}@keyframes cyber-line{0%{transform:translateY(0)}to{transform:translateY(50%)}}.theme-bg-playful{background:radial-gradient(6px,#f973161f 50%,#0000 50%) 10% 20%/200px 200px,radial-gradient(4px,#eab3081a 50%,#0000 50%) 40% 60%/160px 160px,radial-gradient(8px,#f9731614 50%,#0000 50%) 70% 30%/240px 240px,radial-gradient(5px,#eab3081a 50%,#0000 50%) 85% 75%/180px 180px;animation:15s ease-in-out infinite bubbles-float}@keyframes bubbles-float{0%,to{transform:translateY(0)}33%{transform:translateY(-20px)}66%{transform:translateY(10px)}}.theme-bg-flower{background:radial-gradient(3px 4px,#be185d33 50%,#0000 50%) 12% 0/80px 100px,radial-gradient(4px 3px,#a855f726 50%,#0000 50%) 35% 0/110px 130px,radial-gradient(3px 3px,#db277733 50%,#0000 50%) 58% 0/70px 90px,radial-gradient(4px 4px,#a855f726 50%,#0000 50%) 82% 0/100px 120px;animation:9s linear infinite flower-drift}@keyframes flower-drift{0%{background-position-y:-20px,-50px,-10px,-40px;transform:translate(0)}50%{transform:translate(10px)}to{background-position-y:100vh,100vh,100vh,100vh;transform:translate(0)}}.theme-bg-coding:before{content:"";background:repeating-linear-gradient(#0000 0 18px,#10b9810a 18px 20px);position:absolute;inset:0}.theme-bg-coding:after{content:"";background:radial-gradient(1px 8px,#10b98133 50%,#0000 50%) 5% 0/40px 60px,radial-gradient(1px 6px,#34d39926 50%,#0000 50%) 20% 0/55px 45px,radial-gradient(1px 10px,#10b9812e 50%,#0000 50%) 38% 0/35px 70px,radial-gradient(1px 7px,#34d3991f 50%,#0000 50%) 55% 0/50px 50px,radial-gradient(1px 5px,#10b98133 50%,#0000 50%) 72% 0/45px 65px,radial-gradient(1px 9px,#34d39926 50%,#0000 50%) 88% 0/30px 55px;animation:5s linear infinite matrix-rain;position:absolute;inset:0}@keyframes matrix-rain{0%{background-position-y:-20px,-40px,-10px,-35px,-25px,-50px}to{background-position-y:100vh,100vh,100vh,100vh,100vh,100vh}}.theme-bg-anime{background:radial-gradient(2px 2px,#8b5cf666 50%,#0000 50%) 8% 15%/150px 150px,radial-gradient(3px 3px,#ec48994d 50%,#0000 50%) 25% 45%/200px 200px,radial-gradient(2px 2px,#a855f759 50%,#0000 50%) 50% 25%/120px 120px,radial-gradient(3px 3px,#ec489940 50%,#0000 50%) 70% 65%/180px 180px,radial-gradient(2px 2px,#8b5cf64d 50%,#0000 50%) 90% 35%/100px 100px;animation:3s ease-in-out infinite alternate sparkle}@keyframes sparkle{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}.theme-bg-custom-particles{background:radial-gradient(2px 2px, var(--primary) 50%, transparent 50%) 10% 20% / 160px 160px, radial-gradient(1.5px 1.5px, var(--tertiary,var(--secondary)) 50%, transparent 50%) 35% 55% / 200px 200px, radial-gradient(2px 2px, var(--primary) 50%, transparent 50%) 60% 15% / 120px 120px, radial-gradient(1.5px 1.5px, var(--tertiary,var(--secondary)) 50%, transparent 50%) 80% 70% / 180px 180px, radial-gradient(2px 2px, var(--primary) 50%, transparent 50%) 95% 40% / 140px 140px;opacity:.2;animation:18s ease-in-out infinite custom-particles-drift}@keyframes custom-particles-drift{0%,to{transform:translate(0)}25%{transform:translate(-12px,8px)}50%{transform:translate(8px,-12px)}75%{transform:translate(-6px,-6px)}}.theme-bg-custom-rain{background:radial-gradient(1px 6px, var(--primary) 50%, transparent 50%) 8% 0 / 50px 60px, radial-gradient(1px 8px, var(--primary) 50%, transparent 50%) 22% 0 / 40px 50px, radial-gradient(1px 5px, var(--primary) 50%, transparent 50%) 40% 0 / 60px 70px, radial-gradient(1px 7px, var(--primary) 50%, transparent 50%) 58% 0 / 35px 55px, radial-gradient(1px 6px, var(--primary) 50%, transparent 50%) 75% 0 / 45px 65px, radial-gradient(1px 4px, var(--primary) 50%, transparent 50%) 90% 0 / 55px 45px;opacity:.15;animation:4s linear infinite custom-rain-fall}@keyframes custom-rain-fall{0%{background-position-y:-20px,-40px,-10px,-35px,-25px,-50px}to{background-position-y:100vh,100vh,100vh,100vh,100vh,100vh}}.theme-bg-custom-sparkle{background:radial-gradient(2px 2px, var(--primary) 50%, transparent 50%) 10% 20% / 150px 150px, radial-gradient(3px 3px, var(--tertiary,var(--secondary)) 50%, transparent 50%) 30% 50% / 200px 200px, radial-gradient(2px 2px, var(--primary) 50%, transparent 50%) 55% 30% / 120px 120px, radial-gradient(3px 3px, var(--tertiary,var(--secondary)) 50%, transparent 50%) 75% 65% / 180px 180px, radial-gradient(2px 2px, var(--primary) 50%, transparent 50%) 92% 40% / 100px 100px;animation:3s ease-in-out infinite alternate custom-sparkle}@keyframes custom-sparkle{0%{opacity:.15}50%{opacity:.4}to{opacity:.15}}.theme-bg-custom-snow{background:radial-gradient(2px 2px,#ffffffb3 50%,#0000 50%) 10% 0/60px 80px,radial-gradient(3px 3px,#ffffff80 50%,#0000 50%) 25% 0/90px 120px,radial-gradient(1.5px 1.5px,#fff9 50%,#0000 50%) 45% 0/50px 70px,radial-gradient(2.5px 2.5px,#fff6 50%,#0000 50%) 65% 0/110px 100px,radial-gradient(2px 2px,#ffffff80 50%,#0000 50%) 80% 0/70px 90px;animation:12s linear infinite custom-snow-fall}@keyframes custom-snow-fall{0%{background-position-y:-10px,-30px,-20px,-50px,-15px}to{background-position-y:100vh,100vh,100vh,100vh,100vh}}.theme-bg-custom-gradient:before{content:"";background:linear-gradient(135deg, transparent 0%, var(--primary) 25%, var(--tertiary,var(--secondary)) 50%, var(--primary) 75%, transparent 100%);opacity:.04;background-size:400% 400%;animation:12s infinite custom-gradient-shift;position:absolute;inset:0}@keyframes custom-gradient-shift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}
