@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 { font: 1.21em / 1.2 KaTeX_Main, "Times New Roman", serif; text-indent: 0px; text-rendering: auto; }
.katex * { border-color: currentcolor; }
.katex .katex-version::after { content: "0.16.38"; }
.katex .katex-mathml { clip: rect(1px, 1px, 1px, 1px); border: 0px; height: 1px; overflow: hidden; padding: 0px; position: absolute; width: 1px; }
.katex .katex-html > .newline { display: block; }
.katex .base { position: relative; white-space: nowrap; width: min-content; }
.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; display: inline-table; table-layout: fixed; }
.katex .vlist-r { display: table-row; }
.katex .vlist { display: table-cell; position: relative; vertical-align: bottom; }
.katex .vlist > span { display: block; height: 0px; position: relative; }
.katex .vlist > span > span { display: inline-block; }
.katex .vlist > span > .pstrut { overflow: hidden; width: 0px; }
.katex .vlist-t2 { margin-right: -2px; }
.katex .vlist-s { display: table-cell; font-size: 1px; min-width: 2px; vertical-align: bottom; width: 2px; }
.katex .vbox { align-items: baseline; display: inline-flex; flex-direction: column; }
.katex .hbox { width: 100%; }
.katex .hbox, .katex .thinbox { display: inline-flex; flex-direction: row; }
.katex .thinbox { max-width: 0px; width: 0px; }
.katex .msupsub { text-align: left; }
.katex .mfrac > span > span { text-align: center; }
.katex .mfrac .frac-line { border-bottom-style: solid; display: inline-block; width: 100%; }
.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 { display: inline; line-height: 0; }
.katex .clap, .katex .llap, .katex .rlap { position: relative; width: 0px; }
.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: 0px; }
.katex .clap > .inner, .katex .rlap > .inner { left: 0px; }
.katex .clap > .inner > span { margin-left: -50%; margin-right: 50%; }
.katex .rule { border: 0px solid; display: inline-block; position: relative; }
.katex .hline, .katex .overline .overline-line, .katex .underline .underline-line { border-bottom-style: solid; display: inline-block; width: 100%; }
.katex .hdashline { border-bottom-style: dashed; display: inline-block; width: 100%; }
.katex .sqrt > .root { margin-left: 0.277778em; margin-right: -0.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: 0.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: 0.714286em; }
.katex .fontsize-ensurer.reset-size3.size2, .katex .sizing.reset-size3.size2 { font-size: 0.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: 0.625em; }
.katex .fontsize-ensurer.reset-size4.size2, .katex .sizing.reset-size4.size2 { font-size: 0.75em; }
.katex .fontsize-ensurer.reset-size4.size3, .katex .sizing.reset-size4.size3 { font-size: 0.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: 0.555556em; }
.katex .fontsize-ensurer.reset-size5.size2, .katex .sizing.reset-size5.size2 { font-size: 0.666667em; }
.katex .fontsize-ensurer.reset-size5.size3, .katex .sizing.reset-size5.size3 { font-size: 0.777778em; }
.katex .fontsize-ensurer.reset-size5.size4, .katex .sizing.reset-size5.size4 { font-size: 0.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: 0.5em; }
.katex .fontsize-ensurer.reset-size6.size2, .katex .sizing.reset-size6.size2 { font-size: 0.6em; }
.katex .fontsize-ensurer.reset-size6.size3, .katex .sizing.reset-size6.size3 { font-size: 0.7em; }
.katex .fontsize-ensurer.reset-size6.size4, .katex .sizing.reset-size6.size4 { font-size: 0.8em; }
.katex .fontsize-ensurer.reset-size6.size5, .katex .sizing.reset-size6.size5 { font-size: 0.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: 0.416667em; }
.katex .fontsize-ensurer.reset-size7.size2, .katex .sizing.reset-size7.size2 { font-size: 0.5em; }
.katex .fontsize-ensurer.reset-size7.size3, .katex .sizing.reset-size7.size3 { font-size: 0.583333em; }
.katex .fontsize-ensurer.reset-size7.size4, .katex .sizing.reset-size7.size4 { font-size: 0.666667em; }
.katex .fontsize-ensurer.reset-size7.size5, .katex .sizing.reset-size7.size5 { font-size: 0.75em; }
.katex .fontsize-ensurer.reset-size7.size6, .katex .sizing.reset-size7.size6 { font-size: 0.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: 0.347222em; }
.katex .fontsize-ensurer.reset-size8.size2, .katex .sizing.reset-size8.size2 { font-size: 0.416667em; }
.katex .fontsize-ensurer.reset-size8.size3, .katex .sizing.reset-size8.size3 { font-size: 0.486111em; }
.katex .fontsize-ensurer.reset-size8.size4, .katex .sizing.reset-size8.size4 { font-size: 0.555556em; }
.katex .fontsize-ensurer.reset-size8.size5, .katex .sizing.reset-size8.size5 { font-size: 0.625em; }
.katex .fontsize-ensurer.reset-size8.size6, .katex .sizing.reset-size8.size6 { font-size: 0.694444em; }
.katex .fontsize-ensurer.reset-size8.size7, .katex .sizing.reset-size8.size7 { font-size: 0.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: 0.289352em; }
.katex .fontsize-ensurer.reset-size9.size2, .katex .sizing.reset-size9.size2 { font-size: 0.347222em; }
.katex .fontsize-ensurer.reset-size9.size3, .katex .sizing.reset-size9.size3 { font-size: 0.405093em; }
.katex .fontsize-ensurer.reset-size9.size4, .katex .sizing.reset-size9.size4 { font-size: 0.462963em; }
.katex .fontsize-ensurer.reset-size9.size5, .katex .sizing.reset-size9.size5 { font-size: 0.520833em; }
.katex .fontsize-ensurer.reset-size9.size6, .katex .sizing.reset-size9.size6 { font-size: 0.578704em; }
.katex .fontsize-ensurer.reset-size9.size7, .katex .sizing.reset-size9.size7 { font-size: 0.694444em; }
.katex .fontsize-ensurer.reset-size9.size8, .katex .sizing.reset-size9.size8 { font-size: 0.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: 0.24108em; }
.katex .fontsize-ensurer.reset-size10.size2, .katex .sizing.reset-size10.size2 { font-size: 0.289296em; }
.katex .fontsize-ensurer.reset-size10.size3, .katex .sizing.reset-size10.size3 { font-size: 0.337512em; }
.katex .fontsize-ensurer.reset-size10.size4, .katex .sizing.reset-size10.size4 { font-size: 0.385728em; }
.katex .fontsize-ensurer.reset-size10.size5, .katex .sizing.reset-size10.size5 { font-size: 0.433944em; }
.katex .fontsize-ensurer.reset-size10.size6, .katex .sizing.reset-size10.size6 { font-size: 0.48216em; }
.katex .fontsize-ensurer.reset-size10.size7, .katex .sizing.reset-size10.size7 { font-size: 0.578592em; }
.katex .fontsize-ensurer.reset-size10.size8, .katex .sizing.reset-size10.size8 { font-size: 0.694311em; }
.katex .fontsize-ensurer.reset-size10.size9, .katex .sizing.reset-size10.size9 { font-size: 0.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: 0.200965em; }
.katex .fontsize-ensurer.reset-size11.size2, .katex .sizing.reset-size11.size2 { font-size: 0.241158em; }
.katex .fontsize-ensurer.reset-size11.size3, .katex .sizing.reset-size11.size3 { font-size: 0.28135em; }
.katex .fontsize-ensurer.reset-size11.size4, .katex .sizing.reset-size11.size4 { font-size: 0.321543em; }
.katex .fontsize-ensurer.reset-size11.size5, .katex .sizing.reset-size11.size5 { font-size: 0.361736em; }
.katex .fontsize-ensurer.reset-size11.size6, .katex .sizing.reset-size11.size6 { font-size: 0.401929em; }
.katex .fontsize-ensurer.reset-size11.size7, .katex .sizing.reset-size11.size7 { font-size: 0.482315em; }
.katex .fontsize-ensurer.reset-size11.size8, .katex .sizing.reset-size11.size8 { font-size: 0.578778em; }
.katex .fontsize-ensurer.reset-size11.size9, .katex .sizing.reset-size11.size9 { font-size: 0.694534em; }
.katex .fontsize-ensurer.reset-size11.size10, .katex .sizing.reset-size11.size10 { font-size: 0.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 { display: inline-block; width: 0.12em; }
.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: 0px; }
.katex .overlay { display: block; }
.katex .mtable .vertical-separator { display: inline-block; min-width: 1px; }
.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; display: block; height: inherit; position: absolute; width: 100%; }
.katex svg path { stroke: none; }
.katex svg { fill-rule: nonzero; fill-opacity: 1; stroke-width: 1; stroke-linecap: butt; stroke-linejoin: miter; stroke-miterlimit: 4; stroke-dasharray: none; stroke-dashoffset: 0; stroke-opacity: 1; }
.katex img { border-style: none; max-height: none; max-width: none; min-height: 0px; min-width: 0px; }
.katex .stretchy { display: block; overflow: hidden; position: relative; width: 100%; }
.katex .stretchy::after, .katex .stretchy::before { content: ""; }
.katex .hide-tail { overflow: hidden; position: relative; width: 100%; }
.katex .halfarrow-left { left: 0px; overflow: hidden; position: absolute; width: 50.2%; }
.katex .halfarrow-right { overflow: hidden; position: absolute; right: 0px; width: 50.2%; }
.katex .brace-left { left: 0px; overflow: hidden; position: absolute; width: 25.1%; }
.katex .brace-center { left: 25%; overflow: hidden; position: absolute; width: 50%; }
.katex .brace-right { overflow: hidden; position: absolute; right: 0px; width: 25.1%; }
.katex .x-arrow-pad { padding: 0px 0.5em; }
.katex .cd-arrow-pad { padding: 0px 0.55556em 0px 0.27778em; }
.katex .mover, .katex .munder, .katex .x-arrow { text-align: center; }
.katex .boxpad { padding: 0px 0.3em; }
.katex .fbox, .katex .fcolorbox { border: 0.04em solid; box-sizing: border-box; }
.katex .cancel-pad { padding: 0px 0.2em; }
.katex .cancel-lap { margin-left: -0.2em; margin-right: -0.2em; }
.katex .sout { border-bottom-style: solid; border-bottom-width: 0.08em; }
.katex .angl { border-right: 0.049em solid; border-top: 0.049em solid; box-sizing: border-box; margin-right: 0.03889em; }
.katex .anglpad { padding: 0px 0.03889em; }
.katex .eqn-num::before { content: "(" counter(katexEqnNo) ")"; counter-increment: katexEqnNo 1; }
.katex .mml-eqn-num::before { content: "(" counter(mmlEqnNo) ")"; counter-increment: mmlEqnNo 1; }
.katex .mtr-glue { width: 50%; }
.katex .cd-vert-arrow { display: inline-block; position: relative; }
.katex .cd-label-left { display: inline-block; position: absolute; right: calc(50% + 0.3em); text-align: left; }
.katex .cd-label-right { display: inline-block; left: calc(50% + 0.3em); position: absolute; text-align: right; }
.katex-display { display: block; margin: 1em 0px; text-align: center; }
.katex-display > .katex { display: block; text-align: center; white-space: nowrap; }
.katex-display > .katex > .katex-html { display: block; position: relative; }
.katex-display > .katex > .katex-html > .tag { position: absolute; right: 0px; }
.katex-display.leqno > .katex > .katex-html > .tag { left: 0px; right: auto; }
.katex-display.fleqn > .katex { padding-left: 2em; text-align: left; }
body { counter-reset: katexEqnNo 0 mmlEqnNo 0; }
*, ::before, ::after { box-sizing: border-box; margin: 0px; padding: 0px; }
:root { --app-bg: #f0f1f5; --app-sidebar-bg: #ffffff; --app-border: #e2e5eb; --app-text: #1a1d23; --app-text-dim: #555b66; --app-accent: #6366f1; --app-accent-hover: #4f46e5; --app-danger: #ef4444; --topbar-height: 52px; --sidebar-width: 460px; --z-drag-handle: 5; --z-add-backdrop: 9; --z-add-menu: 10; --z-topbar: 100; --z-dropdown-backdrop: 199; --z-dropdown: 200; --z-modal-backdrop: 300; --z-modal: 310; --z-toast: 400; }
html { font-size: 87.5%; }
body { font-family: Inter, system-ui, -apple-system, sans-serif; color: var(--app-text); background: var(--app-bg); overflow: hidden; height: 100vh; }
#root { height: 100vh; display: flex; flex-direction: column; }
.app-layout { display: flex; flex-direction: column; height: 100vh; }
.app-body { display: flex; flex: 1 1 0%; overflow: hidden; }
.topbar { display: flex; align-items: center; justify-content: space-between; height: var(--topbar-height); padding: 0px 16px; background: rgb(255, 255, 255); border-bottom: 1px solid var(--app-border); flex-shrink: 0; gap: 12px; z-index: 100; }
.topbar-left { display: flex; align-items: center; gap: 20px; }
.topbar-logo { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 15px; color: var(--app-text); white-space: nowrap; }
.topbar-logo svg { color: var(--app-accent); }
.topbar-template-pills { display: flex; gap: 4px; background: var(--app-bg); border-radius: 8px; padding: 3px; }
.template-pill { padding: 5px 14px; border: none; background: transparent; border-radius: 6px; font-size: 12.5px; font-weight: 500; cursor: pointer; color: var(--app-text-dim); transition: 0.15s; }
.template-pill:hover { color: var(--app-text); background: rgba(255, 255, 255, 0.6); }
.template-pill.active { background: rgb(255, 255, 255); color: var(--app-text); box-shadow: rgba(0, 0, 0, 0.08) 0px 1px 3px; }
.topbar-right { display: flex; align-items: center; gap: 6px; }
.topbar-btn { display: flex; align-items: center; gap: 6px; padding: 6px 14px; border: 1px solid var(--app-border); background: rgb(255, 255, 255); border-radius: 7px; font-size: 12.5px; font-weight: 500; cursor: pointer; color: var(--app-text); transition: 0.15s; white-space: nowrap; }
.topbar-btn:hover { background: var(--app-bg); border-color: rgb(204, 204, 204); }
.topbar-btn.primary { background: var(--app-accent); color: rgb(255, 255, 255); border-color: var(--app-accent); }
.topbar-btn.primary:hover { background: var(--app-accent-hover); }
.topbar-dropdown-wrapper { position: relative; }
.topbar-dropdown-backdrop { position: fixed; inset: 0px; z-index: 199; }
.topbar-dropdown { position: absolute; top: calc(100% + 6px); right: 0px; z-index: 200; min-width: 200px; padding: 4px; background: rgb(255, 255, 255); border: 1px solid var(--app-border); border-radius: 10px; box-shadow: rgba(0, 0, 0, 0.12) 0px 8px 24px; }
.topbar-dropdown button { display: flex; flex-direction: column; width: 100%; padding: 8px 12px; border: none; background: transparent; text-align: left; border-radius: 7px; cursor: pointer; transition: background 0.12s; }
.topbar-dropdown button:hover { background: var(--app-bg); }
.topbar-dropdown .dropdown-label { font-size: 12.5px; font-weight: 600; color: var(--app-text); }
.topbar-dropdown .dropdown-hint { font-size: 10.5px; color: var(--app-text-dim); margin-top: 1px; }
.topbar-dropdown .dropdown-divider { height: 1px; background: var(--app-border); margin: 4px 8px; }
.sidebar { width: var(--sidebar-width); min-width: var(--sidebar-width); background: var(--app-sidebar-bg); border-right: 1px solid var(--app-border); display: flex; flex-direction: column; overflow: hidden; }
.sidebar-tabs { display: flex; border-bottom: 1px solid var(--app-border); flex-shrink: 0; }
.sidebar-tabs button { flex: 1 1 0%; display: flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 8px; border-top: none; border-right: none; border-left: none; border-image: initial; background: transparent; font-size: 12px; font-weight: 500; color: var(--app-text-dim); cursor: pointer; border-bottom: 2px solid transparent; transition: 0.15s; }
.sidebar-tabs button:hover { color: var(--app-text); background: rgba(0, 0, 0, 0.02); }
.sidebar-tabs button.active { color: var(--app-accent); border-bottom-color: var(--app-accent); }
.sidebar-content { flex: 1 1 0%; overflow-y: auto; padding: 0px; }
.section-list { padding: 8px; }
.section-list-item { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: 8px; cursor: pointer; transition: 0.12s; border: 1px solid transparent; user-select: none; }
.nav-slot { padding: 4px 8px; border-bottom: 1px solid var(--app-border); }
.nav-slot-side { border-bottom: none; border-top: 1px solid var(--app-border); }
.nav-slot .section-list-item { border-radius: 6px; margin: 0px; }
.nav-slot-add { display: flex; align-items: center; gap: 6px; width: 100%; padding: 8px 12px; border: 2px dashed var(--app-border); border-radius: 8px; background: transparent; font-size: 11px; font-weight: 600; color: var(--app-text-dim); cursor: pointer; transition: 0.15s; }
.nav-slot-add:hover { border-color: var(--app-accent); color: var(--app-accent); background: rgba(99, 102, 241, 0.04); }
.nav-placeholder { border: 2px dashed rgba(99, 102, 241, 0.2); border-radius: 8px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: 0.15s; color: rgba(99, 102, 241, 0.4); font-size: 11px; font-weight: 600; }
.nav-placeholder:hover { border-color: var(--app-accent); color: var(--app-accent); background: rgba(99, 102, 241, 0.04); }
.nav-placeholder-top { height: 36px; margin: 8px 16px; }
.nav-placeholder-side { width: 36px; flex-shrink: 0; align-self: center; writing-mode: vertical-lr; text-orientation: mixed; padding: 16px 6px; margin: 16px 4px; }
.section-list-item:hover { background: var(--app-bg); }
.section-list-item.selected { background: rgb(239, 241, 255); border-color: var(--app-accent); }
.section-list-item.drag-over { border-top: 2px solid var(--app-accent); }
.section-list-item { transition: padding 0.2s, opacity 0.2s, font-size 0.2s; overflow: hidden; }
.section-list.has-selection .section-list-item:not(.selected) { padding: 3px 10px; font-size: 0.85em; opacity: 0.5; }
.section-list.has-selection .section-list-item:not(.selected) .section-list-actions, .section-list.has-selection .section-list-item:not(.selected) .section-list-title { display: none; }
.section-list.has-selection .section-list-item:not(.selected):hover { opacity: 0.9; }
.section-list-item.hidden-section { opacity: 0.45; }
.section-list-drag { cursor: grab; color: var(--app-text-dim); flex-shrink: 0; display: flex; }
.section-list-drag:active { cursor: grabbing; }
.section-list-type { display: inline-flex; align-items: center; gap: 6px; font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; color: var(--app-accent); background: rgb(239, 241, 255); padding: 2px 8px; border-radius: 999px; flex-shrink: 0; }
.section-list-type-icon { display: inline-flex; align-items: center; justify-content: center; width: 14px; text-transform: none; }
.section-list-title { font-size: 12.5px; color: var(--app-text); flex: 1 1 0%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.section-list-actions { display: flex; gap: 2px; opacity: 0; transition: opacity 0.15s; }
.section-list-item:hover .section-list-actions { opacity: 1; }
.section-list-actions button { display: flex; align-items: center; justify-content: center; width: 26px; height: 26px; border: none; background: transparent; border-radius: 5px; cursor: pointer; color: var(--app-text-dim); transition: 0.12s; }
.section-list-actions select { height: 26px; border: 1px solid var(--app-border); background: rgb(255, 255, 255); border-radius: 6px; padding: 0px 8px; font-size: 11px; color: var(--app-text-dim); max-width: 108px; }
.section-list-actions button:hover { background: var(--app-bg); color: var(--app-text); }
.section-list-actions button:last-child:hover { color: var(--app-danger); }
.add-section-area { padding: 8px 12px; position: relative; }
.add-section-btn { display: flex; align-items: center; justify-content: center; gap: 6px; width: 100%; padding: 8px; border: 2px dashed var(--app-border); background: transparent; border-radius: 8px; font-size: 12.5px; font-weight: 500; color: var(--app-text-dim); cursor: pointer; transition: 0.15s; }
.add-section-btn:hover { border-color: var(--app-accent); color: var(--app-accent); background: rgb(248, 248, 255); }
.add-section-menu { position: absolute; bottom: 100%; left: 12px; right: 12px; background: rgb(255, 255, 255); border: 1px solid var(--app-border); border-radius: 10px; box-shadow: rgba(0, 0, 0, 0.12) 0px 8px 30px; padding: 6px; display: grid; grid-template-columns: 1fr 1fr; gap: 2px; z-index: 50; max-height: 360px; overflow-y: auto; }
.add-section-menu button { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border: none; background: transparent; border-radius: 6px; font-size: 12px; cursor: pointer; color: var(--app-text); transition: background 0.1s; }
.add-section-menu button:hover { background: rgb(240, 241, 255); }
.add-section-icon { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 22px; background: rgb(239, 241, 255); border-radius: 6px; font-size: 12px; font-weight: 700; color: var(--app-accent); }
.section-editor-panel { border-top: 1px solid var(--app-border); background: rgb(250, 251, 253); }
.section-editor-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; border-bottom: 1px solid var(--app-border); }
.section-editor-header h3 { font-size: 13px; font-weight: 600; flex-shrink: 0; }
.section-type-select { flex: 1 1 0%; min-width: 0px; padding: 4px 8px; border: 1px solid var(--app-border); border-radius: 6px; font-size: 12px; font-weight: 500; background: rgb(255, 255, 255); cursor: pointer; color: var(--app-text); }
.section-type-select:focus { outline: none; border-color: var(--app-accent); }
.section-editor-header button { display: flex; border: none; background: transparent; cursor: pointer; color: var(--app-text-dim); padding: 4px; border-radius: 4px; }
.section-editor-header button:hover { background: var(--app-bg); }
.section-editor-body { padding: 12px 14px; display: flex; flex-direction: column; gap: 12px; max-height: 400px; overflow-y: auto; }
.editor-field { display: flex; flex-direction: column; gap: 4px; }
.editor-field label { font-size: 11.5px; font-weight: 500; color: var(--app-text-dim); }
.editor-field input[type="text"], .editor-field textarea, .editor-field select { padding: 7px 10px; border: 1px solid var(--app-border); border-radius: 6px; font-size: 12.5px; font-family: inherit; background: rgb(255, 255, 255); color: var(--app-text); transition: border-color 0.15s; }
.editor-field input[type="text"]:focus, .editor-field textarea:focus, .editor-field select:focus { outline: none; border-color: var(--app-accent); box-shadow: rgba(99, 102, 241, 0.12) 0px 0px 0px 2px; }
.editor-field textarea { resize: vertical; min-height: 60px; }
.editor-field input[type="range"] { width: 100%; accent-color: var(--app-accent); }
.editor-field input[type="file"] { font-size: 11px; color: var(--app-text-dim); }
.editor-list { display: flex; flex-direction: column; gap: 6px; }
.editor-list > label { font-size: 11.5px; font-weight: 600; color: var(--app-text-dim); text-transform: uppercase; letter-spacing: 0.04em; }
.editor-empty-hint { font-size: 12px; color: var(--app-text-dim); font-style: italic; padding: 8px 0px; }
.input-warning { border-color: rgb(245, 158, 11) !important; background: rgb(255, 251, 235) !important; }
.editor-list-item { padding: 10px; border: 1px solid var(--app-border); border-radius: 8px; background: rgb(255, 255, 255); display: flex; flex-direction: column; gap: 6px; }
.editor-list-item.horizontal { flex-flow: wrap; align-items: center; gap: 6px; }
.editor-list-item input[type="text"], .editor-list-item select { padding: 5px 8px; border: 1px solid var(--app-border); border-radius: 5px; font-size: 12px; font-family: inherit; }
.editor-list-item input[type="text"]:focus { outline: none; border-color: var(--app-accent); }
.media-field { gap: 6px; }
.media-input-row { display: flex; gap: 6px; }
.media-input-row select { width: 80px; flex-shrink: 0; }
.media-input-row input { flex: 1 1 0%; }
.checkbox-label { display: flex; align-items: center; gap: 5px; font-size: 11.5px; color: var(--app-text-dim); cursor: pointer; white-space: nowrap; }
.remove-btn, .add-item-btn { border: none; background: transparent; cursor: pointer; font-size: 12px; font-weight: 500; padding: 4px 8px; border-radius: 5px; transition: 0.12s; }
.remove-btn { color: var(--app-danger); align-self: flex-start; }
.remove-btn:hover { background: rgb(254, 242, 242); }
.add-item-btn { color: var(--app-accent); border: 1px dashed var(--app-accent); padding: 6px; border-radius: 6px; margin-top: 4px; }
.add-item-btn:hover { background: rgb(248, 248, 255); }
.md-toolbar { display: flex; gap: 2px; margin-bottom: 2px; }
.md-btn { background: var(--app-bg); border: 1px solid var(--app-border); border-radius: 4px; width: 28px; height: 26px; display: flex; align-items: center; justify-content: center; font-size: 12px; cursor: pointer; color: var(--app-text); transition: background 0.15s, border-color 0.15s; }
.md-btn:hover { background: var(--app-hover); border-color: var(--app-accent); }
.md-textarea { font-family: "SF Mono", "Fira Code", Consolas, monospace; font-size: 12px; line-height: 1.5; }
.floating-md-editor { position: absolute; z-index: 1000; background: rgb(255, 255, 255); border: 2px solid var(--app-accent, #6366f1); border-radius: 8px; box-shadow: rgba(0, 0, 0, 0.15) 0px 4px 16px; overflow: hidden; }
.floating-md-editor .floating-md-toolbar { display: flex; gap: 2px; padding: 4px 6px; background: rgb(248, 249, 250); border-bottom: 1px solid rgb(229, 231, 235); align-items: center; }
.floating-md-editor .floating-md-toolbar button { background: rgb(255, 255, 255); border: 1px solid rgb(229, 231, 235); border-radius: 4px; width: 26px; height: 24px; display: flex; align-items: center; justify-content: center; font-size: 11px; cursor: pointer; color: rgb(55, 65, 81); transition: background 0.15s, border-color 0.15s; }
.floating-md-editor .floating-md-toolbar button:hover { background: rgb(238, 242, 255); border-color: rgb(99, 102, 241); color: rgb(99, 102, 241); }
.fmt-math-btn { font-style: italic; font-family: KaTeX_Main, "Times New Roman", serif !important; font-size: 12px !important; }
.fmt-heading-btn { letter-spacing: -0.5px; font-size: 10px !important; font-weight: 700 !important; }
.floating-md-hint { margin-left: auto; font-size: 10px; color: rgb(156, 163, 175); }
.floating-md-textarea { width: 100%; box-sizing: border-box; border: none; outline: none; padding: 8px 10px; font-size: 13px; font-family: "SF Mono", "Fira Code", Consolas, monospace; line-height: 1.5; resize: vertical; min-height: 32px; }
.floating-md-divider { width: 1px; height: 18px; background: rgb(209, 213, 219); margin: 0px 2px; }
.fmt-accent-btn { background: linear-gradient(135deg,var(--app-accent, #6366f1),#a855f7) !important; color: rgb(255, 255, 255) !important; font-weight: 700 !important; font-size: 11px !important; }
.fmt-color-btn { position: relative; }
.fmt-color-icon { display: block; width: 14px; height: 14px; border-radius: 50%; background: conic-gradient(rgb(239, 68, 68), rgb(234, 179, 8), rgb(34, 197, 94), rgb(59, 130, 246), rgb(139, 92, 246), rgb(239, 68, 68)); border: 1px solid rgba(0, 0, 0, 0.1); }
.floating-md-color-wrap { position: relative; }
.floating-color-picker-panel { background: rgb(255, 255, 255); border-right: 1px solid rgb(229, 231, 235); border-bottom: 1px solid rgb(229, 231, 235); border-left: 1px solid rgb(229, 231, 235); border-image: initial; border-radius: 0px 0px 8px 8px; border-top: none; padding: 8px; box-shadow: rgba(0, 0, 0, 0.08) 0px 4px 12px; z-index: 1001; }
.color-picker-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; max-height: 160px; overflow-y: auto; padding: 2px; }
.color-swatch { width: 22px; height: 22px; border-radius: 4px; border: 2px solid transparent; cursor: pointer; transition: border-color 0.15s, transform 0.15s; }
.color-swatch:hover { border-color: rgb(55, 65, 81); transform: scale(1.15); }
.color-swatch-selected { border-color: rgb(17, 24, 39); transform: scale(1.15); box-shadow: rgba(59, 130, 246, 0.4) 0px 0px 0px 2px; }
.color-swatch-active { border-color: rgb(59, 130, 246); box-shadow: rgba(59, 130, 246, 0.4) 0px 0px 0px 2px; }
.color-picker-current, .color-picker-preview { display: flex; align-items: center; gap: 8px; padding: 4px 0px 8px; border-bottom: 1px solid rgb(240, 240, 240); margin-bottom: 6px; font-size: 11px; }
.color-picker-current-swatch { width: 18px; height: 18px; border-radius: 4px; border: 1px solid rgba(0, 0, 0, 0.15); flex-shrink: 0; }
.color-picker-current-label { font-family: monospace; color: rgb(107, 114, 128); flex: 1 1 0%; }
.color-picker-remove-btn, .color-picker-apply-btn { font-size: 10px; padding: 2px 8px; border-radius: 4px; border: 1px solid rgb(229, 231, 235); background: rgb(249, 250, 251); cursor: pointer; white-space: nowrap; }
.color-picker-remove-btn:hover { background: rgb(254, 242, 242); border-color: rgb(252, 165, 165); color: rgb(220, 38, 38); }
.color-picker-apply-btn:hover { background: rgb(239, 246, 255); border-color: rgb(147, 197, 253); color: rgb(37, 99, 235); }
.color-picker-custom-row { display: flex; align-items: center; gap: 6px; margin-top: 6px; padding-top: 6px; border-top: 1px solid rgb(240, 240, 240); }
.color-custom-input { width: 32px; height: 24px; border: 1px solid rgb(229, 231, 235); border-radius: 4px; cursor: pointer; padding: 0px; }
.md-accent { color: var(--accent, #6366f1); font-weight: 600; }
.math-inline { display: inline; }
.math-inline .katex { font-size: 1em; }
.math-display { margin: 1em 0px; text-align: center; overflow-x: auto; }
.math-display .katex-display { margin: 0px; }
.md-subsection { font-size: var(--subsection-size, 1.2em); font-weight: 700; color: var(--subsection-color, var(--heading, var(--text))); margin: 1.4em 0px 0.5em; padding-bottom: 0.2em; border-bottom: 1px solid var(--subsection-border-color, var(--border-color, #e5e7eb)); }
[data-subsection-no-border] .md-subsection { border-bottom: none; padding-bottom: 0px; }
.md-subsubsection { font-size: var(--subsubsection-size, 1.05em); font-weight: 600; color: var(--subsubsection-color, var(--heading, var(--text))); margin: 1.2em 0px 0.4em; }
.fde-backdrop { position: fixed; inset: 0px; z-index: 2000; background: rgba(0, 0, 0, 0.35); backdrop-filter: blur(2px); display: flex; align-items: center; justify-content: center; animation: 0.15s ease-out 0s 1 normal none running fdeBackdropIn; }
@keyframes fdeBackdropIn { 
  0% { opacity: 0; }
  100% { opacity: 1; }
}
.fde-panel { background: rgb(255, 255, 255); border-radius: 14px; box-shadow: rgba(0, 0, 0, 0.25) 0px 20px 60px, rgba(0, 0, 0, 0.05) 0px 0px 0px 1px; width: min(1100px, 92vw); height: min(80vh, 800px); display: flex; flex-direction: column; overflow: hidden; animation: 0.2s ease-out 0s 1 normal none running fdePanelIn; }
@keyframes fdePanelIn { 
  0% { opacity: 0; transform: translateY(12px) scale(0.97); }
  100% { opacity: 1; transform: none; }
}
.fde-topbar { display: flex; align-items: center; gap: 10px; padding: 12px 16px; border-bottom: 1px solid rgb(229, 231, 235); background: rgb(250, 251, 252); border-radius: 14px 14px 0px 0px; }
.fde-topbar-title { display: flex; align-items: center; gap: 6px; font-weight: 600; font-size: 14px; color: rgb(31, 41, 55); }
.fde-close-btn { background: none; border: none; cursor: pointer; color: rgb(156, 163, 175); padding: 4px; border-radius: 6px; transition: 0.15s; }
.fde-close-btn:hover { background: rgb(243, 244, 246); color: rgb(55, 65, 81); }
.fde-panel-with-preview { width: min(1400px, 95vw); }
.fde-body-split { display: flex; flex: 1 1 0%; overflow: hidden; }
.fde-editor-col { flex: 1 1 0%; min-width: 0px; display: flex; flex-direction: column; overflow: hidden; }
.fde-preview-col { width: 400px; min-width: 300px; max-width: 500px; border-left: 1px solid rgb(229, 231, 235); display: flex; flex-direction: column; background: rgb(249, 250, 251); }
.fde-preview-header { font-size: 11px; font-weight: 600; color: rgb(107, 114, 128); padding: 8px 12px; border-bottom: 1px solid rgb(229, 231, 235); text-transform: uppercase; letter-spacing: 0.5px; }
.fde-preview-content { flex: 1 1 0%; overflow: auto; padding: 16px; position: relative; }
.fde-preview-content .sec-wrapper { margin: 0px !important; padding: 0px !important; }
.fde-preview-hint { font-size: 10px; color: rgb(156, 163, 175); padding: 4px 12px 8px; text-align: center; font-style: italic; }
.fde-legend-ghost { position: absolute; pointer-events: none; padding: 4px 10px; background: rgba(59, 130, 246, 0.1); border: 1px dashed rgb(59, 130, 246); border-radius: 4px; font-size: 10px; color: rgb(59, 130, 246); white-space: nowrap; }
.fde-preview-content .chart-legend { cursor: grab; }
.fde-preview-content .chart-legend:active { cursor: grabbing; }
.fde-topbar-toggles { display: flex; gap: 4px; margin-left: auto; margin-right: 8px; }
.fde-toggle-btn { display: flex; align-items: center; gap: 4px; font-size: 11px; padding: 4px 10px; border-radius: 6px; border: 1px solid rgb(229, 231, 235); background: rgb(255, 255, 255); cursor: pointer; color: rgb(107, 114, 128); transition: 0.15s; }
.fde-toggle-btn:hover { background: rgb(243, 244, 246); }
.fde-toggle-btn.active { background: rgb(239, 246, 255); border-color: rgb(147, 197, 253); color: rgb(37, 99, 235); }
.fde-theme-section { padding: 10px 20px; border-bottom: 1px solid rgb(240, 240, 240); background: rgb(250, 251, 252); }
.fde-theme-title { font-size: 11px; font-weight: 700; color: rgb(55, 65, 81); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.5px; }
.fde-theme-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 6px 10px; }
.fde-color-field { display: flex; align-items: center; gap: 4px; font-size: 11px; }
.fde-color-field label { color: rgb(107, 114, 128); min-width: 60px; white-space: nowrap; }
.fde-color-field input[type="color"] { width: 24px; height: 20px; border: 1px solid rgb(209, 213, 219); border-radius: 3px; cursor: pointer; padding: 0px; }
.fde-color-field input[type="number"] { width: 50px; padding: 2px 4px; border: 1px solid rgb(209, 213, 219); border-radius: 4px; font-size: 11px; }
.fde-color-field select { padding: 2px 4px; border: 1px solid rgb(209, 213, 219); border-radius: 4px; font-size: 11px; }
.fde-color-hex { font-family: monospace; font-size: 10px; color: rgb(156, 163, 175); }
.fde-body { flex: 1 1 0%; overflow-y: auto; padding: 16px 20px; }
.fde-settings-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 8px 12px; margin-bottom: 12px; }
.fde-field { display: flex; flex-direction: column; gap: 2px; }
.fde-field label { font-size: 10px; font-weight: 600; color: rgb(107, 114, 128); text-transform: uppercase; letter-spacing: 0.03em; }
.fde-field input, .fde-field select { font-size: 12px; padding: 5px 8px; border: 1px solid rgb(209, 213, 219); border-radius: 6px; background: rgb(255, 255, 255); }
.fde-field input:focus, .fde-field select:focus { outline: none; border-color: var(--app-accent, #6366f1); box-shadow: rgba(99, 102, 241, 0.15) 0px 0px 0px 2px; }
.fde-field input[type="range"] { padding: 0px; }
.fde-field input[type="number"] { width: 100%; }
.fde-toggles { display: flex; gap: 16px; margin-bottom: 12px; }
.fde-toggles label { font-size: 12px; color: rgb(55, 65, 81); display: flex; align-items: center; gap: 4px; cursor: pointer; }
.fde-data-label { font-size: 11px; font-weight: 600; color: rgb(107, 114, 128); text-transform: uppercase; letter-spacing: 0.03em; margin-bottom: 6px; }
.fde-hint { font-weight: 400; text-transform: none; letter-spacing: 0px; color: rgb(156, 163, 175); margin-left: 8px; }
.fde-grid-scroll { overflow-x: auto; margin-bottom: 8px; border: 1px solid rgb(229, 231, 235); border-radius: 8px; }
.fde-grid { width: 100%; border-collapse: collapse; font-size: 12px; }
.fde-grid th, .fde-grid td { padding: 0px; border: 1px solid rgb(229, 231, 235); }
.fde-grid th { background: rgb(248, 249, 250); }
.fde-grid input { width: 100%; border: none; outline: none; padding: 6px 10px; font-size: 12px; background: transparent; }
.fde-grid input:focus { background: rgb(238, 242, 255); }
.fde-grid-header-input { font-weight: 600; }
.fde-grid-series { min-width: 160px; }
.fde-grid-series-cell { display: flex; gap: 6px; align-items: center; padding: 2px 4px; }
.fde-grid-series-cell input[type="text"] { flex: 1 1 0%; font-weight: 600; }
.fde-grid-series-cell input[type="color"] { width: 22px; height: 22px; padding: 0px; border: 1px solid rgb(209, 213, 219); border-radius: 4px; cursor: pointer; }
.fde-grid-add-col { width: 32px; background: rgb(248, 249, 250); text-align: center; }
.fde-grid-add-col button { background: none; border: none; font-size: 16px; cursor: pointer; color: rgb(99, 102, 241); font-weight: 700; }
.fde-col-del { position: absolute; top: 0px; right: 2px; background: none; border: none; font-size: 12px; cursor: pointer; color: rgb(239, 68, 68); opacity: 0; transition: opacity 0.15s; }
.fde-grid th { position: relative; }
.fde-grid th:hover .fde-col-del { opacity: 1; }
.fde-grid-actions { display: flex; gap: 2px; padding: 2px 4px; align-items: center; }
.fde-hl-row { background: rgb(254, 249, 195) !important; }
.fde-hl-btn { background: none; border: none; cursor: pointer; font-size: 14px; color: rgb(209, 213, 219); transition: color 0.15s; }
.fde-hl-btn.active { color: rgb(234, 179, 8); }
.fde-del-btn { background: none; border: none; cursor: pointer; font-size: 14px; color: rgb(209, 213, 219); transition: color 0.15s; }
.fde-del-btn:hover { color: rgb(239, 68, 68); }
.fde-move-btn { background: none; border: none; cursor: pointer; font-size: 13px; color: rgb(156, 163, 175); transition: color 0.15s; padding: 0px 2px; line-height: 1; }
.fde-move-btn:hover:not(:disabled) { color: rgb(99, 102, 241); }
.fde-move-btn:disabled { opacity: 0.2; cursor: default; }
.fde-col-header { display: flex; align-items: center; gap: 0px; }
.fde-col-header .fde-grid-header-input { flex: 1 1 0%; min-width: 0px; }
.fde-col-move { width: 14px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.fde-col-move .fde-move-btn { font-size: 16px; font-weight: 700; }
.fde-add-btn { background: none; border: 1px dashed rgb(209, 213, 219); border-radius: 6px; padding: 5px 12px; font-size: 12px; color: rgb(99, 102, 241); cursor: pointer; transition: 0.15s; }
.fde-add-btn:hover { background: rgb(238, 242, 255); border-color: rgb(99, 102, 241); }
.fde-remove-btn { background: none; border: 1px solid rgb(254, 202, 202); border-radius: 6px; padding: 5px 12px; font-size: 12px; color: rgb(239, 68, 68); cursor: pointer; transition: 0.15s; }
.fde-remove-btn:hover { background: rgb(254, 242, 242); }
.fde-actions-row { display: flex; gap: 8px; margin-top: 4px; }
.fde-table-tabs { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 12px; }
.fde-tab { background: rgb(243, 244, 246); border: 1px solid rgb(229, 231, 235); border-radius: 6px; padding: 5px 12px; font-size: 12px; cursor: pointer; transition: 0.15s; color: rgb(55, 65, 81); }
.fde-tab.active { background: var(--app-accent, #6366f1); color: rgb(255, 255, 255); border-color: var(--app-accent, #6366f1); }
.fde-chart-block { border: 1px solid rgb(229, 231, 235); border-radius: 10px; overflow: hidden; margin-bottom: 12px; }
.fde-chart-header { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: rgb(248, 249, 250); cursor: pointer; border-bottom: 1px solid rgb(229, 231, 235); }
.fde-chart-title { font-weight: 600; font-size: 13px; flex: 1 1 0%; }
.fde-chart-type { font-size: 11px; color: rgb(156, 163, 175); background: rgb(243, 244, 246); padding: 2px 8px; border-radius: 4px; }
.fde-chart-body { padding: 14px; }
.chart-expand-icon { font-size: 10px; transition: transform 0.2s; display: inline-block; color: rgb(156, 163, 175); }
.fde-scatter-block { border: 1px solid rgb(229, 231, 235); border-radius: 8px; padding: 10px; margin-bottom: 8px; }
.fde-ds-header { display: flex; gap: 6px; align-items: center; margin-bottom: 6px; }
.fde-ds-name { flex: 1 1 0%; font-weight: 600; font-size: 12px; padding: 4px 8px; border: 1px solid rgb(229, 231, 235); border-radius: 4px; }
.fde-open-section { display: flex; flex-direction: column; gap: 10px; padding: 12px; background: rgb(248, 249, 250); border-radius: 10px; border: 1px solid rgb(229, 231, 235); }
.fde-summary { display: flex; gap: 10px; align-items: center; }
.fde-summary-icon { color: var(--app-accent, #6366f1); flex-shrink: 0; }
.fde-summary-text { display: flex; flex-direction: column; gap: 1px; }
.fde-summary-text strong { font-size: 13px; color: rgb(31, 41, 55); }
.fde-summary-text span { font-size: 11px; color: rgb(107, 114, 128); }
.fde-open-btn { display: flex; align-items: center; justify-content: center; gap: 6px; padding: 8px 16px; border-radius: 8px; background: var(--app-accent, #6366f1); color: rgb(255, 255, 255); border: none; font-size: 13px; font-weight: 600; cursor: pointer; transition: 0.15s; }
.fde-open-btn:hover { filter: brightness(1.1); box-shadow: rgba(99, 102, 241, 0.3) 0px 2px 8px; }
.bullet-editor .bullet-hint { font-size: 10px; color: var(--app-text-dim); opacity: 0.6; margin-top: -2px; margin-bottom: 2px; }
.bullet-row { cursor: default; transition: opacity 0.15s; }
.bullet-row.dragging { opacity: 0.4; }
.bullet-drag-handle { cursor: grab; font-size: 14px; color: var(--app-text-dim); opacity: 0.4; user-select: none; flex-shrink: 0; line-height: 1; }
.bullet-drag-handle:hover { opacity: 0.8; }
.bullet-row input[type="text"] { flex: 1 1 0%; }
.table-grid-editor { display: flex; flex-direction: column; gap: 8px; }
.editor-field-label { font-size: 11.5px; font-weight: 600; color: var(--app-text-dim); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: -2px; }
.editor-hint { font-size: 10.5px; color: var(--app-text-dim); opacity: 0.7; margin-top: -2px; }
.editor-field-row { display: flex; gap: 8px; }
.table-grid-scroll { overflow-x: auto; max-width: 100%; border: 1px solid var(--app-border); border-radius: 8px; }
.table-grid { width: 100%; border-collapse: collapse; min-width: max-content; }
.table-grid-th { position: relative; background: var(--app-bg); }
.table-grid-th .table-grid-input.header { font-weight: 600; background: transparent; font-size: 11.5px; }
.table-grid-input { width: 100%; border: none; padding: 7px 8px; font-size: 12px; font-family: inherit; background: transparent; color: var(--app-text); outline: none; min-width: 60px; box-sizing: border-box; }
.table-grid-input:focus { background: rgb(240, 240, 255); }
.table-grid-input[type="number"] { }
.table-grid-input[type="number"]::-webkit-inner-spin-button, .table-grid-input[type="number"]::-webkit-outer-spin-button { appearance: none; }
.table-grid th, .table-grid td { border: 1px solid var(--app-border); }
.table-grid-col-del { position: absolute; top: 2px; right: 2px; width: 16px; height: 16px; border: none; background: transparent; color: var(--app-danger); font-size: 12px; cursor: pointer; opacity: 0; border-radius: 3px; line-height: 1; }
.table-grid-th:hover .table-grid-col-del { opacity: 0.6; }
.table-grid-col-del:hover { background: rgb(255, 238, 238); opacity: 1 !important; }
.table-grid-add-col { width: 32px; background: var(--app-bg); text-align: center; vertical-align: middle; }
.table-grid-add-col button { border: none; background: transparent; color: var(--app-accent); font-size: 16px; font-weight: 700; cursor: pointer; padding: 4px 8px; }
.table-grid-actions { width: 50px; background: var(--app-bg); text-align: center; vertical-align: middle; white-space: nowrap; }
.table-grid-hl-btn, .table-grid-del-btn { border: none; background: transparent; cursor: pointer; font-size: 13px; padding: 2px 4px; border-radius: 3px; line-height: 1; vertical-align: middle; }
.table-grid-hl-btn { color: rgb(204, 204, 204); }
.table-grid-hl-btn.active, .table-grid-hl-btn:hover { color: rgb(245, 158, 11); }
.table-grid-del-btn { color: rgb(204, 204, 204); font-size: 14px; }
.table-grid-del-btn:hover { color: var(--app-danger); background: rgb(255, 238, 238); }
.table-grid-hl tr, tr.table-grid-hl { background: rgba(245, 158, 11, 0.06); }
.chart-editor { display: flex; flex-direction: column; gap: 8px; }
.chart-editor-options { display: flex; flex-direction: column; gap: 4px; margin-top: 4px; }
.chart-config-block { border: 1px solid var(--app-border, #e5e7eb); border-radius: 8px; padding: 10px !important; }
.chart-config-header { display: flex; align-items: center; gap: 6px; cursor: pointer; user-select: none; }
.chart-expand-icon { font-size: 12px; color: rgb(136, 136, 136); transition: transform 0.15s; display: inline-block; }
.chart-expand-icon.open { transform: rotate(90deg); }
.chart-data-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.chart-apply-all-btn { color: rgb(124, 58, 237) !important; border-color: rgb(124, 58, 237) !important; }
.chart-apply-all-btn:hover { background: rgb(245, 243, 255) !important; }
.scatter-dataset-block { border: 1px solid var(--app-border); border-radius: 8px; padding: 8px; margin-bottom: 6px; background: rgb(250, 250, 250); }
.scatter-dataset-header { display: flex; align-items: center; gap: 4px; margin-bottom: 6px; }
.theme-editor { padding: 0px; display: flex; flex-direction: column; gap: 2px; }
.theme-category-tabs { display: flex; gap: 0px; padding: 6px 8px; border-bottom: 1px solid var(--app-border); background: rgb(250, 251, 253); position: sticky; top: 0px; z-index: 5; }
.theme-category-tabs button { flex: 1 1 0%; padding: 6px 0px; border: none; background: transparent; font-size: 11.5px; font-weight: 600; cursor: pointer; color: var(--app-text-dim); border-radius: 6px; transition: 0.15s; }
.theme-category-tabs button:hover { color: var(--app-text); background: rgba(0, 0, 0, 0.03); }
.theme-category-tabs button.active { color: var(--app-accent); background: rgb(239, 241, 255); }
.theme-editor > :not(.theme-category-tabs) { padding: 0px 8px; }
.shadow-preview-box { display: flex; gap: 12px; padding: 12px 8px; background: rgb(245, 246, 248); border-radius: 8px; }
.shadow-preview-card { flex: 1 1 0%; height: 48px; background: rgb(255, 255, 255); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 600; color: rgb(136, 136, 136); transition: box-shadow 0.2s; }
.theme-group-collapsible { border-bottom: 1px solid var(--app-border); position: relative; }
.theme-group-collapsible.focused { background: rgba(99, 102, 241, 0.04); box-shadow: inset 3px 0 0 var(--app-accent); }
.theme-group-collapsible.focused > .theme-group-toggle { color: var(--app-accent); }
.theme-group-toggle { display: flex; align-items: center; gap: 8px; width: 100%; padding: 10px 6px; border: none; background: transparent; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--app-text-dim); cursor: pointer; transition: color 0.15s; }
.theme-group-icon { display: inline-flex; align-items: center; justify-content: center; width: 18px; color: var(--app-accent); font-size: 12px; flex-shrink: 0; }
.theme-group-toggle:hover { color: var(--app-text); }
.theme-group-toggle.open { color: var(--app-accent); }
.theme-group-body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.2s, padding 0.2s, opacity 0.15s; opacity: 0; padding: 0px 8px; overflow: hidden; }
.theme-group-body > * { overflow: hidden; display: flex; flex-direction: column; gap: 6px; min-height: 0px; }
.theme-group-body.open { grid-template-rows: 1fr; opacity: 1; padding: 4px 8px 14px; overflow: visible; }
.theme-group-body.open > * { overflow: visible; }
.color-palettes { margin-bottom: 10px; display: flex; flex-direction: column; gap: 6px; }
.palette-cat-label { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: rgb(170, 170, 170); padding: 0px 2px; }
.color-palette-row { display: grid; grid-template-columns: repeat(auto-fill, minmax(56px, 1fr)); gap: 4px; }
.color-palette-chip { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 4px 4px 3px; border: 1.5px solid var(--app-border); border-radius: 6px; background: rgb(255, 255, 255); cursor: pointer; transition: 0.15s; min-width: 0px; }
.color-palette-chip:hover { border-color: var(--app-accent); }
.color-palette-chip.active { border-color: var(--app-accent); background: rgba(99, 102, 241, 0.04); box-shadow: rgba(99, 102, 241, 0.15) 0px 0px 0px 1.5px; }
.cp-dots { display: flex; gap: 2px; }
.cp-dots span { width: 12px; height: 12px; border-radius: 50%; border: 1px solid rgba(0, 0, 0, 0.08); }
.cp-name { font-size: 9px; font-weight: 600; color: var(--app-text-dim); white-space: nowrap; }
.color-grid-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 12px; }
.color-input { display: flex; flex-direction: column; gap: 3px; position: relative; }
.color-input label { font-size: 11.5px; color: var(--app-text-dim); }
.color-input-row { display: flex; gap: 6px; align-items: center; }
.color-swatch-trigger { width: 24px; height: 24px; border: 1.5px solid var(--app-border); border-radius: 5px; cursor: pointer; flex-shrink: 0; transition: box-shadow 0.15s; }
.color-swatch-trigger:hover { box-shadow: rgba(99, 102, 241, 0.25) 0px 0px 0px 2px; }
.color-input-row input[type="text"] { flex: 1 1 0%; padding: 4px 7px; border: 1px solid var(--app-border); border-radius: 5px; font-size: 11px; font-family: "JetBrains Mono", monospace; min-width: 0px; }
.color-input-row input[type="text"]:focus { outline: none; border-color: var(--app-accent); }
.color-popup { position: absolute; top: 100%; left: 0px; right: 0px; z-index: 20; margin-top: 4px; background: rgb(255, 255, 255); border: 1px solid var(--app-border); border-radius: 10px; box-shadow: rgba(0, 0, 0, 0.15) 0px 8px 24px; padding: 10px; display: flex; flex-direction: column; gap: 8px; }
.color-popup-label { font-size: 10px; font-weight: 700; color: rgb(153, 153, 153); text-transform: uppercase; letter-spacing: 0.3px; }
.color-popup-swatches { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; }
.color-popup-custom { display: flex; gap: 6px; align-items: center; border-top: 1px solid rgb(238, 238, 238); padding-top: 8px; }
.color-popup-custom input[type="color"] { width: 28px; height: 28px; border: 1px solid rgb(221, 221, 221); border-radius: 5px; padding: 1px; cursor: pointer; background: rgb(255, 255, 255); }
.color-popup-custom input[type="text"] { flex: 1 1 0%; padding: 5px 8px; border: 1px solid var(--app-border); border-radius: 5px; font-size: 11px; font-family: "JetBrains Mono", monospace; }
.color-swatch { width: 100%; aspect-ratio: 1 / 1; border-radius: 3px; border: 1.5px solid transparent; cursor: pointer; transition: 0.1s; padding: 0px; }
.color-swatch:hover { transform: scale(1.25); z-index: 1; border-radius: 2px; }
.color-swatch.active { border-color: var(--app-accent); box-shadow: 0 0 0 1.5px #fff,0 0 0 3px var(--app-accent); }
.color-row { display: flex; align-items: center; gap: 8px; position: relative; }
.color-row-label { font-size: 11px; color: var(--app-text-dim); flex-shrink: 0; min-width: 60px; }
.color-row-dots { display: flex; gap: 4px; }
.color-row-dot { width: 22px; height: 22px; border-radius: 5px; border: 1.5px solid rgba(0, 0, 0, 0.1); cursor: pointer; transition: 0.12s; padding: 0px; }
.color-row-dot:hover { transform: scale(1.15); box-shadow: rgba(99, 102, 241, 0.2) 0px 0px 0px 2px; }
.color-row-dot.active { box-shadow: 0 0 0 2px var(--app-accent); }
.color-row .color-popup { left: 0px; right: auto; min-width: 240px; }
.theme-field { display: flex; flex-direction: column; gap: 4px; }
.theme-field label { font-size: 11.5px; color: var(--app-text-dim); }
.scrub-field { position: relative; border: 1px solid var(--app-border); border-radius: 8px; overflow: hidden; background: rgb(255, 255, 255); transition: border-color 0.15s, box-shadow 0.15s; }
.scrub-field::before { content: ""; position: absolute; inset: 0px; width: var(--scrub-pct, 0%); background: var(--app-accent, #6366f1); opacity: 0.06; transition: opacity 0.15s; pointer-events: none; }
.scrub-field:hover { border-color: rgb(192, 196, 204); }
.scrub-field:hover::before { opacity: 0.1; }
.scrub-field.dragging { border-color: var(--app-accent); box-shadow: rgba(99, 102, 241, 0.1) 0px 0px 0px 2px; }
.scrub-field.dragging::before { opacity: 0.14; transition: none; }
.scrub-label { display: flex; align-items: center; justify-content: space-between; padding: 7px 10px; cursor: ew-resize; user-select: none; position: relative; z-index: 1; }
.scrub-name { font-size: 11.5px; color: var(--app-text-dim); }
.scrub-value { font-size: 11.5px; font-weight: 600; color: var(--app-text); font-family: "JetBrains Mono", monospace; min-width: 32px; text-align: right; }
.scrub-edit { width: 60px; text-align: right; border: none; outline: none; font-size: 11.5px; font-weight: 600; font-family: "JetBrains Mono", monospace; color: var(--app-accent); background: transparent; padding: 0px; }
.font-select { display: flex; flex-direction: column; gap: 3px; position: relative; }
.font-select label { font-size: 11.5px; color: var(--app-text-dim); }
.font-select-trigger { display: flex; align-items: center; justify-content: space-between; padding: 6px 10px; border: 1px solid var(--app-border); border-radius: 6px; background: rgb(255, 255, 255); cursor: pointer; font-size: 13px; transition: border-color 0.15s; }
.font-select-trigger:hover { border-color: rgb(187, 187, 187); }
.font-select-dropdown { position: absolute; top: 100%; left: 0px; right: 0px; z-index: 30; margin-top: 4px; background: rgb(255, 255, 255); border: 1px solid var(--app-border); border-radius: 10px; box-shadow: rgba(0, 0, 0, 0.15) 0px 8px 24px; max-height: 260px; overflow-y: auto; padding: 4px; }
.font-select-cat { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: rgb(153, 153, 153); padding: 8px 10px 2px; }
.font-select-item { display: block; width: 100%; text-align: left; padding: 7px 10px; border: none; background: transparent; cursor: pointer; border-radius: 6px; font-size: 14px; transition: background 0.1s; color: var(--app-text); }
.font-select-item:hover { background: var(--app-bg); }
.font-select-item.active { background: rgb(239, 241, 255); color: var(--app-accent); font-weight: 600; }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.shadow-controls { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
.theme-field select, .theme-field input[type="text"] { padding: 7px 10px; border: 1px solid var(--app-border); border-radius: 6px; font-size: 12.5px; background: rgb(255, 255, 255); }
.theme-field select:focus, .theme-field input[type="text"]:focus { outline: none; border-color: var(--app-accent); }
.theme-field input[type="range"] { width: 100%; accent-color: var(--app-accent); }
.style-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.style-grid-item { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 8px 4px 6px; border: 2px solid transparent; border-radius: 10px; cursor: pointer; background: rgb(248, 249, 251); transition: 0.15s; font-family: inherit; color: var(--app-text); }
.style-grid-item:hover { background: rgb(240, 241, 246); border-color: rgb(216, 218, 224); }
.style-grid-item.active { border-color: var(--app-accent); background: rgb(240, 240, 255); box-shadow: 0 0 0 1px var(--app-accent); }
.style-grid-preview { width: 100%; height: 38px; display: flex; align-items: center; justify-content: center; border-radius: 6px; background: rgb(255, 255, 255); overflow: hidden; }
.style-grid-item.active .style-grid-preview { background: rgb(250, 250, 255); }
.style-grid-name { font-size: 10px; font-weight: 600; line-height: 1.2; text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
.style-grid-hint { font-size: 8px; font-weight: 500; color: var(--app-text-dim); opacity: 0.55; text-transform: uppercase; letter-spacing: 0.04em; line-height: 1; margin-top: -2px; }
.json-editor { display: flex; flex-direction: column; height: 100%; padding: 8px; }
.json-editor textarea { flex: 1 1 0%; min-height: 400px; padding: 12px; border: 1px solid var(--app-border); border-radius: 8px; font-family: "JetBrains Mono", monospace; font-size: 11px; line-height: 1.5; resize: none; background: rgb(250, 251, 253); color: var(--app-text); }
.json-editor textarea:focus { outline: none; border-color: var(--app-accent); }
.json-apply-btn { margin-top: 8px; padding: 8px; background: var(--app-accent); color: rgb(255, 255, 255); border: none; border-radius: 7px; font-size: 12.5px; font-weight: 600; cursor: pointer; transition: background 0.15s; }
.json-apply-btn:hover { background: var(--app-accent-hover); }
.preview { flex: 1 1 0%; overflow: hidden; position: relative; }
.preview.preview-full { width: 100%; }
.preview-scroll { height: 100%; overflow-y: auto; }
.preview-outer { font-family: var(--font); font-size: var(--font-size, 16px); color: var(--text); line-height: var(--body-line-height, 1.5); background: var(--bg, #fff); min-height: 100%; }
.preview-outer.has-sidebar { display: flex; }
.preview-outer.sidebar-right { flex-direction: row-reverse; }
.preview-page { flex: 1 1 0%; min-width: 0px; max-width: var(--max-width, 1000px); margin: 0px auto; }
.preview-page-body { position: relative; }
.preview-page-content { min-width: 0px; }
.preview-sidebar-col { width: 200px; flex-shrink: 0; position: sticky; top: 0px; height: 100vh; display: flex; flex-direction: column; justify-content: flex-start; padding: 24px 8px 24px 16px; overflow-y: auto; }
.preview-sidebar-col[data-align="center"] { justify-content: center; }
.preview-sidebar-col[data-align="bottom"] { justify-content: flex-end; }
.preview-outer.sidebar-right > .preview-sidebar-col { padding: 24px 16px 24px 8px; }
.preview-section-wrapper { position: relative; transition: outline 0.15s, opacity 0.2s; scroll-margin-top: 60px; outline: transparent solid 2px; outline-offset: -2px; cursor: pointer; }
.preview-section-wrapper:hover { outline-color: rgba(99, 102, 241, 0.25); }
.preview-section-wrapper.selected { outline-color: var(--app-accent); background: rgba(99, 102, 241, 0.02); }
.preview-section-wrapper.dragging { opacity: 0.4; }
.spacing-handle { position: absolute; left: 0px; right: 0px; height: 12px; cursor: ns-resize; z-index: 10; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.15s; }
.spacing-handle::before { content: ""; position: absolute; left: 10%; right: 10%; height: 2px; background: var(--app-accent, #6366f1); border-radius: 1px; opacity: 0.5; }
.spacing-handle-top { top: 0px; }
.spacing-handle-bottom { bottom: 0px; }
.preview-section-wrapper.selected .spacing-handle, .spacing-handle:hover, .spacing-handle.dragging { opacity: 1; }
.spacing-handle:hover::before, .spacing-handle.dragging::before { opacity: 1; height: 3px; }
.spacing-handle-label { font-size: 10px; font-weight: 600; color: rgb(255, 255, 255); background: var(--app-accent, #6366f1); padding: 0px 6px; border-radius: 3px; line-height: 16px; z-index: 1; pointer-events: none; opacity: 0; transition: opacity 0.15s; white-space: nowrap; }
.spacing-handle:hover .spacing-handle-label, .spacing-handle.dragging .spacing-handle-label { opacity: 1; }
.spacing-handle.custom::after { content: ""; position: absolute; right: 8px; top: 50%; transform: translateY(-50%); width: 6px; height: 6px; border-radius: 50%; background: var(--app-accent, #6366f1); }
.editor-reset-btn { border: none; background: none; cursor: pointer; padding: 2px; color: rgb(153, 153, 153); display: flex; align-items: center; border-radius: 4px; }
.editor-reset-btn:hover { color: var(--app-accent, #6366f1); background: rgba(99, 102, 241, 0.08); }
.editor-spacing-section { border-top: 1px solid rgb(238, 238, 238); margin-top: 12px; padding-top: 12px; }
.assets-panel { padding: 12px; display: flex; flex-direction: column; gap: 8px; height: 100%; }
.assets-empty { flex: 1 1 0%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: rgb(170, 170, 170); text-align: center; padding: 24px; }
.assets-empty p { font-size: 14px; font-weight: 600; color: rgb(136, 136, 136); margin: 0px; }
.assets-empty span { font-size: 12px; line-height: 1.5; }
.assets-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); gap: 8px; flex: 1 1 0%; overflow-y: auto; align-content: start; }
.assets-item { border: 2px solid rgb(229, 231, 235); border-radius: 8px; overflow: hidden; cursor: grab; transition: border-color 0.15s; position: relative; background: rgb(248, 249, 250); }
.assets-item:hover { border-color: rgb(99, 102, 241); }
.assets-item:active { cursor: grabbing; }
.assets-item img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; }
.assets-item-actions { display: flex; align-items: center; justify-content: space-between; padding: 3px 6px; background: rgb(255, 255, 255); border-top: 1px solid rgb(238, 238, 238); }
.assets-item-label { font-size: 9px; color: rgb(153, 153, 153); }
.assets-item-remove { background: none; border: none; cursor: pointer; color: rgb(204, 204, 204); padding: 2px; border-radius: 3px; line-height: 0; }
.assets-item-remove:hover { color: rgb(239, 68, 68); background: rgb(254, 242, 242); }
.file-tree { display: flex; flex-direction: column; height: 100%; }
.file-tree-header { display: flex; align-items: center; gap: 6px; padding: 8px 4px; font-size: 12px; font-weight: 700; color: rgb(85, 85, 85); border-bottom: 1px solid var(--app-border); }
.file-tree-items { flex: 1 1 0%; overflow-y: auto; padding: 4px 0px; }
.file-tree-item { display: flex; align-items: center; gap: 6px; padding: 4px 8px 4px 12px; font-size: 11.5px; color: rgb(102, 102, 102); font-family: "JetBrains Mono", monospace; }
.file-icon { font-size: 12px; }
.file-tracked { color: rgb(85, 85, 85); }
.file-tree-folder { margin-top: 4px; }
.file-tree-folder-name { display: flex; align-items: center; gap: 5px; padding: 4px 8px; font-size: 11.5px; font-weight: 600; color: rgb(85, 85, 85); }
.file-count { font-size: 10px; background: var(--app-bg); color: rgb(136, 136, 136); padding: 0px 5px; border-radius: 8px; }
.file-tree-empty { padding: 8px 16px 8px 28px; font-size: 11px; color: rgb(170, 170, 170); }
.file-tree-asset { display: flex; align-items: center; gap: 6px; padding: 3px 8px 3px 28px; cursor: grab; transition: background 0.1s; }
.file-tree-asset:hover { background: var(--app-bg); }
.file-tree-asset:active { cursor: grabbing; }
.file-tree-asset-thumb { width: 28px; height: 28px; border-radius: 4px; overflow: hidden; flex-shrink: 0; border: 1px solid rgb(238, 238, 238); cursor: pointer; transition: transform 0.1s; }
.file-tree-asset-thumb:hover { transform: scale(1.15); border-color: var(--app-accent); }
.file-tree-asset-thumb img { width: 100%; height: 100%; object-fit: cover; }
.asset-lightbox { position: fixed; inset: 0px; z-index: 9999; background: rgba(0, 0, 0, 0.8); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; cursor: pointer; }
.asset-lightbox img { max-width: 85vw; max-height: 85vh; border-radius: 8px; box-shadow: rgba(0, 0, 0, 0.5) 0px 10px 40px; cursor: default; object-fit: contain; }
.asset-lightbox-close { position: absolute; top: 16px; right: 16px; background: rgba(255, 255, 255, 0.15); border: none; color: rgb(255, 255, 255); width: 36px; height: 36px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.asset-lightbox-close:hover { background: rgba(255, 255, 255, 0.3); }
.file-tree-asset-name { flex: 1 1 0%; font-size: 11px; font-family: "JetBrains Mono", monospace; color: rgb(85, 85, 85); min-width: 0px; overflow: hidden; text-overflow: ellipsis; }
.file-tree-asset-remove { opacity: 0; background: none; border: none; cursor: pointer; color: rgb(204, 204, 204); padding: 2px; border-radius: 3px; line-height: 0; }
.file-tree-asset:hover .file-tree-asset-remove { opacity: 1; }
.file-tree-asset-remove:hover { color: rgb(239, 68, 68); }
.file-tree-upload { padding: 4px 8px 4px 28px; }
.file-tree-upload button { display: flex; align-items: center; gap: 5px; width: 100%; padding: 5px 10px; border: 1.5px dashed rgb(208, 213, 221); border-radius: 6px; background: transparent; cursor: pointer; font-size: 11px; font-weight: 600; color: var(--app-text-dim); transition: 0.15s; }
.file-tree-upload button:hover { border-color: var(--app-accent); color: var(--app-accent); background: rgba(99, 102, 241, 0.03); }
.file-tree-item { cursor: pointer; border-radius: 4px; transition: background 0.1s; }
.file-tree-item:hover { background: var(--app-bg); }
.media-input-preview { position: relative; width: 100%; height: 60px; border-radius: 6px; overflow: hidden; border: 1px solid rgb(238, 238, 238); margin-bottom: 4px; }
.media-input-preview img { width: 100%; height: 100%; object-fit: cover; }
.media-crop-btn { position: absolute; top: 4px; right: 4px; width: 24px; height: 24px; border-radius: 4px; background: rgba(0, 0, 0, 0.55); border: none; color: rgb(255, 255, 255); cursor: pointer; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.15s; padding: 0px; line-height: 0; }
.media-input-preview:hover .media-crop-btn { opacity: 1; }
.media-crop-btn:hover { background: rgba(0, 0, 0, 0.8); }
.crop-backdrop { position: fixed; inset: 0px; z-index: 9999; background: rgba(0, 0, 0, 0.7); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; }
.crop-modal { background: rgb(26, 26, 46); border-radius: 12px; box-shadow: rgba(0, 0, 0, 0.5) 0px 20px 60px; display: flex; flex-direction: column; max-width: 90vw; max-height: 90vh; overflow: hidden; }
.crop-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
.crop-title { color: rgb(255, 255, 255); font-size: 14px; font-weight: 600; }
.crop-close { background: none; border: none; color: rgba(255, 255, 255, 0.6); cursor: pointer; padding: 4px; line-height: 0; border-radius: 4px; }
.crop-close:hover { color: rgb(255, 255, 255); background: rgba(255, 255, 255, 0.1); }
.crop-canvas-area { padding: 16px; display: flex; align-items: center; justify-content: center; overflow: auto; flex: 1 1 0%; }
.crop-canvas-area canvas { border-radius: 4px; }
.crop-loading { color: rgba(255, 255, 255, 0.6); font-size: 13px; }
.crop-footer { display: flex; gap: 8px; justify-content: flex-end; padding: 12px 16px; border-top: 1px solid rgba(255, 255, 255, 0.1); }
.crop-btn { padding: 6px 16px; border-radius: 6px; font-size: 13px; font-weight: 500; cursor: pointer; border: none; transition: 0.15s; }
.crop-btn-cancel { background: rgba(255, 255, 255, 0.1); color: rgb(255, 255, 255); }
.crop-btn-cancel:hover { background: rgba(255, 255, 255, 0.2); }
.crop-btn-apply { background: rgb(99, 102, 241); color: rgb(255, 255, 255); }
.crop-btn-apply:hover { background: rgb(79, 70, 229); }
.crop-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.media-upload-btn { padding: 6px 8px; background: rgb(255, 255, 255); border: 1px solid var(--app-border); border-radius: 6px; cursor: pointer; color: rgb(136, 136, 136); line-height: 0; transition: 0.15s; flex-shrink: 0; }
.media-upload-btn:hover { border-color: var(--app-accent); color: var(--app-accent); }
.label-title-controls { display: flex; flex-direction: column; gap: 4px; }
.label-title-row { display: flex; gap: 4px; align-items: center; }
.label-input { flex: 1 1 0%; padding: 5px 8px; border: 1px solid var(--app-border); border-radius: 6px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--app-accent); min-width: 0px; }
.title-input { flex: 1 1 0%; padding: 5px 8px; border: 1px solid var(--app-border); border-radius: 6px; font-size: 13px; font-weight: 600; min-width: 0px; }
.add-label-btn { padding: 4px 10px; border: 1.5px dashed var(--app-border); border-radius: 6px; background: transparent; font-size: 11px; color: var(--app-text-dim); cursor: pointer; transition: 0.15s; }
.add-label-btn:hover { border-color: var(--app-accent); color: var(--app-accent); }
.preview-section-wrapper.asset-drop-target:not(:has(.grid-cell)) { outline-offset: -3px; outline: rgb(34, 197, 94) dashed 3px !important; background: rgba(34, 197, 94, 0.06) !important; }
.pv-controls { position: absolute; top: 0px; left: 0px; right: 0px; z-index: 10; display: flex; align-items: center; justify-content: space-between; padding: 3px 6px; opacity: 0; transition: opacity 0.12s; background: linear-gradient(rgba(255, 255, 255, 0.95) 80%, transparent); font-family: Inter, sans-serif; pointer-events: none; }
.preview-section-wrapper:hover .pv-controls, .preview-section-wrapper.selected .pv-controls { opacity: 1; pointer-events: auto; }
.pv-type-select { font-size: 10px; font-weight: 600; color: var(--app-accent); text-transform: uppercase; letter-spacing: 0.03em; background: transparent; border: 1px solid transparent; border-radius: 4px; padding: 2px 4px; cursor: pointer; max-width: 140px; }
.pv-type-select:hover { border-color: rgba(99, 102, 241, 0.3); background: rgba(255, 255, 255, 0.8); }
.pv-type-select:focus { outline: none; border-color: var(--app-accent); background: rgb(255, 255, 255); }
.pv-controls-label { font-size: 10px; font-weight: 600; color: var(--app-accent); text-transform: uppercase; letter-spacing: 0.03em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 200px; }
.pv-controls-btns { display: flex; align-items: center; gap: 2px; }
.pv-ctrl-btn { display: flex; align-items: center; justify-content: center; width: 26px; height: 26px; border: none; background: transparent; cursor: pointer; border-radius: 5px; color: var(--app-text-dim); transition: 0.12s; }
.pv-ctrl-btn:hover { background: var(--app-bg); color: var(--app-accent); }
.pv-ctrl-btn.pv-ctrl-danger:hover { background: rgb(254, 242, 242); color: var(--app-danger); }
.pv-ctrl-btn.pv-ctrl-add:hover { background: rgb(240, 253, 244); color: rgb(34, 197, 94); }
.pv-controls-add-menu { position: absolute; top: 100%; right: 0px; z-index: 30; background: rgb(255, 255, 255); border: 1px solid var(--app-border); border-radius: 8px; box-shadow: rgba(0, 0, 0, 0.12) 0px 4px 16px; padding: 4px; min-width: 140px; max-height: 300px; overflow-y: auto; }
.pv-controls-add-menu button { display: block; width: 100%; text-align: left; padding: 6px 10px; border: none; background: none; font-size: 11px; cursor: pointer; border-radius: 4px; color: var(--app-text); }
.pv-controls-add-menu button:hover { background: var(--app-bg); color: var(--app-accent); }
.pv-grid-settings { position: relative; }
.pv-grid-popup { display: none; position: absolute; top: 100%; right: 0px; z-index: 30; background: rgb(255, 255, 255); border: 1px solid var(--app-border); border-radius: 8px; box-shadow: rgba(0, 0, 0, 0.12) 0px 4px 12px; padding: 8px; gap: 6px; align-items: center; flex-wrap: wrap; }
.pv-grid-settings.show-popup .pv-grid-popup { display: flex; min-width: 220px; }
.pv-grid-popup label { font-size: 10px; font-weight: 600; color: rgb(136, 136, 136); }
.pv-grid-popup input { width: 40px; padding: 3px 6px; border: 1px solid rgb(221, 221, 221); border-radius: 4px; font-size: 12px; text-align: center; }
.pv-grid-popup-divider { width: 100%; height: 1px; background: rgb(238, 238, 238); margin: 2px 0px; }
.pv-drag-handle { display: flex; align-items: center; justify-content: center; width: 26px; height: 26px; cursor: grab; color: rgb(204, 204, 204); border-radius: 5px; transition: 0.12s; }
.pv-drag-handle:hover { color: var(--app-text-dim); background: var(--app-bg); }
.pv-drag-handle:active { cursor: grabbing; }
.drop-indicator { height: 3px; background: var(--app-accent); border-radius: 2px; margin: 0px 20px; box-shadow: rgba(99, 102, 241, 0.4) 0px 0px 6px; }
.pv-add-zone { position: relative; display: flex; justify-content: center; height: 0px; z-index: 8; }
.pv-add-btn { position: absolute; top: -12px; display: flex; align-items: center; justify-content: center; width: 24px; height: 24px; border: 1.5px solid var(--app-border); background: rgb(255, 255, 255); border-radius: 50%; cursor: pointer; color: var(--app-text-dim); transition: 0.15s; opacity: 0; box-shadow: rgba(0, 0, 0, 0.08) 0px 1px 4px; }
.pv-add-zone:hover .pv-add-btn, .pv-add-btn:focus { opacity: 1; }
.pv-add-btn:hover { border-color: var(--app-accent); color: var(--app-accent); transform: scale(1.15); }
.pv-add-backdrop { position: fixed; inset: 0px; z-index: 9; }
.pv-add-menu { position: absolute; top: 16px; left: 50%; transform: translate(-50%); z-index: 10; min-width: 160px; padding: 4px; background: rgb(255, 255, 255); border: 1px solid var(--app-border); border-radius: 10px; box-shadow: rgba(0, 0, 0, 0.12) 0px 8px 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 2px; font-family: Inter, sans-serif; }
.pv-add-menu button { padding: 6px 10px; border: none; background: transparent; font-size: 11px; font-weight: 500; text-align: left; border-radius: 6px; cursor: pointer; color: var(--app-text); transition: background 0.1s; white-space: nowrap; }
.pv-add-menu button:hover { background: var(--app-bg); color: var(--app-accent); }
.sec-nav-top { padding: 0px !important; }
.sec-nav-top a { cursor: pointer; }
.nav-top-inner { display: flex; gap: 4px; justify-content: center; flex-wrap: wrap; max-width: var(--max-width); margin: 0px auto; padding: 0 var(--content-px); align-items: center; }
.nav-top-logo { font-weight: 700; margin-right: 16px; font-size: 0.95em; white-space: nowrap; }
.nav-top-link { padding: 6px 14px; font-size: 0.82em; font-weight: 500; color: inherit; text-decoration: none; border-radius: 6px; transition: 0.2s; position: relative; }
.nav-top-link:hover { opacity: 0.8; }
[data-nav-style="pills"] .nav-top-link { background: rgba(0, 0, 0, 0.04); border-radius: 20px; padding: 5px 14px; }
[data-nav-style="underline"] .nav-top-link { border-radius: 0px; padding: 6px 12px 8px; border-bottom: 2px solid transparent; }
[data-nav-style="underline"] .nav-top-link:hover { border-bottom-color: currentcolor; }
[data-nav-style="minimal"] .nav-top-link { padding: 6px 10px; }
.sec-nav-sidebar { padding: 0px !important; }
.sec-nav-sidebar a { cursor: pointer; }
.sidebar-nav-item { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; }
.sidebar-nav-item span { overflow: hidden; text-overflow: ellipsis; }
[data-sidebar-style="dots"] .sidebar-nav-item { display: flex; align-items: center; gap: 10px; height: 38px; }
[data-sidebar-style="dots"] .sidebar-nav-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; border: 2px solid rgb(255, 255, 255); box-sizing: content-box; transition: 0.2s; }
[data-sidebar-style="clean"] .sidebar-nav-item { padding: 8px 14px; border-radius: 8px; transition: background 0.15s; }
[data-sidebar-style="clean"] .sidebar-nav-item:hover { background: rgba(0, 0, 0, 0.04); }
[data-sidebar-style="clean"] .sidebar-nav-item.active { background: rgba(0, 0, 0, 0.06); }
[data-sidebar-style="bordered"] .sidebar-nav-item { padding: 8px 14px; border-left: 3px solid transparent; transition: 0.15s; }
[data-sidebar-style="bordered"] .sidebar-nav-item.active { border-left-color: var(--primary, #6366f1); }
[data-sidebar-style="minimal"] .sidebar-nav-item { padding: 4px 8px; }
.content-container { max-width: var(--max-width); margin: 0px auto; padding: 0 var(--content-px, 40px); }
.sec { padding-top: var(--sec-pt, var(--section-spacing, 48px)); padding-bottom: var(--sec-pb, var(--section-spacing, 48px)); }
.section-label-tag { font-family: var(--font, system-ui); font-size: var(--label-size, .85rem); font-weight: 600; letter-spacing: var(--label-spacing, .1em); text-transform: uppercase; color: var(--label-color, var(--primary, #6366f1)); margin-bottom: var(--label-title-gap, 10px); }
.section-label-tag + .section-heading { font-size: var(--title-size, var(--heading-size, 1.8rem)); }
.bullet-list { display: flex; flex-direction: column; gap: 14px; margin-top: 16px; }
.bullet-item { display: flex; gap: 12px; align-items: flex-start; }
.bullet-item p { font-size: 0.95em; line-height: 1.65; margin: 0px; }
.bullet-num { flex-shrink: 0; width: 24px; height: 24px; border-radius: 50%; background: var(--surface, #f5f5f5); color: var(--primary, #6366f1); font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; margin-top: 2px; }
.bullet-dot { flex-shrink: 0; width: 6px; height: 6px; border-radius: 50%; background: var(--primary, #6366f1); margin-top: 8px; }
.bullet-dash { flex-shrink: 0; color: var(--primary, #6366f1); font-weight: 700; margin-top: 0px; }
.bullet-none .bullet-item { padding-left: 0px; }
[data-section-divider="border-top"] .sec { border-top: 1px solid var(--border-color, #e2e8f0); }
[data-section-divider="border-top"] .sec-hero, [data-section-divider="border-top"] .sec-authors, [data-section-divider="border-top"] .sec-links, [data-section-divider="border-top"] .sec-tldr { border-top: none; }
[data-section-divider="line"] .sec + .sec { border-top: 1px solid rgba(0, 0, 0, 0.06); }
[data-animation="fade-in"] .sec { animation: 0.8s ease-out 0s 1 normal both running fadeIn; }
[data-animation="slide-up"] .sec { animation: 0.6s ease-out 0s 1 normal both running slideUp; }
@keyframes fadeIn { 
  0% { opacity: 0; }
  100% { opacity: 1; }
}
@keyframes slideUp { 
  0% { opacity: 0; transform: translateY(20px); }
  100% { opacity: 1; transform: none; }
}
.section-heading { font-family: var(--font-heading); font-size: var(--heading-font-size, 1.8rem); font-weight: 700; color: var(--text); margin-bottom: 20px; }
[data-heading="underline-bar"] .section-heading { position: relative; padding-bottom: 16px; margin-bottom: 2rem; }
[data-heading="underline-bar"] .section-heading::after { content: ""; position: absolute; bottom: 0px; left: 0px; width: var(--heading-deco-width, 50px); height: var(--heading-deco-thickness, 4px); background: var(--heading-deco-color, #7155ae); border-radius: 2px; }
[data-heading="border-bottom"] .section-heading { padding-bottom: 1rem; margin-bottom: 2rem; border-bottom: var(--heading-deco-thickness, 2px) solid var(--border-color, #e2e8f0); width: fit-content; }
[data-heading="left-accent"] .section-heading { padding-left: 16px; border-left: var(--heading-deco-thickness, 4px) solid var(--heading-deco-color); }
[data-heading="centered-underline"] .section-heading { text-align: center; position: relative; padding-bottom: 16px; margin-bottom: 2rem; }
[data-heading="centered-underline"] .section-heading::after { content: ""; position: absolute; bottom: 0px; left: 50%; transform: translate(-50%); width: var(--heading-deco-width, 50px); height: var(--heading-deco-thickness, 4px); background: var(--heading-deco-color); border-radius: 2px; }
[data-heading="double-line"] .section-heading { text-align: center; padding: 14px 0px; margin-bottom: 2rem; border-top: var(--heading-deco-thickness, 2px) solid var(--heading-deco-color); border-bottom: var(--heading-deco-thickness, 2px) solid var(--heading-deco-color); }
.sec-hero { text-align: center; padding-top: var(--sec-pt, 64px); padding-bottom: var(--sec-pb, 40px); padding-left: var(--content-px, 40px); padding-right: var(--content-px, 40px); }
[data-hero="colored"] .sec-hero { background: var(--hero-bg, #f5f5f5); }
[data-hero="gradient"] .sec-hero { background: linear-gradient(to bottom,var(--hero-grad-from, #f9f9ff),var(--hero-grad-to, #fff)); }
[data-hero="dark"] .sec-hero { background: var(--hero-bg, #1a1a2e); }
[data-hero="dark"] .sec-hero .hero-title { color: rgb(255, 255, 255); }
[data-hero="dark"] .sec-hero .hero-subtitle { color: rgba(255, 255, 255, 0.7); }
[data-hero="dark"] .sec-hero .venue-badge { color: rgba(255, 255, 255, 0.6); }
[data-hero="split"] .sec-hero { background: linear-gradient(135deg,var(--hero-grad-from, #f9f9ff) 50%,var(--hero-grad-to, #fff) 50%); }
[data-hero="pattern"] .sec-hero { background-position-x: ; background-position-y: ; background-repeat: ; background-attachment: ; background-origin: ; background-clip: ; background-color: ; background-image: radial-gradient(var(--border-color, #ddd) 1px,transparent 1px); background-size: 20px 20px; }
.hero-venue { margin-bottom: 16px; }
.venue-badge { display: inline-block; font-size: 13px; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; color: var(--text-secondary); padding: 5px 16px; border-radius: 100px; }
.hero-title { font-family: var(--font-heading); font-size: var(--hero-title-size, 3rem); font-weight: 700; line-height: 1.2; color: var(--text); margin-bottom: 16px; letter-spacing: -0.02em; }
.hero-title-line { display: block; }
.hero-title-line-highlight, .hero-title-accent { color: var(--hero-highlight, var(--accent, var(--primary))); }
.hero-title-sep { color: var(--text-secondary); font-weight: 400; }
.hero-subtitle { font-size: var(--hero-subtitle-size, 1.25rem); color: var(--text-secondary); max-width: 680px; margin: 0px auto; line-height: 1.6; }
.hero-media { margin-top: 32px; max-width: 800px; margin-left: auto; margin-right: auto; }
.sec-teaser { padding-top: var(--sec-pt, 0px) !important; padding-bottom: var(--sec-pb, calc(var(--section-spacing, 48px) * .5)) !important; }
.sec-teaser .hero-teaser { padding-top: 0px; max-width: var(--teaser-max-w, 800px); margin: 0px auto; }
.sec-teaser .media-placeholder { min-height: 200px; border-radius: var(--teaser-radius, 10px); }
.sec-teaser .media-image img { width: 100%; border-radius: var(--teaser-radius, 10px); }
.sec-teaser .media-figure { border-radius: var(--teaser-radius, 10px); overflow: hidden; }
.sec-teaser[data-media="card"] .media-figure, .sec-teaser[data-media="card"] .media-image { background: var(--surface, #f5f5f5); padding: var(--teaser-media-padding, var(--media-box-padding, .5rem)); border-radius: var(--teaser-radius, var(--media-radius, 10px)); box-shadow: var(--card-shadow, 0 2px 8px rgba(0,0,0,.08)); }
.sec-teaser[data-media="bordered"] .media-figure, .sec-teaser[data-media="bordered"] .media-image { border: 1px solid var(--border-color, #e2e8f0); padding: var(--teaser-media-padding, var(--media-box-padding, .5rem)); border-radius: var(--teaser-radius, var(--media-radius, 10px)); }
.sec-teaser[data-media="shadow"] .media-figure, .sec-teaser[data-media="shadow"] .media-image { box-shadow: rgba(0, 0, 0, 0.12) 0px 4px 20px; border-radius: var(--teaser-radius, var(--media-radius, 10px)); overflow: hidden; }
.sec-teaser[data-media="rounded"] .media-figure, .sec-teaser[data-media="rounded"] .media-image { border-radius: 20px; overflow: hidden; }
.sec-teaser[data-media="rounded"] .media-image img { border-radius: 20px; }
.sec-teaser .media-figure img, .sec-teaser .media-figure video { border: var(--teaser-border-width, 0) solid var(--teaser-border-color, transparent); }
.sec-teaser[data-caption="plain"] .media-caption { font-style: normal; }
.sec-teaser[data-caption="small-caps"] .media-caption { font-variant: small-caps; font-style: normal; }
.sec-teaser[data-caption="numbered"] .media-caption::before { content: none; }
.sec-teaser[data-caption="accent-left"] .media-caption { border-left: 3px solid var(--primary, #6366f1); padding-left: 8px; font-style: normal; }
.sec-teaser[data-caption="hidden"] .media-caption { display: none; }
.media-figure img, .media-figure video { border: var(--media-border-width, 0) solid var(--media-border-color, transparent); }
.sec-authors { text-align: center; padding-top: var(--sec-pt, 12px); padding-bottom: var(--sec-pb, 24px); padding-left: var(--content-px, 40px); padding-right: var(--content-px, 40px); }
.authors-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--author-row-gap, 16px) var(--author-gap, 24px); }
.author-card { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.sec-authors { font-size: var(--author-font-size, 1em); }
.author-name { font-size: 1em; font-weight: 600; color: var(--author-link, #209cee); text-decoration: none; transition: opacity 0.15s; line-height: var(--author-line-height, 1.5); }
.author-name:hover { opacity: 0.7; }
.author-name.no-link { color: var(--text); cursor: default; }
.author-name.no-link:hover { opacity: 1; }
.author-name sup { font-size: 0.65em; margin-left: 1px; }
.author-affil { font-size: 0.85em; color: var(--text-secondary); }
.affil-legend { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px 18px; margin-top: var(--author-affil-gap, 8px); }
.affil-legend-item { font-size: 0.85em; color: var(--text-secondary); }
.affil-legend-item sup { font-size: 0.7em; margin-right: 2px; font-weight: 600; }
.equal-note { font-size: 0.8em; color: var(--text-secondary); margin-top: 8px; font-style: italic; }
.sec-links { padding-top: var(--sec-pt, 8px); padding-bottom: var(--sec-pb, 32px); padding-left: var(--content-px, 40px); padding-right: var(--content-px, 40px); }
.links-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; }
.link-btn { display: inline-flex; align-items: center; gap: 7px; padding: 9px 20px; background: var(--btn-bg); color: var(--btn-text); border: 1px solid var(--btn-border, transparent); border-radius: 8px; font-size: 0.9em; font-weight: 500; text-decoration: none; transition: 0.3s; }
.link-btn svg { stroke: currentcolor; transition: stroke 0.15s; }
[data-btn="pill"] .link-btn { border-radius: 9999px; background: var(--btn-bg); color: var(--btn-text); border: 1px solid var(--btn-border, transparent); }
[data-btn="rounded"] .link-btn { border-radius: var(--btn-radius, 8px); background: var(--btn-bg); color: var(--btn-text); border: 1px solid var(--btn-border, transparent); }
[data-btn="square"] .link-btn { border-radius: 2px; background: var(--btn-bg); color: var(--btn-text); border: 1px solid var(--btn-border, transparent); }
[data-btn="dark-pill"] .link-btn { background: var(--secondary, #1e293b); color: rgb(255, 255, 255); border-radius: 9999px; border: 1px solid transparent; }
[data-btn="outline"] .link-btn { background: transparent; color: var(--primary, #6366f1); border: 2px solid var(--primary, #6366f1); border-radius: var(--btn-radius, 8px); }
[data-btn="ghost"] .link-btn { background: transparent; color: var(--primary, #6366f1); border: none; padding: 9px 16px; border-radius: var(--btn-radius, 8px); }
[data-btn="ghost"] .link-btn:hover { text-decoration: underline; text-underline-offset: 4px; }
[data-btn-hover="color-swap"] .link-btn:hover { background: var(--text, #1e293b); color: rgb(255, 255, 255); border-color: var(--text, #1e293b); }
[data-btn-hover="lift"] .link-btn:hover { transform: translateY(-5px); background: var(--surface, #f7fafc); }
[data-btn-hover="darken"] .link-btn:hover { filter: brightness(0.85); }
.sec-tldr { padding-top: var(--sec-pt, 16px); padding-bottom: var(--sec-pb, 16px); }
[data-tldr="border-left"] .tldr-box { background: var(--tldr-bg); border-left: 4px solid var(--tldr-border); border-radius: 0 var(--radius, 8px) var(--radius, 8px) 0; padding: 20px 24px; }
[data-tldr="border-left"] .tldr-box > strong { color: var(--tldr-label); font-size: 0.85em; text-transform: uppercase; letter-spacing: 0.05em; display: block; margin-bottom: 6px; }
[data-tldr="filled"] .tldr-box { background: var(--tldr-bg); border-radius: var(--radius, 10px); padding: 1.5rem; border: none; }
[data-tldr="filled"] .tldr-box > strong { color: var(--tldr-label); font-size: 0.85em; text-transform: uppercase; letter-spacing: 0.05em; display: block; margin-bottom: 6px; }
[data-tldr="full-border"] .tldr-box { background: var(--tldr-bg); border: 2px solid var(--tldr-border); border-radius: var(--radius, 12px); padding: 1.5rem; }
[data-tldr="full-border"] .tldr-box > strong { color: var(--tldr-label); font-size: 0.85em; text-transform: uppercase; letter-spacing: 0.05em; display: block; margin-bottom: 6px; }
[data-tldr="badge-label"] .tldr-box { background: var(--tldr-bg); border: 2px solid var(--tldr-border); border-radius: 12px; padding: 2rem; }
[data-tldr="badge-label"] .tldr-box > strong { display: inline-block; background: var(--tldr-label); color: rgb(255, 255, 255); padding: 0.25rem 1rem; border-radius: 0.5rem; font-size: 0.95em; font-weight: 700; margin-bottom: 12px; }
[data-tldr="badge-label"] .tldr-box p { font-size: 1.1em; font-weight: 500; line-height: 1.625; }
.tldr-box { font-size: 1em; }
.tldr-box p, .tldr-text p { font-size: 1em; line-height: var(--body-line-height, 1.7); color: var(--text); }
.tldr-text strong { color: var(--text); font-weight: 700; }
.tldr-text em { font-style: italic; }
.callout-box { display: flex; gap: 12px; align-items: flex-start; padding: 1.25rem 1.5rem; font-size: 1em; }
.callout-icon { font-size: 1.25em; flex-shrink: 0; line-height: 1.6; color: var(--callout-icon, var(--accent)); }
.callout-text { flex: 1 1 0%; }
.callout-title { display: block; font-size: 1.05em; font-weight: 700; color: var(--callout-border, var(--accent)); margin-bottom: 4px; }
.callout-text p { font-size: 1em; line-height: var(--body-line-height, 1.7); color: var(--text); }
.callout-text strong { color: var(--text); font-weight: 700; }
[data-callout="border-left"] .callout-box { background: var(--callout-bg); border-left: 4px solid var(--callout-border); border-radius: 0 var(--radius, 10px) var(--radius, 10px) 0; }
[data-callout="filled"] .callout-box { background: var(--callout-bg); border-radius: var(--radius, 10px); }
[data-callout="full-border"] .callout-box { background: var(--callout-bg); border: 2px solid var(--callout-border); border-radius: var(--radius, 10px); }
[data-callout="banner"] .callout-box { background: var(--callout-bg); border-left: 4px solid var(--callout-border); border-right: 4px solid var(--callout-border); border-radius: 0px; }
[data-callout="minimal"] .callout-box { border-left: 2px solid var(--callout-border); padding: 0.75rem 1.25rem; }
.abstract-text, .text-content { line-height: var(--body-line-height, 1.8); font-size: 1em; color: var(--text); }
.media-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; min-height: 200px; background: var(--surface); border: 2px dashed var(--border-color, #dde0e6); border-radius: var(--media-radius, 10px); padding: var(--media-padding, 0); color: var(--text-secondary); font-size: 0.9em; cursor: pointer; transition: 0.15s; }
.media-placeholder:hover { border-color: var(--primary, #6366f1); background: color-mix(in srgb,var(--surface, #f8f9fa) 90%,var(--primary, #6366f1)); }
.media-video video, .media-video .video-embed-wrapper { width: 100%; overflow: hidden; border-radius: var(--media-radius, 10px); }
.video-embed-wrapper { position: relative; padding-bottom: 56.25%; height: 0px; }
.video-embed-wrapper iframe { position: absolute; top: 0px; left: 0px; width: 100%; height: 100%; border: none; border-radius: var(--media-radius, 10px); }
.media-video video { display: block; border-radius: var(--media-radius, 10px); }
.media-image img { width: 100%; display: block; border-radius: var(--media-radius, 10px); }
.media-figure { margin: 0px; box-sizing: border-box; }
.media-figure img, .media-figure video { box-sizing: border-box; }
.media-frame { overflow: hidden; box-sizing: border-box; border-radius: var(--media-radius, 10px); }
.media-frame img { width: 100%; height: 100%; display: block; border-radius: 0px; }
.media-caption { font-size: 0.85em; color: var(--text-secondary); text-align: center; margin-top: 10px; line-height: 1.5; }
.caption-label { font-weight: 700; color: var(--text); }
[data-caption="italic"] .media-caption { font-style: italic; }
[data-caption="plain"] .media-caption { font-style: normal; }
[data-caption="small-caps"] .media-caption { font-variant: small-caps; font-style: normal; }
[data-caption="numbered"] .caption-label { font-weight: 700; }
[data-caption="numbered"] .media-caption { font-style: normal; text-align: left; }
[data-caption="accent-left"] .media-caption { text-align: left; font-style: normal; padding-left: 12px; border-left: 3px solid var(--accent, var(--primary)); }
[data-caption="hidden"] .media-caption { display: none; }
[data-media="plain"] .media-figure { margin: 0px; }
[data-media="plain"] .media-image img, [data-media="plain"] .media-video video, [data-media="plain"] .media-video iframe { border-radius: 0px; width: 100%; }
[data-media="plain"] .media-placeholder { border-radius: 0px; border-style: dashed; }
[data-media="card"] .media-video, [data-media="card"] .media-image, [data-media="card"] .media-placeholder { background: rgb(255, 255, 255); border-radius: var(--content-box-radius, 12px); padding: var(--media-padding, 1rem); box-shadow: var(--card-shadow, 0 5px 15px rgba(0,0,0,.1)); transition: box-shadow 0.3s; border: none; }
[data-media="card"] .media-video:hover, [data-media="card"] .media-image:hover, [data-media="card"] .media-placeholder:hover { box-shadow: var(--card-hover-shadow, 0 10px 30px rgba(0,0,0,.2)); }
[data-media="card"] .media-image img { cursor: zoom-in; transition: transform 0.2s; }
[data-media="card"] .media-image img:hover { transform: scale(1.02); }
[data-media="bordered"] .media-video, [data-media="bordered"] .media-image, [data-media="bordered"] .media-placeholder { border: 1px solid var(--border-color); border-radius: var(--content-box-radius, 12px); padding: var(--media-padding, .5rem); }
.image-grid { display: grid; gap: 16px; }
.image-grid .media-image img { aspect-ratio: 4 / 3; object-fit: cover; }
.image-grid .media-frame { aspect-ratio: 4 / 3; }
.image-grid .media-frame img { aspect-ratio: unset; }
.grid-cell { position: relative; transition: outline 0.1s, opacity 0.15s; border-radius: 6px; }
.grid-cell.dragging { opacity: 0.4; }
.grid-cell.drop-hover { outline: rgb(34, 197, 94) dashed 3px; outline-offset: -3px; background: rgba(34, 197, 94, 0.08); border-radius: 6px; }
[data-grid-fit="contain"] .image-grid .media-image img { object-fit: contain; background: var(--surface, #f5f5f5); }
[data-grid-fit="contain"] .image-grid .media-frame img { background: transparent; }
[data-grid-fit="full"] .image-grid .media-image img { aspect-ratio: unset; object-fit: unset; width: 100%; height: auto; }
[data-grid-fit="full"] .image-grid .media-frame { aspect-ratio: unset; }
.image-grid .media-placeholder { min-height: 140px; }
.grid-gap-handle { position: absolute; z-index: 10; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.15s; }
.image-grid-wrapper:hover .grid-gap-handle { opacity: 1; }
.grid-gap-col { top: 0px; left: 50%; transform: translate(-50%); width: 24px; height: 100%; cursor: col-resize; }
.grid-gap-row { left: 0px; top: 50%; transform: translateY(-50%); width: 100%; height: 24px; cursor: row-resize; }
.grid-gap-handle:hover, .grid-gap-handle:active { opacity: 1; }
.grid-gap-handle:active .grid-gap-label { background: var(--primary, #6366f1); color: rgb(255, 255, 255); }
.grid-gap-label { font-size: 9px; font-weight: 700; padding: 2px 6px; border-radius: 10px; background: rgba(99, 102, 241, 0.12); color: var(--primary, #6366f1); pointer-events: none; white-space: nowrap; user-select: none; }
.comparison-grid { display: grid; gap: 18px; }
.comparison-item { min-width: 0px; }
.comparison-container { position: relative; width: 100%; overflow: hidden; border-radius: var(--media-radius, 10px); user-select: none; touch-action: none; cursor: ew-resize; }
.comparison-img-wrapper { width: 100%; }
.comparison-img-wrapper.comparison-overlay { position: absolute; top: 0px; left: 0px; height: 100%; }
.comparison-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.comparison-slider-line { position: absolute; top: 0px; bottom: 0px; width: 3px; background: rgb(255, 255, 255); transform: translate(-50%); cursor: ew-resize; z-index: 2; box-shadow: rgba(0, 0, 0, 0.3) 0px 0px 6px; }
.comparison-slider-handle { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 30px; height: 30px; background: rgb(255, 255, 255); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 10px; color: var(--comp-slider-color, #333); }
.comparison-label { position: absolute; bottom: 12px; padding: 4px 12px; border-radius: 6px; font-size: 12px; font-weight: 600; z-index: 3; }
.comparison-label-a { left: 12px; background: var(--comp-label-a-bg); color: var(--comp-label-a-color); }
.comparison-label-b { right: 12px; background: var(--comp-label-b-bg); color: var(--comp-label-b-color); }
[data-comp-label="branded"] .comparison-label-a { border: 2px solid var(--comp-label-a-color); font-weight: 700; }
[data-comp-label="branded"] .comparison-label-b { border: 1px solid var(--text-secondary, #64748b); }
[data-comp-label="glass"] .comparison-label { backdrop-filter: blur(8px); }
.carousel-viewport { overflow: hidden; border-radius: var(--media-radius, 10px); }
.carousel-controls { display: flex; align-items: center; justify-content: center; gap: 16px; margin-top: 12px; }
.carousel-controls button { display: flex; align-items: center; justify-content: center; width: 2.5rem; height: 2.5rem; border: 1px solid var(--border-color); background: var(--surface, #fff); border-radius: 50%; cursor: pointer; color: var(--primary); transition: 0.15s; }
.carousel-controls button:hover:not(:disabled) { background: var(--primary); color: rgb(255, 255, 255); border-color: var(--primary); }
.carousel-controls button:disabled { opacity: 0.3; cursor: default; }
.carousel-indicator { font-size: 13px; font-weight: 500; color: var(--text-secondary); min-width: 48px; text-align: center; }
.table-wrapper { overflow-x: auto; }
.table-stack, .chart-stack { display: flex; flex-direction: column; gap: 14px; }
.switcher-content-area { position: relative; overflow: hidden; }
.switcher-panel { animation-duration: 0.3s; animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1); animation-fill-mode: both; }
.switcher-slide-right { animation-name: switcherSlideRight; }
.switcher-slide-left { animation-name: switcherSlideLeft; }
@keyframes switcherSlideRight { 
  0% { opacity: 0; transform: translate(40px); }
  100% { opacity: 1; transform: translate(0px); }
}
@keyframes switcherSlideLeft { 
  0% { opacity: 0; transform: translate(-40px); }
  100% { opacity: 1; transform: translate(0px); }
}
.table-switcher { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.table-switcher-tabs { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; flex: 1 1 0%; }
.table-switcher-tab, .table-switcher-nav { border: 1px solid var(--table-border, var(--border-color, #e2e8f0)); background: var(--surface, #fff); color: var(--text, #1e293b); border-radius: 999px; font: inherit; cursor: pointer; }
.table-switcher-tab { padding: 6px 12px; font-size: 0.88em; transition: background 0.2s, color 0.2s, border-color 0.2s, font-weight 0.15s; }
.table-switcher-tab.active { background: var(--table-highlight-bg, var(--surface, #fff)); color: var(--table-highlight-color, var(--primary)); font-weight: 700; border-color: var(--table-highlight-color, var(--primary)); }
.table-switcher-tab:not(.active):hover { background: color-mix(in srgb,var(--primary, #6366f1) 6%,transparent); }
.table-switcher-nav { width: 34px; height: 34px; font-size: 20px; line-height: 1; }
[data-content-box="card"] .table-wrapper { background: rgb(255, 255, 255); border-radius: var(--content-box-radius); padding: var(--content-box-padding); box-shadow: var(--card-shadow); transition: box-shadow 0.3s; }
[data-content-box="card"] .table-wrapper:hover { box-shadow: var(--card-hover-shadow); }
.results-table { width: 100%; border-collapse: collapse; font-size: 0.9em; }
.results-table th { text-align: center; padding: 10px 16px; font-weight: 600; background: var(--table-header-bg); color: var(--table-header-color); border-bottom: 2px solid var(--table-border, #e2e8f0); }
.results-table td { text-align: center; padding: 10px 16px; border-bottom: 1px solid var(--table-border); }
.table-cell-rich p { margin: 0px; }
.table-cell-rich strong { font-weight: 700; }
.table-cell-rich u { text-decoration-thickness: 2px; text-underline-offset: 0.14em; }
.results-table .highlight-row { background: var(--table-highlight-bg); }
.results-table .highlight-row td { color: var(--table-highlight-color); }
.results-table tbody tr { transition: background 0.15s; }
.results-table tbody tr:hover { background: rgba(0, 0, 0, 0.016); }
.results-table.table-align-left th, .results-table.table-align-left td { text-align: left; }
.results-table.table-align-center th, .results-table.table-align-center td { text-align: center; }
.results-table.table-align-right th, .results-table.table-align-right td { text-align: right; }
.results-table.table-density-compact th, .results-table.table-density-compact td { padding: 7px 10px; }
.results-table.table-density-relaxed th, .results-table.table-density-relaxed td { padding: 14px 20px; }
.results-table.table-style-plain th { background: transparent; color: var(--text, #1e293b); border-bottom: 1px solid var(--table-border, #e2e8f0); }
.results-table.table-style-plain td, .results-table.table-style-plain th { border-left: none; border-right: none; }
.results-table.table-style-striped tbody tr:nth-child(2n):not(.highlight-row) { background: color-mix(in srgb,var(--surface, #fff) 70%,var(--bg, #f8fafc)); }
.results-table.table-style-minimal { border-collapse: separate; border-spacing: 0px; }
.results-table.table-style-minimal th { background: transparent; color: var(--text-secondary, #64748b); border-bottom: 1px solid var(--table-border, #e2e8f0); }
.results-table.table-style-minimal td { border-bottom: none; }
.results-table.table-style-boxed { border: 1px solid var(--table-border, #e2e8f0); border-radius: 14px; overflow: hidden; }
.results-table.table-style-boxed th, .results-table.table-style-boxed td { border-right: 1px solid color-mix(in srgb,var(--table-border, #e2e8f0) 72%,white); }
.results-table.table-style-boxed th:last-child, .results-table.table-style-boxed td:last-child { border-right: none; }
.charts-grid { display: grid; gap: 18px; align-items: start; }
.chart-wrapper { overflow-x: auto; background: var(--chart-surface, var(--surface, #f8fafc)); border: 1px solid color-mix(in srgb,var(--border-color, #e2e8f0) 88%,white); border-radius: calc(var(--radius, 12px) + 4px); padding: 18px 18px 14px; box-shadow: rgba(15, 23, 42, 0.04) 0px 8px 20px; }
.chart-wrapper.legend-right { display: grid; grid-template-columns: minmax(0px, 1fr) auto; gap: 18px; align-items: start; }
.chart-wrapper.legend-left { display: grid; grid-template-columns: auto minmax(0px, 1fr); gap: 18px; align-items: start; }
.chart-wrapper svg { display: block; width: 100%; height: auto; }
.chart-legend { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 14px; }
.chart-legend-bottom { margin-top: 14px; margin-bottom: 0px; }
.chart-legend-right, .chart-legend-left { margin: 0px; flex-direction: column; min-width: 140px; align-self: center; }
.chart-legend-item { display: inline-flex; align-items: center; gap: 0.7em; color: var(--text, #1e293b); }
.chart-legend-minimal .chart-legend-item { padding: 0px; }
.chart-legend-pill .chart-legend-item { padding: 0.45em 0.8em; border-radius: 999px; background: color-mix(in srgb,var(--surface, #fff) 72%,var(--bg, #f8fafc)); border: 1px solid color-mix(in srgb,var(--border-color, #e2e8f0) 70%,white); }
.chart-legend-boxed .chart-legend-item { padding: 0.5em 0.8em; border-radius: 12px; background: var(--bg, #fff); border: 1px solid var(--border-color, #e2e8f0); box-shadow: rgba(255, 255, 255, 0.5) 0px 1px inset; }
.chart-legend-label { line-height: 1.2; font-weight: 600; }
.chart-legend-marker { display: inline-block; background: var(--legend-color); flex-shrink: 0; }
.chart-legend-marker-dot { width: 0.8em; height: 0.8em; border-radius: 999px; }
.chart-legend-marker-square { width: 0.85em; height: 0.85em; border-radius: 0.2em; }
.chart-legend-marker-line { width: 1.5em; height: 0.22em; border-radius: 999px; }
.chart-legend-marker-bar { width: 0.8em; height: 1em; border-radius: 0.2em; }
.chart-plot-bg { fill: color-mix(in srgb,var(--bg, #fff) 82%,var(--surface, #f8fafc)); stroke: color-mix(in srgb,var(--border-color, #e2e8f0) 92%,white); stroke-width: 1; }
.chart-axis-label { font-size: var(--chart-legend-size, 12px); fill: var(--text-secondary, #64748b); font-family: var(--font, inherit); font-weight: 600; }
.chart-tick-label { font-size: var(--chart-tick-size, 11px); fill: var(--chart-axis, var(--text-secondary, #64748b)); font-family: var(--font, inherit); }
.chart-value-label { font-size: var(--chart-tick-size, 10px); fill: var(--text, #1e293b); font-weight: 700; font-family: var(--font, inherit); }
.chart-gridline { stroke: var(--chart-grid, var(--border-color, #e2e8f0)); stroke-width: 0.8; stroke-dasharray: 3, 6; }
.chart-axis-line { stroke: color-mix(in srgb,var(--text-secondary, #64748b) 24%,transparent); stroke-width: 1; }
.chart-bar { transition: opacity 0.2s, transform 0.2s; transform-box: fill-box; transform-origin: center bottom; }
.chart-bar:hover { opacity: 0.9 !important; transform: translateY(-2px); }
.chart-line { fill: none; }
.chart-point { transition: r 0.15s, opacity 0.15s; }
.chart-point:hover { r: 6 !important; opacity: 1 !important; }
.radar-chart { overflow: visible; }
.radar-ring-label { opacity: 0.55; font-size: 9px; }
.radar-cat-label { font-size: 12px; }
.radar-point { transition: r 0.15s; cursor: default; }
.radar-point:hover { r: 7 !important; }
.radar-dataset polygon { transition: fill-opacity 0.2s, stroke-width 0.2s; }
.radar-dataset:hover polygon { fill-opacity: 0.25 !important; stroke-width: 3 !important; }
[data-content-box="plain"] .chart-wrapper { box-shadow: rgba(15, 23, 42, 0.03) 0px 6px 18px; }
@supports not (color: color-mix(in srgb,white,black)) {
  .chart-wrapper { background: var(--surface, #f8fafc); border: 1px solid var(--border-color, #e2e8f0); }
  .chart-plot-bg { fill: var(--bg, #fff); stroke: var(--border-color, #e2e8f0); }
  .chart-axis-line { stroke: var(--border-color, #e2e8f0); }
  .results-table.table-style-striped tbody tr:nth-child(2n):not(.highlight-row) { background: var(--surface, #fff); }
  .chart-legend-pill .chart-legend-item, .chart-legend-boxed .chart-legend-item { border: 1px solid var(--border-color, #e2e8f0); }
}
.two-col-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.two-col-grid .col { display: flex; flex-direction: column; gap: 12px; }
.bibtex-wrapper { position: relative; }
[data-bibtex="plain"] .bibtex-code { background: var(--bib-bg); padding: 20px 24px; border: none; border-radius: var(--radius, 8px); }
[data-bibtex="filled"] .bibtex-code { background: var(--bib-bg); padding: 20px 24px; border: none; border-radius: 6px; }
[data-bibtex="border-left"] .bibtex-code { background: var(--bib-bg); border-left: 4px solid var(--bib-border, #7155ae); border-radius: 5px; padding: 1.5rem; }
[data-bibtex="border-left"] .bibtex-wrapper { background: var(--surface); border-radius: 10px; padding: 2rem; }
[data-bibtex="card"] .bibtex-wrapper { background: var(--bib-bg); border: 1px solid var(--bib-border, #e2e8f0); border-radius: 0.25rem; padding: 1rem; }
[data-bibtex="card"] .bibtex-code { background: transparent; border: none; padding: 0px; }
.bibtex-code { font-family: var(--font-mono); font-size: 0.8em; line-height: 1.6; overflow-x: auto; white-space: pre-wrap; word-break: break-word; color: var(--text-secondary); }
.copy-btn { position: absolute; top: 10px; right: 10px; display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; border: 1px solid var(--border-color); background: rgb(255, 255, 255); border-radius: 6px; cursor: pointer; color: var(--text-secondary); transition: 0.15s; opacity: 0; }
.bibtex-wrapper:hover .copy-btn { opacity: 1; }
.copy-btn:hover { background: var(--surface); color: var(--primary); border-color: var(--primary); }
.sec-acknowledgment .acknowledgment-content { font-size: 0.9em; color: var(--text-secondary, #64748b); line-height: 1.7; }
.sec-divider { padding-top: var(--sec-pt, 16px); padding-bottom: var(--sec-pb, 16px); min-height: 20px; }
.sec-divider .content-container { min-height: 10px; display: flex; align-items: center; }
.sec-divider hr { border-right: none; border-bottom: none; border-left: none; border-image: initial; border-top: 1px solid var(--border-color); width: 100%; margin: 0px; }
.divider-gradient { height: 2px; background: linear-gradient(90deg,transparent,var(--primary),transparent); border-radius: 2px; }
.divider-dots { text-align: center; font-size: 18px; letter-spacing: 12px; color: var(--border-color, #cbd5e1); line-height: 1; }
.divider-dots::after { content: "···"; }
[data-animation="scale-in"] .sec { animation: 0.6s ease-out 0s 1 normal both running scaleIn; }
[data-animation="blur-in"] .sec { animation: 0.8s ease-out 0s 1 normal both running blurIn; }
[data-animation="slide-left"] .sec { animation: 0.6s ease-out 0s 1 normal both running slideLeft; }
@keyframes scaleIn { 
  0% { opacity: 0; transform: scale(0.95); }
  100% { opacity: 1; transform: none; }
}
@keyframes blurIn { 
  0% { opacity: 0; filter: blur(8px); }
  100% { opacity: 1; filter: none; }
}
@keyframes slideLeft { 
  0% { opacity: 0; transform: translate(-20px); }
  100% { opacity: 1; transform: none; }
}
[data-content-box="filled"] .table-wrapper { background: var(--surface); border-radius: var(--content-box-radius); padding: var(--content-box-padding); }
[data-content-box="inset"] .table-wrapper { background: var(--surface); border-radius: var(--content-box-radius); padding: var(--content-box-padding); box-shadow: rgba(0, 0, 0, 0.06) 0px 2px 8px inset; }
[data-content-box="glass"] .table-wrapper { background: rgba(255, 255, 255, 0.6); backdrop-filter: blur(12px); border: 1px solid rgba(255, 255, 255, 0.3); border-radius: var(--content-box-radius); padding: var(--content-box-padding); }
[data-tldr="callout"] .tldr-box { background: var(--tldr-bg); border-left: 4px solid var(--tldr-border); border-radius: 0 var(--radius, 8px) var(--radius, 8px) 0; padding: 20px 24px 20px 48px; position: relative; }
[data-tldr="callout"] .tldr-box::before { content: "💡"; position: absolute; left: 16px; top: 18px; font-size: 18px; }
[data-tldr="callout"] .tldr-box > strong { color: var(--tldr-label); font-size: 0.85em; text-transform: uppercase; display: block; margin-bottom: 6px; }
[data-tldr="minimal"] .tldr-box { border-left: 2px solid var(--tldr-border); padding: 12px 20px; }
[data-tldr="minimal"] .tldr-box > strong { color: var(--tldr-label); font-size: 0.8em; font-weight: 700; margin-right: 6px; display: inline; }
[data-btn-hover="glow"] .link-btn:hover { box-shadow: rgba(99, 102, 241, 0.4) 0px 0px 20px; }
[data-btn-hover="fill"] .link-btn:hover { background: var(--primary, #6366f1); color: rgb(255, 255, 255); border-color: var(--primary, #6366f1); }
[data-btn-hover="underline"] .link-btn:hover { text-decoration: underline; text-underline-offset: 4px; }
[data-bibtex="terminal"] .bibtex-wrapper { background: transparent; }
[data-bibtex="terminal"] .bibtex-code { background: rgb(30, 30, 46); color: rgb(166, 227, 161); padding: 20px 24px; border-radius: 6px; }
[data-bibtex="minimal"] .bibtex-code { background: transparent; border-right: none; border-left: none; border-image: initial; padding: 16px 0px; border-top: 1px solid var(--border-color); border-bottom: 1px solid var(--border-color); }
[data-media="shadow"] .media-video, [data-media="shadow"] .media-image, [data-media="shadow"] .media-placeholder { box-shadow: var(--card-shadow, 0 4px 12px rgba(0,0,0,.1)); border-radius: var(--media-radius, 10px); overflow: hidden; transition: box-shadow 0.3s; border: none; }
[data-media="shadow"] .media-video:hover, [data-media="shadow"] .media-image:hover, [data-media="shadow"] .media-placeholder:hover { box-shadow: var(--card-hover-shadow); }
[data-media="rounded"] .media-video, [data-media="rounded"] .media-image, [data-media="rounded"] .media-placeholder { border-radius: 20px; overflow: hidden; }
[data-media="rounded"] .media-video video, [data-media="rounded"] .media-image img { border-radius: 20px; }
[data-media="filmstrip"] .media-video, [data-media="filmstrip"] .media-image, [data-media="filmstrip"] .media-placeholder { border: 3px solid rgb(51, 51, 51); border-radius: 4px; padding: 8px 16px; background: rgb(51, 51, 51); }
[data-media="filmstrip"] .media-placeholder { color: rgb(204, 204, 204); border-style: solid; }
[data-media="filmstrip"] .media-image img, [data-media="filmstrip"] .media-video video { border-radius: 2px; }
[data-comp-label="outline"] .comparison-label { background: transparent; border: 2px solid currentcolor; }
[data-comp-label="pill"] .comparison-label { border-radius: 20px; padding: 4px 16px; }
[data-comp-label="minimal"] .comparison-label { background: transparent; font-size: 11px; opacity: 0.8; padding: 2px 8px; }
[data-section-divider="gradient"] .sec + .sec { position: relative; }
[data-section-divider="gradient"] .sec + .sec::before { content: ""; display: block; height: 2px; margin: 0px 10%; background: linear-gradient(90deg,transparent,var(--primary, #6366f1),transparent); border-radius: 2px; }
[data-section-divider="gradient"] .sec-hero + .sec::before, [data-section-divider="gradient"] .sec-authors + .sec::before { display: none; }
[data-section-divider="dots"] .sec + .sec { position: relative; }
[data-section-divider="dots"] .sec + .sec::before { content: "· · ·"; display: block; text-align: center; color: var(--border-color, #ccc); font-size: 20px; letter-spacing: 6px; padding: 4px 0px; }
[data-section-divider="dots"] .sec-hero + .sec::before, [data-section-divider="dots"] .sec-authors + .sec::before { display: none; }
[data-section-divider="thick"] .sec + .sec { border-top: 3px solid var(--border-color, #e2e8f0); }
[data-section-divider="thick"] .sec-hero, [data-section-divider="thick"] .sec-authors { border-top: none; }
::-webkit-scrollbar { width: 7px; height: 7px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgb(196, 199, 206); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: rgb(161, 164, 171); }
.sidebar-content::-webkit-scrollbar-thumb { background: rgb(221, 221, 221); }
.topbar-sep { width: 1px; height: 20px; background: var(--app-border); flex-shrink: 0; }
.topbar-group { display: flex; gap: 0px; }
.topbar-group-gh { background: rgb(246, 248, 250); border: 1px solid rgb(208, 215, 222); border-radius: 8px; overflow: hidden; }
.topbar-group-gh .topbar-btn-gh { border: none; border-radius: 0px; background: transparent; font-weight: 600; font-size: 12px; padding: 6px 12px; gap: 5px; color: rgb(36, 41, 47); }
.topbar-group-gh .topbar-btn-gh:hover { background: rgb(235, 238, 241); }
.topbar-group-gh .topbar-btn-save { border-left: 1px solid rgb(208, 215, 222); background: rgb(45, 164, 78); color: rgb(255, 255, 255); }
.topbar-group-gh .topbar-btn-save:hover { background: rgb(33, 136, 56); }
.topbar-group-gh .topbar-btn-saveas { border-left: 1px solid rgba(255, 255, 255, 0.3); background: rgb(45, 164, 78); color: rgb(255, 255, 255); padding: 6px; min-width: 0px; }
.topbar-group-gh .topbar-btn-saveas:hover { background: rgb(33, 136, 56); }
.topbar-repo-label { font-size: 11px; color: rgb(136, 136, 136); font-family: "JetBrains Mono", monospace; max-width: 160px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.topbar-group-ext { display: flex; align-items: center; gap: 4px; background: rgb(246, 248, 250); border: 1px solid rgb(208, 215, 222); border-radius: 8px; padding: 0px 4px 0px 8px; overflow: hidden; }
.topbar-group-ext .topbar-repo-label { max-width: 140px; }
.topbar-group-ext .topbar-btn-gh { border: none; border-radius: 4px; background: transparent; font-weight: 600; font-size: 11px; padding: 4px 8px; gap: 4px; color: rgb(36, 41, 47); }
.topbar-group-ext .topbar-btn-gh:hover { background: rgb(235, 238, 241); }
.topbar-group-ext .topbar-btn-save { background: rgb(45, 164, 78); color: rgb(255, 255, 255); border-radius: 4px; }
.topbar-group-ext .topbar-btn-save:hover { background: rgb(33, 136, 56); }
.topbar-btn-github { gap: 6px; background: rgb(36, 41, 46) !important; color: rgb(255, 255, 255) !important; border: none !important; font-weight: 600 !important; }
.topbar-btn-github:hover { background: rgb(27, 31, 35) !important; }
.topbar-btn-ai { background: linear-gradient(135deg, rgb(245, 243, 255), rgb(237, 233, 254)) !important; border-color: rgb(196, 181, 253) !important; color: rgb(109, 40, 217) !important; font-weight: 600 !important; }
.topbar-btn-ai:hover { background: linear-gradient(135deg, rgb(237, 233, 254), rgb(221, 214, 254)) !important; }
.topbar-gh-avatar { background: none; cursor: pointer; padding: 0px; width: 30px; height: 30px; border-radius: 50%; overflow: hidden; border: 2px solid transparent; transition: border-color 0.15s; }
.topbar-gh-avatar:hover { border-color: var(--app-accent); }
.topbar-gh-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.dropdown-user-info { padding: 8px 12px; display: flex; flex-direction: column; gap: 2px; }
.dropdown-user-info strong { font-size: 13px; }
.dropdown-section-label { padding: 6px 12px 2px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: rgb(153, 153, 153); }
.ai-guide-modal { background: rgb(255, 255, 255); border-radius: 20px; width: 440px; max-width: 90vw; position: relative; box-shadow: rgba(0, 0, 0, 0.2) 0px 24px 80px; animation: 0.2s ease-out 0s 1 normal none running deploySlideUp; }
.ai-guide-content { padding: 32px 28px 24px; }
.ai-guide-icon { width: 52px; height: 52px; border-radius: 14px; background: linear-gradient(135deg, rgb(245, 243, 255), rgb(237, 233, 254)); display: inline-flex; align-items: center; justify-content: center; color: rgb(109, 40, 217); margin-bottom: 16px; }
.ai-guide-content h3 { font-size: 18px; font-weight: 700; margin: 0px 0px 20px; color: rgb(26, 29, 35); }
.ai-guide-steps { display: flex; flex-direction: column; gap: 16px; margin-bottom: 24px; }
.ai-guide-step { display: flex; gap: 12px; align-items: flex-start; }
.ai-guide-num { width: 24px; height: 24px; border-radius: 50%; background: rgb(240, 240, 255); color: rgb(99, 102, 241); font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.ai-guide-step strong { font-size: 13px; display: block; margin-bottom: 2px; }
.ai-guide-step p { font-size: 12px; color: rgb(102, 102, 102); line-height: 1.5; margin: 0px; }
.ai-guide-step a { color: rgb(99, 102, 241); text-decoration: none; }
.ai-guide-step a:hover { text-decoration: underline; }
.ai-guide-copy-btn { width: 100%; padding: 12px; border: none; border-radius: 10px; background: linear-gradient(135deg, rgb(99, 102, 241), rgb(124, 58, 237)); color: rgb(255, 255, 255); font-size: 14px; font-weight: 600; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: opacity 0.15s; }
.ai-guide-subtitle { font-size: 13px; color: rgb(102, 102, 102); margin-bottom: 14px; }
.ai-section-checklist { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 12px; margin-bottom: 12px; max-height: 220px; overflow-y: auto; padding: 10px; background: rgb(248, 249, 250); border-radius: 8px; }
.ai-check-item { display: flex; align-items: center; gap: 6px; font-size: 12px; cursor: pointer; padding: 3px 0px; }
.ai-check-item input { accent-color: var(--app-accent); }
.ai-options-row { display: flex; gap: 16px; padding: 8px 10px; background: rgb(240, 240, 255); border-radius: 8px; margin-bottom: 8px; }
.ai-options-row .ai-check-item { font-weight: 600; color: var(--app-accent); }
.ai-guide-copy-btn:hover { opacity: 0.9; }
.topbar-btn-pdf { background: rgb(254, 243, 199) !important; border-color: rgb(251, 191, 36) !important; color: rgb(146, 64, 14) !important; font-weight: 600 !important; }
.topbar-btn-pdf:hover { background: rgb(253, 230, 138) !important; }
.deploy-backdrop { position: fixed; inset: 0px; background: rgba(0, 0, 0, 0.45); display: flex; align-items: center; justify-content: center; z-index: 1000; backdrop-filter: blur(3px); animation: 0.15s ease-out 0s 1 normal none running deployFadeIn; }
@keyframes deployFadeIn { 
  0% { opacity: 0; }
  100% { opacity: 1; }
}
@keyframes deploySlideUp { 
  0% { opacity: 0; transform: translateY(12px) scale(0.97); }
  100% { opacity: 1; transform: translateY(0px) scale(1); }
}
@keyframes deploySpin { 
  100% { transform: rotate(360deg); }
}
@keyframes deployCheckPop { 
  0% { transform: scale(0); }
  60% { transform: scale(1.15); }
  100% { transform: scale(1); }
}
.deploy-modal { background: rgb(255, 255, 255); border-radius: 20px; width: 400px; max-width: 90vw; position: relative; box-shadow: rgba(0, 0, 0, 0.2) 0px 24px 80px, rgba(0, 0, 0, 0.04) 0px 0px 0px 1px; animation: 0.2s ease-out 0s 1 normal none running deploySlideUp; }
.deploy-close { position: absolute; top: 14px; right: 14px; z-index: 1; background: none; border: none; cursor: pointer; color: rgb(187, 187, 187); padding: 6px; border-radius: 8px; line-height: 0; }
.deploy-close:hover { background: rgb(245, 245, 245); color: rgb(102, 102, 102); }
.deploy-body-form { padding: 32px 28px 28px; text-align: center; }
.deploy-form-icon { width: 52px; height: 52px; border-radius: 14px; background: rgb(246, 248, 250); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 14px; color: rgb(36, 41, 46); }
.deploy-body-form h3 { font-size: 17px; font-weight: 700; margin: 0px 0px 20px; color: rgb(26, 29, 35); }
.deploy-field { margin-bottom: 20px; text-align: left; }
.deploy-field label { display: block; font-size: 12px; font-weight: 600; color: rgb(102, 102, 102); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.3px; }
.deploy-repo-input { display: flex; align-items: center; border: 1.5px solid rgb(224, 227, 232); border-radius: 10px; overflow: hidden; font-size: 14px; transition: border-color 0.15s, box-shadow 0.15s; background: rgb(255, 255, 255); }
.deploy-repo-input:focus-within { border-color: rgb(99, 102, 241); box-shadow: rgba(99, 102, 241, 0.1) 0px 0px 0px 3px; }
.deploy-repo-prefix { padding: 10px 0px 10px 12px; color: rgb(153, 153, 153); background: transparent; font-size: 13px; white-space: nowrap; font-family: "JetBrains Mono", monospace; }
.deploy-repo-input input { border: none; outline: none; padding: 10px 12px 10px 2px; flex: 1 1 0%; font-size: 14px; font-family: "JetBrains Mono", monospace; min-width: 0px; background: transparent; }
.deploy-hint { display: block; font-size: 11px; color: rgb(170, 170, 170); margin-top: 8px; font-family: "JetBrains Mono", monospace; }
.deploy-error { background: rgb(254, 242, 242); border: 1px solid rgb(254, 202, 202); color: rgb(220, 38, 38); padding: 10px 14px; border-radius: 10px; font-size: 12px; margin-bottom: 16px; text-align: left; }
.deploy-body-progress { padding: 48px 28px; text-align: center; }
.deploy-spinner { width: 36px; height: 36px; border-width: 3px; border-style: solid; border-color: rgb(99, 102, 241) rgb(229, 231, 235) rgb(229, 231, 235); border-image: initial; border-radius: 50%; animation: 0.7s linear 0s infinite normal none running deploySpin; margin: 0px auto 18px; }
.deploy-status-text { font-size: 14px; color: rgb(102, 102, 102); font-weight: 500; }
.deploy-body-success { padding: 36px 28px 28px; text-align: center; }
.deploy-check-ring { width: 56px; height: 56px; border-radius: 50%; background: linear-gradient(135deg, rgb(34, 197, 94), rgb(22, 163, 74)); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 16px; box-shadow: rgba(34, 197, 94, 0.3) 0px 4px 16px; animation: 0.35s ease-out 0s 1 normal none running deployCheckPop; }
.deploy-body-success h3 { font-size: 18px; font-weight: 700; margin: 0px 0px 6px; color: rgb(26, 29, 35); }
.deploy-published-url { font-size: 13px; color: rgb(136, 136, 136); margin-bottom: 20px; font-family: "JetBrains Mono", monospace; }
.deploy-action-row { display: flex; gap: 8px; margin-bottom: 16px; }
.deploy-action-btn { flex: 1 1 0%; display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 16px; border-radius: 10px; font-size: 13px; font-weight: 600; cursor: pointer; text-decoration: none; border: none; transition: 0.15s; }
.deploy-action-primary { background: rgb(26, 29, 35); color: rgb(255, 255, 255); }
.deploy-action-primary:hover { background: rgb(51, 51, 51); }
.deploy-action-secondary { background: rgb(244, 245, 247); color: rgb(85, 85, 85); }
.deploy-action-secondary:hover { background: rgb(234, 235, 238); }
.deploy-submit { width: 100%; }
.deploy-submit:disabled { opacity: 0.5; cursor: not-allowed; }
.deploy-footnote { display: block; font-size: 11px; color: rgb(170, 170, 170); margin-top: 4px; }
.load-modal { width: 420px; }
.load-header { padding: 28px 28px 16px; text-align: center; }
.load-header h3 { font-size: 17px; font-weight: 700; margin: 0px; color: rgb(26, 29, 35); }
.load-body { padding: 0px 16px 16px; }
.load-body .deploy-error { margin: 0px 12px 12px; }
.load-repo-list { max-height: 320px; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.load-repo-item { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px; border: none; background: none; border-radius: 10px; cursor: pointer; text-align: left; transition: background 0.12s; width: 100%; gap: 12px; }
.load-repo-item:hover { background: rgb(245, 246, 248); }
.load-repo-info { display: flex; flex-direction: column; gap: 2px; min-width: 0px; }
.load-repo-name { font-size: 13px; font-weight: 600; color: rgb(26, 29, 35); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.load-repo-desc { font-size: 11px; color: rgb(136, 136, 136); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.load-repo-date { font-size: 11px; color: rgb(170, 170, 170); white-space: nowrap; flex-shrink: 0; }
.external-import-section { padding: 0px 8px 8px; }
.external-import-label { font-size: 12px; font-weight: 600; color: rgb(85, 85, 85); margin-bottom: 6px; display: block; }
.external-import-row { display: flex; gap: 6px; }
.external-import-input { flex: 1 1 0%; padding: 8px 10px; border: 1px solid rgb(221, 221, 221); border-radius: 8px; font-size: 12.5px; outline: none; transition: border-color 0.15s; }
.external-import-input:focus { border-color: var(--app-accent, #2563eb); }
.external-import-btn { padding: 8px 14px; border: none; border-radius: 8px; background: var(--app-accent, #2563eb); color: rgb(255, 255, 255); font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap; transition: opacity 0.15s; }
.external-import-btn:hover { opacity: 0.85; }
.external-import-hint { font-size: 10.5px; color: rgb(153, 153, 153); margin-top: 4px; display: block; }
.load-divider { display: flex; align-items: center; gap: 12px; padding: 12px 8px 4px; font-size: 11px; font-weight: 600; color: rgb(153, 153, 153); text-transform: uppercase; letter-spacing: 0.04em; }
.load-divider::before, .load-divider::after { content: ""; flex: 1 1 0%; height: 1px; background: rgb(229, 231, 235); }
.media-thumb-section { display: flex; flex-direction: column; gap: 8px; }
.media-thumb-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(70px, 1fr)); gap: 6px; }
.media-thumb { aspect-ratio: 1 / 1; border: 2px solid rgb(229, 231, 235); border-radius: 8px; background: rgb(248, 249, 250); cursor: pointer; position: relative; overflow: hidden; transition: border-color 0.15s; }
.media-thumb:hover { border-color: rgb(196, 181, 253); }
.media-thumb.active { border-color: var(--app-accent); box-shadow: rgba(99, 102, 241, 0.15) 0px 0px 0px 2px; }
.media-thumb.dragging { opacity: 0.4; }
.media-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.media-thumb-empty { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.media-thumb-x { position: absolute; top: 3px; right: 3px; width: 16px; height: 16px; border-radius: 50%; background: rgba(0, 0, 0, 0.55); color: rgb(255, 255, 255); border: none; cursor: pointer; display: none; align-items: center; justify-content: center; padding: 0px; line-height: 0; }
.media-thumb:hover .media-thumb-x { display: flex; }
.media-thumb-add { border: 2px dashed rgb(208, 213, 221); display: flex; align-items: center; justify-content: center; color: var(--app-accent); transition: 0.15s; }
.media-thumb-add:hover { border-color: var(--app-accent); background: rgb(245, 243, 255); }
.media-bulk-btn { display: flex; align-items: center; justify-content: center; gap: 5px; padding: 6px 12px; background: rgb(255, 255, 255); border: 1px solid rgb(221, 221, 221); border-radius: 7px; font-size: 11px; font-weight: 600; cursor: pointer; color: rgb(85, 85, 85); transition: 0.15s; }
.media-bulk-btn:hover { background: rgb(245, 245, 245); border-color: rgb(187, 187, 187); }
.media-thumb-detail { padding: 10px; border: 1px solid rgb(229, 231, 235); border-radius: 8px; background: rgb(250, 251, 253); }
.comp-thumb-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: 6px; }
.comp-thumb { border: 2px solid rgb(229, 231, 235); border-radius: 8px; overflow: hidden; cursor: pointer; position: relative; transition: border-color 0.15s; }
.comp-thumb:hover { border-color: rgb(196, 181, 253); }
.comp-thumb.active { border-color: var(--app-accent); box-shadow: rgba(99, 102, 241, 0.15) 0px 0px 0px 2px; }
.comp-thumb-pair { display: flex; height: 56px; }
.comp-thumb-img { flex: 1 1 0%; display: flex; align-items: center; justify-content: center; font-size: 10px; color: rgb(170, 170, 170); position: relative; }
.comp-thumb-img + .comp-thumb-img { border-left: 1px solid rgb(229, 231, 235); }
.comp-thumb-label { position: absolute; bottom: 2px; left: 3px; font-size: 8px; font-weight: 700; color: rgb(255, 255, 255); background: rgba(0, 0, 0, 0.4); padding: 0px 3px; border-radius: 2px; }
.comp-thumb-add { border: 2px dashed rgb(208, 213, 221); display: flex; align-items: center; justify-content: center; min-height: 56px; color: var(--app-accent); }
.comp-thumb-add:hover { border-color: var(--app-accent); background: rgb(245, 243, 255); }
.comp-detail { padding: 10px; border: 1px solid rgb(229, 231, 235); border-radius: 8px; background: rgb(250, 251, 253); display: flex; flex-direction: column; gap: 8px; }
.comp-detail-row { display: flex; gap: 6px; }
.comp-upload-box { flex: 1 1 0%; height: 80px; border: 2px dashed rgb(221, 221, 221); border-radius: 8px; display: flex; align-items: center; justify-content: center; cursor: pointer; overflow: hidden; background: rgb(248, 249, 250); font-size: 11px; color: rgb(153, 153, 153); transition: border-color 0.15s; }
.comp-upload-box:hover { border-color: var(--app-accent); color: var(--app-accent); }
.comp-upload-box img { width: 100%; height: 100%; object-fit: cover; }
.comp-detail input[type="text"] { padding: 6px 8px; border: 1px solid var(--app-border); border-radius: 6px; font-size: 12px; width: 100%; }
.asset-tray { position: fixed; bottom: 16px; left: calc(var(--sidebar-width) + 16px); right: 16px; z-index: 90; background: rgb(255, 255, 255); border: 1px solid rgb(226, 229, 235); border-radius: 12px; box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 20px; padding: 8px 12px; display: flex; align-items: center; gap: 10px; max-width: 600px; }
.asset-tray-header { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.asset-tray-header span { font-size: 11px; font-weight: 700; color: rgb(85, 85, 85); white-space: nowrap; }
.asset-tray-header button { background: none; border: none; cursor: pointer; color: rgb(170, 170, 170); padding: 2px; border-radius: 4px; line-height: 0; }
.asset-tray-header button:hover { color: rgb(102, 102, 102); background: rgb(240, 240, 240); }
.asset-tray-items { display: flex; gap: 6px; overflow-x: auto; flex: 1 1 0%; padding: 2px 0px; }
.asset-tray-img { height: 48px; border-radius: 6px; cursor: grab; border: 2px solid transparent; transition: border-color 0.15s; object-fit: cover; flex-shrink: 0; }
.asset-tray-img:hover { border-color: rgb(99, 102, 241); }
.asset-tray-img:active { cursor: grabbing; }
.pdf-backdrop { position: fixed; inset: 0px; background: rgba(0, 0, 0, 0.5); display: flex; align-items: center; justify-content: center; z-index: 1000; backdrop-filter: blur(3px); }
.pdf-modal { background: rgb(255, 255, 255); border-radius: 16px; width: 90vw; max-width: 960px; height: 80vh; box-shadow: rgba(0, 0, 0, 0.25) 0px 24px 80px; display: flex; flex-direction: column; position: relative; overflow: hidden; }
.pdf-topbar { display: flex; align-items: center; gap: 12px; padding: 12px 16px; border-bottom: 1px solid rgb(238, 238, 238); flex-shrink: 0; }
.pdf-upload-btn { display: flex; align-items: center; gap: 5px; padding: 7px 14px; background: rgb(255, 255, 255); border: 1px solid rgb(221, 221, 221); border-radius: 8px; font-size: 12px; font-weight: 600; cursor: pointer; color: rgb(85, 85, 85); transition: 0.15s; }
.pdf-upload-btn:hover { background: rgb(245, 245, 245); }
.pdf-tabs { display: flex; gap: 2px; background: rgb(240, 241, 245); border-radius: 8px; padding: 3px; }
.pdf-tabs button { padding: 5px 14px; border: none; background: transparent; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; color: rgb(136, 136, 136); transition: 0.15s; }
.pdf-tabs button.active { background: rgb(255, 255, 255); color: rgb(26, 29, 35); box-shadow: rgba(0, 0, 0, 0.08) 0px 1px 3px; }
.pdf-body-row, .pdf-body { flex: 1 1 0%; overflow: hidden; display: flex; }
.pdf-loading { flex: 1 1 0%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; color: rgb(136, 136, 136); font-size: 13px; }
.pdf-empty { flex: 1 1 0%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; cursor: pointer; }
.pdf-empty span { font-size: 13px; color: rgb(170, 170, 170); }
.pdf-empty:hover { background: rgb(250, 250, 250); }
.pdf-images-grid { flex: 1 1 0%; overflow-y: auto; padding: 16px; display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; align-content: start; }
.pdf-image-card { border: 1px solid rgb(229, 231, 235); border-radius: 10px; overflow: hidden; background: rgb(250, 250, 250); transition: box-shadow 0.15s; }
.pdf-image-card:hover { box-shadow: rgba(0, 0, 0, 0.1) 0px 2px 12px; }
.pdf-image-card img { width: 100%; display: block; background: repeating-conic-gradient(rgb(240, 240, 240), rgb(240, 240, 240) 25%, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 50%) 50% center / 16px 16px; }
.pdf-image-info { display: flex; align-items: center; justify-content: space-between; padding: 6px 10px; }
.pdf-image-info span { font-size: 10px; color: rgb(153, 153, 153); }
.pdf-add-btn { display: flex; align-items: center; gap: 4px; padding: 4px 10px; background: rgb(99, 102, 241); color: rgb(255, 255, 255); border: none; border-radius: 6px; font-size: 11px; font-weight: 600; cursor: pointer; transition: background 0.15s; }
.pdf-add-btn:hover { background: rgb(79, 70, 229); }
.pdf-layout { display: flex; flex: 1 1 0%; overflow: hidden; }
.pdf-sidebar { width: 140px; min-width: 140px; border-right: 1px solid rgb(238, 238, 238); background: rgb(249, 250, 251); overflow-y: auto; }
.pdf-thumbs { padding: 8px; display: flex; flex-direction: column; gap: 6px; }
.pdf-thumb { border: 2px solid transparent; border-radius: 6px; padding: 3px; background: rgb(255, 255, 255); cursor: pointer; transition: border-color 0.15s; display: flex; flex-direction: column; align-items: center; gap: 2px; }
.pdf-thumb:hover { border-color: rgb(196, 181, 253); }
.pdf-thumb.active { border-color: rgb(99, 102, 241); background: rgb(245, 243, 255); }
.pdf-thumb img { width: 100%; border-radius: 3px; }
.pdf-thumb span { font-size: 10px; color: rgb(136, 136, 136); }
.pdf-main { flex: 1 1 0%; display: flex; flex-direction: column; overflow: hidden; }
.pdf-canvas-area { flex: 1 1 0%; overflow: auto; display: flex; align-items: flex-start; justify-content: center; padding: 16px; background: rgb(240, 240, 240); }
.pdf-canvas-area canvas { box-shadow: rgba(0, 0, 0, 0.15) 0px 2px 12px; }
.pdf-crop-actions { display: flex; align-items: center; justify-content: space-between; padding: 10px 16px; border-top: 1px solid rgb(238, 238, 238); background: rgb(255, 255, 255); }
.pdf-crop-hint { font-size: 12px; color: rgb(136, 136, 136); }
.pdf-crop-btns { display: flex; gap: 6px; }
.pdf-extract-btn { padding: 7px 14px; border: 1px solid rgb(221, 221, 221); background: rgb(255, 255, 255); border-radius: 7px; font-size: 12px; font-weight: 600; cursor: pointer; transition: 0.15s; color: rgb(85, 85, 85); }
.pdf-extract-btn:hover { background: rgb(245, 245, 245); }
.pdf-extract-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.pdf-extract-primary { background: rgb(99, 102, 241); color: rgb(255, 255, 255); border-color: rgb(99, 102, 241); }
.pdf-extract-primary:hover:not(:disabled) { background: rgb(79, 70, 229); }
.crop-quality-picker { display: flex; flex-direction: column; gap: 6px; width: 100%; }
.crop-quality-options { display: flex; gap: 4px; }
.crop-quality-btn { flex: 1 1 0%; display: flex; flex-direction: column; align-items: center; gap: 1px; padding: 6px 8px; border: 1.5px solid rgb(226, 229, 235); border-radius: 8px; background: rgb(255, 255, 255); cursor: pointer; transition: 0.12s; }
.crop-quality-btn:hover { border-color: rgb(99, 102, 241); background: rgb(245, 243, 255); }
.crop-settings { display: flex; gap: 4px; align-items: center; }
.crop-select { padding: 4px 6px; border: 1px solid rgb(221, 221, 221); border-radius: 5px; font-size: 11px; background: rgb(255, 255, 255); cursor: pointer; }
.crop-split-btn { padding: 3px 8px; border: 1px solid rgb(252, 165, 165); border-radius: 5px; background: rgb(254, 242, 242); color: rgb(220, 38, 38); font-size: 10px; font-weight: 600; cursor: pointer; transition: 0.12s; }
.crop-split-btn:hover { background: rgb(254, 226, 226); }
.crop-split-clear { border-color: rgb(221, 221, 221); background: rgb(255, 255, 255); color: rgb(136, 136, 136); }
.crop-split-clear:hover { background: rgb(245, 245, 245); }
.crop-actions-right { display: flex; gap: 6px; align-items: center; }
.pdf-bbox { position: absolute; border: 2px solid rgba(99, 102, 241, 0.4); background: rgba(99, 102, 241, 0.04); border-radius: 3px; pointer-events: none; z-index: 3; transition: 0.12s; }
.pdf-bbox:hover { border-color: rgb(99, 102, 241); background: rgba(99, 102, 241, 0.12); box-shadow: rgba(99, 102, 241, 0.2) 0px 0px 0px 2px; }
.pdf-bbox.added { border-color: rgb(34, 197, 94); background: rgba(34, 197, 94, 0.08); }
.pdf-bbox.added::after { content: ""; position: absolute; top: 4px; right: 4px; width: 16px; height: 16px; border-radius: 50%; background: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center center / 10px no-repeat rgb(34, 197, 94); }
.pdf-images-tab { display: flex; flex-direction: column; flex: 1 1 0%; overflow: hidden; }
.pdf-filter-bar { display: flex; align-items: center; justify-content: space-between; padding: 8px 16px; border-bottom: 1px solid rgb(238, 238, 238); flex-shrink: 0; }
.pdf-filter-label { font-size: 11px; color: rgb(136, 136, 136); }
.pdf-filter-pills { display: flex; gap: 2px; background: rgb(240, 241, 245); border-radius: 6px; padding: 2px; }
.pdf-filter-pills button { padding: 3px 10px; border: none; background: transparent; border-radius: 4px; font-size: 11px; font-weight: 600; cursor: pointer; color: rgb(136, 136, 136); }
.pdf-filter-pills button.active { background: rgb(255, 255, 255); color: rgb(26, 29, 35); box-shadow: rgba(0, 0, 0, 0.08) 0px 1px 2px; }
.pdf-assets-panel { width: 160px; min-width: 160px; border-left: 1px solid rgb(238, 238, 238); display: flex; flex-direction: column; background: rgb(249, 250, 251); }
.pdf-assets-header { padding: 12px 10px 8px; border-bottom: 1px solid rgb(238, 238, 238); }
.pdf-assets-header h4 { font-size: 12px; font-weight: 700; margin: 0px; color: rgb(85, 85, 85); }
.pdf-assets-list { flex: 1 1 0%; overflow-y: auto; padding: 8px; display: flex; flex-direction: column; gap: 6px; }
.pdf-asset-item { border-radius: 6px; overflow: hidden; background: rgb(255, 255, 255); border: 1px solid rgb(229, 231, 235); cursor: grab; transition: border-color 0.15s; }
.pdf-asset-item:hover { border-color: rgb(99, 102, 241); }
.pdf-asset-item:active { cursor: grabbing; }
.pdf-asset-item img { width: 100%; display: block; }
.pdf-no-page { flex: 1 1 0%; display: flex; align-items: center; justify-content: center; color: rgb(170, 170, 170); font-size: 14px; }
@media (max-width: 900px) {
  .sidebar { width: 300px; min-width: 300px; }
  :root { --sidebar-width: 336px; }
  .topbar-template-pills { display: none; }
}
@media (max-width: 700px) {
  .sidebar { display: none; }
  .preview-scroll { padding: 12px; }
  .preview-sidebar-col { display: none; }
  .preview-outer.has-sidebar { display: block; }
}
@media (max-width: 600px) {
  .topbar { flex-wrap: wrap; height: auto; min-height: var(--topbar-height); padding: 6px 10px; }
  .topbar-left, .topbar-right { width: 100%; justify-content: center; }
  .topbar-sep { display: none; }
  .topbar-group-gh { flex-wrap: wrap; }
  .preview-scroll { padding: 8px; }
}
@media (max-width: 768px) {
  .preview-outer { font-size: calc(var(--font-size, 16px) * .95) !important; }
  .content-container { padding-left: 20px !important; padding-right: 20px !important; }
  .sec-hero { padding-left: 20px; padding-right: 20px; }
  .hero-title { letter-spacing: -0.01em; font-size: clamp(1.5rem, 5vw, 2.4rem) !important; line-height: 1.25 !important; }
  .hero-subtitle { max-width: 100%; line-height: 1.55; font-size: clamp(0.9rem, 2.5vw, 1.15rem) !important; }
  .hero-media { max-width: 100%; }
  .venue-badge { font-size: 0.8em; }
  .sec-authors { padding-left: 16px !important; padding-right: 16px !important; }
  .author-card { gap: 1px; }
  .author-name { font-size: 0.9em; }
  .author-affil { font-size: 0.7em; }
  .links-row { gap: 8px; }
  .link-btn { font-size: 12px; padding: 8px 14px; gap: 5px; }
  .link-btn svg { width: 14px; height: 14px; }
  .preview-sidebar-col { display: none; }
  .preview-outer.has-sidebar { display: block; }
  .preview-outer.has-sidebar .preview-page { width: 100%; }
  .nav-top-inner { padding: 0px 16px; gap: 2px; }
  .nav-top-link { font-size: 12px; padding: 6px 8px; }
  .nav-top-logo { font-size: 0.85em; }
  .image-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 8px !important; }
  .charts-grid { grid-template-columns: 1fr !important; }
  .chart-wrapper { padding: 12px; }
  .chart-wrapper.legend-right, .chart-wrapper.legend-left { grid-template-columns: 1fr; }
  .chart-legend-right, .chart-legend-left { min-width: 0px; flex-flow: wrap; margin-top: 10px; }
  .chart-legend { gap: 6px; }
  .chart-legend-item { font-size: 11px; }
  .results-table { font-size: 12px; }
  .table-grid-scroll { }
  .results-table th, .results-table td { padding: 8px 10px; white-space: nowrap; }
  .two-col-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .tldr-box { padding: 16px !important; }
  .bibtex-code { font-size: 0.72em; padding: 14px 16px !important; }
  .comparison-container { max-width: 100%; }
  .comparison-label { font-size: 10px; padding: 3px 8px; }
  .carousel-controls { gap: 10px; }
  .carousel-btn { width: 32px; height: 32px; }
  .content-bg-box { padding: 16px !important; }
  .hero-teaser { max-width: 100% !important; }
  .sec { padding-top: calc(var(--sec-pt, var(--section-spacing, 48px)) * .55); padding-bottom: calc(var(--sec-pb, var(--section-spacing, 48px)) * .55); }
  .sec-authors { padding-top: calc(var(--sec-pt, 12px) * .6); padding-bottom: calc(var(--sec-pb, 24px) * .6); }
  .sec-links { padding-top: calc(var(--sec-pt, 8px) * .6); padding-bottom: calc(var(--sec-pb, 32px) * .6); }
  .sec-tldr { padding-top: calc(var(--sec-pt, 16px) * .6); padding-bottom: calc(var(--sec-pb, 16px) * .6); }
  .sec-divider { padding-top: calc(var(--sec-pt, 16px) * .5); padding-bottom: calc(var(--sec-pb, 16px) * .5); }
  .sec-teaser { padding-bottom: calc(var(--sec-pb, calc(var(--section-spacing, 48px) * .5)) * .55) !important; }
  .section-heading { font-size: clamp(1.1rem,3.5vw,var(--heading-font-size, 1.5rem)) !important; }
  .section-label-tag { font-size: 0.75rem; letter-spacing: 0.1em; }
  .md-subsection { font-size: 1.1em; }
  .md-subsubsection { font-size: 1em; }
  .sec p, .sec li { line-height: 1.6; }
  .divider-dots { letter-spacing: 8px; font-size: 16px; }
  [data-section-divider="dots"] .sec + .sec::before { letter-spacing: 4px; font-size: 18px; }
  .math-display { overflow-x: auto; }
  .bullet-list { gap: 10px; }
  .bullet-item p { font-size: 0.9em; }
}
@media (max-width: 480px) {
  .preview-outer { font-size: calc(var(--font-size, 16px) * .9) !important; }
  .content-container { padding-left: 12px !important; padding-right: 12px !important; }
  .sec-hero { padding: 32px 12px 24px !important; }
  .hero-title { letter-spacing: -0.01em; font-size: clamp(1.3rem, 6vw, 1.8rem) !important; line-height: 1.3 !important; }
  .hero-subtitle { font-size: 0.85rem !important; line-height: 1.5; }
  .hero-venue { margin-bottom: 10px; }
  .venue-badge { font-size: 0.72em; padding: 4px 10px; letter-spacing: 0.03em; }
  .sec { padding-top: calc(var(--sec-pt, var(--section-spacing, 48px)) * .4); padding-bottom: calc(var(--sec-pb, var(--section-spacing, 48px)) * .4); }
  .sec-authors { padding-top: calc(var(--sec-pt, 12px) * .5); padding-bottom: calc(var(--sec-pb, 24px) * .5); }
  .sec-links { padding-top: calc(var(--sec-pt, 8px) * .5); padding-bottom: calc(var(--sec-pb, 32px) * .5); }
  .sec-divider { padding-top: calc(var(--sec-pt, 16px) * .4); padding-bottom: calc(var(--sec-pb, 16px) * .4); }
  .sec-authors { padding-left: 12px !important; padding-right: 12px !important; }
  .author-list { flex-direction: column !important; gap: 12px !important; }
  .author-card { flex-direction: row; gap: 6px; }
  .author-name { font-size: 0.85em; }
  .author-affil { font-size: 0.65em; }
  .links-row { gap: 6px; }
  .link-btn { font-size: 11px; padding: 6px 10px; gap: 4px; }
  .image-grid { grid-template-columns: 1fr !important; }
  .chart-wrapper { padding: 10px; border-radius: 8px; }
  .chart-wrapper svg text { font-size: 9px; }
  .results-table { font-size: 11px; }
  .results-table th, .results-table td { padding: 6px 8px; }
  .nav-top-inner { overflow-x: auto; flex-wrap: nowrap; justify-content: flex-start; padding: 0px 12px; gap: 0px; }
  .nav-top-link { white-space: nowrap; font-size: 11px; }
  .comparison-container { flex-direction: column; gap: 8px; }
  .section-heading { font-size: clamp(1rem, 4vw, 1.3rem) !important; }
  .section-label-tag { font-size: 0.7rem; letter-spacing: 0.08em; }
  .sec p, .sec li { line-height: 1.55; }
  .bullet-item p { font-size: 0.88em; }
  .divider-dots { letter-spacing: 6px; font-size: 14px; }
  [data-section-divider="dots"] .sec + .sec::before { letter-spacing: 3px; font-size: 16px; }
  .content-bg-box { border-radius: 8px !important; }
  .floating-md-editor { width: calc(-24px + 100vw) !important; left: 12px !important; }
}
@media (max-width: 360px) {
  .preview-outer { font-size: calc(var(--font-size, 16px) * .85) !important; }
  .content-container { padding-left: 8px !important; padding-right: 8px !important; }
  .sec { padding-top: calc(var(--sec-pt, var(--section-spacing, 48px)) * .3); padding-bottom: calc(var(--sec-pb, var(--section-spacing, 48px)) * .3); }
  .sec-hero { padding: 24px 8px 20px !important; }
  .hero-title { font-size: 1.2rem !important; }
  .hero-subtitle { font-size: 0.8rem !important; }
  .venue-badge { font-size: 0.65em; }
  .link-btn { font-size: 10px; padding: 5px 8px; }
  .author-name { font-size: 0.8em; }
  .author-affil { font-size: 0.6em; }
  .chart-legend { display: none; }
  .bibtex-code { font-size: 0.65em; }
  .section-heading { font-size: clamp(0.95rem, 4.5vw, 1.2rem) !important; }
  .divider-dots { letter-spacing: 4px; font-size: 12px; }
}
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0px; margin: -1px; overflow: hidden; clip: rect(0px, 0px, 0px, 0px); white-space: nowrap; border: 0px; }
:focus-visible { outline: 2px solid var(--app-accent); outline-offset: 2px; }
button:focus:not(:focus-visible), input:focus:not(:focus-visible), select:focus:not(:focus-visible), textarea:focus:not(:focus-visible) { outline: none; }
@media (prefers-reduced-motion: reduce) {
  *, ::before, ::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}
@media print {
  .topbar, .sidebar, .pv-controls, .pv-add-zone, .pv-add-btn, .nav-placeholder, .deploy-backdrop, .pdf-backdrop { display: none !important; }
  body, .preview { overflow: visible; height: auto; }
  .preview-scroll { overflow: visible; height: auto; padding: 0px; }
  .preview-section-wrapper { break-inside: avoid; outline: none !important; }
  .app-body { display: block; }
}
.pdf-toast { position: absolute; top: 12px; left: 50%; transform: translate(-50%); z-index: var(--z-toast, 400); background: rgb(34, 197, 94); color: rgb(255, 255, 255); padding: 8px 18px; border-radius: 8px; font-size: 13px; font-weight: 500; box-shadow: rgba(0, 0, 0, 0.15) 0px 4px 12px; pointer-events: none; animation: 0.3s ease 0s 1 normal none running toast-in; }
@keyframes toast-in { 
  0% { opacity: 0; transform: translate(-50%) translateY(-8px); }
  100% { opacity: 1; transform: translate(-50%) translateY(0px); }
}
.preview-section-wrapper.asset-drop-target { outline-offset: -2px; background: rgba(99, 102, 241, 0.04); outline: 2px dashed var(--app-accent) !important; }
.preview-section-wrapper.dragging { opacity: 0.4; transform: scale(0.98); transition: opacity 0.15s, transform 0.15s; outline: 2px dashed var(--app-accent) !important; }

/* Standalone page overrides */
html { height: auto; }
body { height: auto; overflow-y: auto; overflow-x: hidden; margin: 0; padding: 0; }
#root { height: auto; display: block; overflow: visible; }
.app-layout, .app-body { height: auto; display: contents; overflow: visible; }
.topbar, .sidebar, .topbar-dropdown-wrapper, .topbar-dropdown { display: none !important; }
.preview { overflow: visible; height: auto; background: none; }
.preview-scroll { height: auto; overflow: visible; padding: 0; background: none; }
.preview-outer { min-height: 100vh; }
.preview-sidebar-col {
  position: sticky !important; top: 0 !important;
  height: 100vh !important; overflow-y: auto !important;
}
@media (max-width: 768px) {
  .preview-sidebar-col { display: none !important; }
  .preview-outer.has-sidebar { display: block !important; }
  .preview-outer.has-sidebar .preview-page { width: 100% !important; }
}
.preview-section-wrapper { outline: none !important; cursor: default; }
.preview-section-wrapper.selected, .preview-section-wrapper:hover { outline: none !important; background: transparent !important; }
.pv-controls, .pv-add-btn, .pv-add-menu, .deploy-backdrop, .deploy-modal, .asset-tray { display: none !important; }
[class*="spacing-handle"] { display: none !important; }
