diff --git a/extension-dev/firefox-mv2/content.4a18726a.js b/extension-dev/firefox-mv2/content.4a18726a.js index 41c7a20..5e1b89b 100644 --- a/extension-dev/firefox-mv2/content.4a18726a.js +++ b/extension-dev/firefox-mv2/content.4a18726a.js @@ -588,7 +588,18 @@ var _gpthToggleCircledWebp = require("../img/gpth-toggle-circled.webp"); var _gpthToggleCircledWebpDefault = parcelHelpers.interopDefault(_gpthToggleCircledWebp); let isOptionsShown = false; (0, _webextensionPolyfillDefault.default).storage.sync.get("gptheme").then((data)=>{ - const theme = data.gptheme || "light"; + /* const theme = data.gptheme || 'dark' + applyTheme(theme) */ let theme = ""; + const storedTheme = data.gptheme; + if (storedTheme) { + theme = storedTheme; + applyTheme(theme); + return; + } + // Check if the dark or light theme preference is set + const lightThemeQuery = window.matchMedia("(prefers-color-scheme: light)"); + lightThemeQuery.matches ? theme = "light" : theme = "dark" // Fallback theme + ; applyTheme(theme); }); createAndAppendSVGStickyBtn(); @@ -1888,4 +1899,4 @@ exports.export = function(dest, destName, get) { },{}]},["c93qz","3q87D"], "3q87D", "parcelRequire2158") -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAI,WAAW;AAAY,IAAI,WAAW;AAAK,IAAI,aAAa;AAAM,IAAI,eAAe;AAAmB,OAAO,MAAM,CAAC,aAAa,GAAG;AAAmB;AAE7J,iJAAiJ,GACjJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6CA,GACA,IAAI,aAAa;AACjB,IAAI,YAAY,OAAO,MAAM,CAAC,MAAM;AACpC,SAAS,OAAO,UAAU;IACxB,UAAU,IAAI,CAAC,IAAI,EAAE;IACrB,IAAI,CAAC,GAAG,GAAG;QACT,MAAM,OAAO,MAAM,CAAC,OAAO,CAAC,WAAW;QACvC,kBAAkB,EAAE;QACpB,mBAAmB,EAAE;QACrB,QAAQ,SAAU,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,YAAa;QAChD;QACA,SAAS,SAAU,EAAE;YACnB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;QAC9B;IACF;IACA,OAAO,MAAM,CAAC,OAAO,CAAC,WAAW,GAAG;AACtC;AACA,OAAO,MAAM,CAAC,MAAM,GAAG;AACvB,OAAO,MAAM,CAAC,OAAO,GAAG,CAAC;AACzB,IAAI,cAAc,0BAA0B,KAAI,gBAAgB,mCAAmC,KAAI,eAAe,mCAAmC;AAEzJ,SAAS;IACP,OAAO,YAAa,CAAA,SAAS,QAAQ,CAAC,OAAO,CAAC,YAAY,IAAI,SAAS,QAAQ,GAAG,WAAU;AAC9F;AACA,SAAS;IACP,OAAO,YAAY,SAAS,IAAI;AAClC;AAEA,wCAAwC;AACxC,IAAI,SAAS,OAAO,MAAM,CAAC,MAAM;AACjC,IAAI,AAAC,CAAA,CAAC,UAAU,CAAC,OAAO,eAAe,AAAD,KAAM,OAAO,cAAc,aAAa;IAC5E,IAAI,WAAW;IACf,IAAI,OAAO;IACX,IAAI,WAAW,cAAc,SAAS,QAAQ,IAAI,YAAY,CAAC;QAAC;QAAa;QAAa;KAAU,CAAC,QAAQ,CAAC,YAAY,QAAQ;IAClI,IAAI;IACJ,IAAI;QACF,KAAK,IAAI,UAAU,WAAW,QAAQ,WAAY,CAAA,OAAO,MAAM,OAAO,EAAC,IAAK;IAC9E,EAAE,OAAO,KAAK;QACZ,IAAI,IAAI,OAAO,EACb,QAAQ,KAAK,CAAC,IAAI,OAAO;QAE3B,KAAK,CAAC;IACR;IAEA,wBAAwB;IACxB,IAAI,SAAS,OAAO,YAAY,cAAc,OAAO,WAAW,cAAc,OAAO,SAAS;IAE9F,oDAAoD;IACpD,0DAA0D;IAC1D,IAAI,oBAAoB;IACxB,IAAI;QACD,CAAA,GAAG,IAAG,EAAG;IACZ,EAAE,OAAO,KAAK;QACZ,oBAAoB,IAAI,KAAK,CAAC,QAAQ,CAAC;IACzC;IAEA,aAAa;IACb,GAAG,SAAS,GAAG,eAAgB,MAAM,wBAAwB,GAAzB;QAClC,gBAAgB,CAAC,EAAE,0BAA0B;QAC7C,iBAAiB,EAAE;QACnB,kBAAkB,EAAE;QACpB,IAAI,KAAK,eAAe,MAAK,KAAK,KAAK,CAAC,MAAM,IAAI;QAClD,IAAI,KAAK,IAAI,KAAK,UAAU;YAC1B,uCAAuC;YACvC,IAAI,OAAO,aAAa,aACtB;YAEF,IAAI,SAAS,KAAK,MAAM,CAAC,MAAM,CAAC,CAAA,QAAS,MAAM,OAAO,KAAK;YAE3D,oBAAoB;YACpB,IAAI,UAAU,OAAO,KAAK,CAAC,CAAA;gBACzB,OAAO,MAAM,IAAI,KAAK,SAAS,MAAM,IAAI,KAAK,QAAQ,eAAe,OAAO,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,MAAM,YAAY;YACvH;YACA,IAAI,SAAS;gBACX,QAAQ,KAAK;gBAEb,yEAAyE;gBACzE,IAAI,OAAO,WAAW,eAAe,OAAO,gBAAgB,aAC1D,OAAO,aAAa,CAAC,IAAI,YAAY;gBAEvC,MAAM,gBAAgB;gBAEtB,0BAA0B;gBAC1B,IAAI,kBAAkB,CAAC,EAAE,0BAA0B;gBACnD,IAAK,IAAI,IAAI,GAAG,IAAI,gBAAgB,MAAM,EAAE,IAAK;oBAC/C,IAAI,KAAK,eAAe,CAAC,EAAE,CAAC,EAAE;oBAC9B,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE;wBACxB,WAAW,eAAe,CAAC,EAAE,CAAC,EAAE,EAAE;wBAClC,eAAe,CAAC,GAAG,GAAG;oBACxB;gBACF;gBAEA,8FAA8F;gBAC9F,kBAAkB,CAAC;gBACnB,IAAK,IAAI,IAAI,GAAG,IAAI,eAAe,MAAM,EAAE,IAAK;oBAC9C,IAAI,KAAK,cAAc,CAAC,EAAE,CAAC,EAAE;oBAC7B,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE;wBACxB,UAAU,cAAc,CAAC,EAAE,CAAC,EAAE,EAAE;wBAChC,eAAe,CAAC,GAAG,GAAG;oBACxB;gBACF;YACF,OAAO;QACT;QACA,IAAI,KAAK,IAAI,KAAK,SAAS;YACzB,+BAA+B;YAC/B,KAAK,IAAI,kBAAkB,KAAK,WAAW,CAAC,IAAI,CAAE;gBAChD,IAAI,QAAQ,eAAe,SAAS,GAAG,eAAe,SAAS,GAAG,eAAe,KAAK;gBACtF,QAAQ,KAAK,CAAC,4BAAkB,eAAe,OAAO,GAAG,OAAO,QAAQ,SAAS,eAAe,KAAK,CAAC,IAAI,CAAC;YAC7G;YACA,IAAI,OAAO,aAAa,aAAa;gBACnC,gCAAgC;gBAChC;gBACA,IAAI,UAAU,mBAAmB,KAAK,WAAW,CAAC,IAAI;gBACtD,aAAa;gBACb,SAAS,IAAI,CAAC,WAAW,CAAC;YAC5B;QACF;IACF;IACA,GAAG,OAAO,GAAG,SAAU,CAAC;QACtB,IAAI,EAAE,OAAO,EACX,QAAQ,KAAK,CAAC,EAAE,OAAO;IAE3B;IACA,GAAG,OAAO,GAAG;QACX,QAAQ,IAAI,CAAC;IACf;AACF;AACA,SAAS;IACP,IAAI,UAAU,SAAS,cAAc,CAAC;IACtC,IAAI,SAAS;QACX,QAAQ,MAAM;QACd,QAAQ,GAAG,CAAC;IACd;AACF;AACA,SAAS,mBAAmB,WAAW;IACrC,IAAI,UAAU,SAAS,aAAa,CAAC;IACrC,QAAQ,EAAE,GAAG;IACb,IAAI,YAAY;IAChB,KAAK,IAAI,cAAc,YAAa;QAClC,IAAI,QAAQ,WAAW,MAAM,CAAC,MAAM,GAAG,WAAW,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG;YAClE,OAAO,CAAC,EAAE,EAAE;sCACoB,EAAE,mBAAmB,MAAM,QAAQ,EAAE,2FAA2F,EAAE,MAAM,QAAQ,CAAC;AACvL,EAAE,MAAM,IAAI,CAAC,CAAC;QACV,GAAG,MAAM,WAAW,KAAK;QACzB,aAAa,CAAC;;;oBAGL,EAAE,WAAW,OAAO,CAAC;;aAErB,EAAE,MAAM;;UAEX,EAAE,WAAW,KAAK,CAAC,GAAG,CAAC,CAAA,OAAQ,uBAAa,OAAO,UAAU,IAAI,CAAC,IAAI;;QAExE,EAAE,WAAW,aAAa,GAAG,CAAC,8CAAuC,EAAE,WAAW,aAAa,CAAC,sCAAsC,CAAC,GAAG,GAAG;;IAEjJ,CAAC;IACH;IACA,aAAa;IACb,QAAQ,SAAS,GAAG;IACpB,OAAO;AACT;AACA,SAAS;IACP,IAAI,YAAY,UACd,SAAS,MAAM;SACV,IAAI,UAAU,OAAO,OAAO,IAAI,OAAO,OAAO,CAAC,MAAM,EAC1D,OAAO,OAAO,CAAC,MAAM;AAEzB;AACA,SAAS,WAAW,MAAM,EAAE,EAAE,EAAE,mCAAmC;IACjE,IAAI,UAAU,OAAO,OAAO;IAC5B,IAAI,CAAC,SACH,OAAO,EAAE;IAEX,IAAI,UAAU,EAAE;IAChB,IAAI,GAAG,GAAG;IACV,IAAK,KAAK,QACR,IAAK,KAAK,OAAO,CAAC,EAAE,CAAC,EAAE,CAAE;QACvB,MAAM,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE;QACtB,IAAI,QAAQ,MAAM,MAAM,OAAO,CAAC,QAAQ,GAAG,CAAC,IAAI,MAAM,GAAG,EAAE,KAAK,IAC9D,QAAQ,IAAI,CAAC;YAAC;YAAQ;SAAE;IAE5B;IAEF,IAAI,OAAO,MAAM,EACf,UAAU,QAAQ,MAAM,CAAC,WAAW,OAAO,MAAM,EAAE;IAErD,OAAO;AACT;AACA,SAAS,WAAW,IAAI;IACtB,IAAI,OAAO,KAAK,YAAY,CAAC;IAC7B,IAAI,CAAC,MACH;IAEF,IAAI,UAAU,KAAK,SAAS;IAC5B,QAAQ,MAAM,GAAG;QACf,IAAI,KAAK,UAAU,KAAK,MACtB,aAAa;QACb,KAAK,UAAU,CAAC,WAAW,CAAC;IAEhC;IACA,QAAQ,YAAY,CAAC,QACrB,aAAa;IACb,KAAK,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,KAAK,GAAG;IACnC,aAAa;IACb,KAAK,UAAU,CAAC,YAAY,CAAC,SAAS,KAAK,WAAW;AACxD;AACA,IAAI,aAAa;AACjB,SAAS;IACP,IAAI,YACF;IAEF,aAAa,WAAW;QACtB,IAAI,QAAQ,SAAS,gBAAgB,CAAC;QACtC,IAAK,IAAI,IAAI,GAAG,IAAI,MAAM,MAAM,EAAE,IAAK;YACrC,gCAAgC;YAChC,IAAI,KAAK,WAAW,MAAK,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC;YAC/C,IAAI,WAAW;YACf,IAAI,sBAAsB,aAAa,cAAc,IAAI,OAAO,mDAAmD,WAAW,IAAI,CAAC,QAAQ,KAAK,OAAO,CAAC,WAAW,MAAM;YACzK,IAAI,WAAW,gBAAgB,IAAI,CAAC,SAAS,KAAK,OAAO,CAAC,SAAS,MAAM,MAAM,KAAK,CAAC;YACrF,IAAI,CAAC,UACH,WAAW,KAAK,CAAC,EAAE;QAEvB;QACA,aAAa;IACf,GAAG;AACL;AACA,SAAS,YAAY,KAAK;IACxB,IAAI,MAAM,IAAI,KAAK,MAAM;QACvB,IAAI,OAAO,aAAa,aAAa;YACnC,IAAI,SAAS,SAAS,aAAa,CAAC;YACpC,OAAO,GAAG,GAAG,MAAM,GAAG,GAAG,QAAQ,KAAK,GAAG;YACzC,IAAI,MAAM,YAAY,KAAK,YACzB,OAAO,IAAI,GAAG;YAEhB,OAAO,IAAI,QAAQ,CAAC,SAAS;gBAC3B,IAAI;gBACJ,OAAO,MAAM,GAAG,IAAM,QAAQ;gBAC9B,OAAO,OAAO,GAAG;gBAChB,CAAA,iBAAiB,SAAS,IAAI,AAAD,MAAO,QAAQ,mBAAmB,KAAK,KAAK,eAAe,WAAW,CAAC;YACvG;QACF,OAAO,IAAI,OAAO,kBAAkB,YAAY;YAC9C,iBAAiB;YACjB,IAAI,MAAM,YAAY,KAAK,YACzB,OAAO,OAAmB,MAAM,GAAG,GAAG,QAAQ,KAAK,GAAG;iBAEtD,OAAO,IAAI,QAAQ,CAAC,SAAS;gBAC3B,IAAI;oBACF,cAA0B,MAAM,GAAG,GAAG,QAAQ,KAAK,GAAG;oBACtD;gBACF,EAAE,OAAO,KAAK;oBACZ,OAAO;gBACT;YACF;QAEJ;IACF;AACF;AACA,eAAe,gBAAgB,MAAM;IACnC,OAAO,eAAe,GAAG,OAAO,MAAM,CAAC;IACvC,IAAI;IACJ,IAAI;QACF,kEAAkE;QAClE,gEAAgE;QAChE,gEAAgE;QAChE,mDAAmD;QACnD,iDAAiD;QACjD,mDAAmD;QACnD,IAAI,CAAC,mBAAmB;YACtB,IAAI,WAAW,OAAO,GAAG,CAAC,CAAA;gBACxB,IAAI;gBACJ,OAAO,AAAC,CAAA,eAAe,YAAY,MAAK,MAAO,QAAQ,iBAAiB,KAAK,IAAI,KAAK,IAAI,aAAa,KAAK,CAAC,CAAA;oBAC3G,oBAAoB;oBACpB,IAAI,UAAU,OAAO,OAAO,IAAI,OAAO,OAAO,CAAC,WAAW,GAAG,gBAAgB,IAAI,KAAK,OAAO,4BAA4B,eAAe,kBAAkB,0BAA0B;wBAClL,OAAO,OAAO,CAAC,MAAM;wBACrB;oBACF;oBACA,MAAM;gBACR;YACF;YACA,kBAAkB,MAAM,QAAQ,GAAG,CAAC;QACtC;QACA,OAAO,OAAO,CAAC,SAAU,KAAK;YAC5B,SAAS,OAAO,MAAM,CAAC,IAAI,EAAE;QAC/B;IACF,SAAU;QACR,OAAO,OAAO,eAAe;QAC7B,IAAI,iBACF,gBAAgB,OAAO,CAAC,CAAA;YACtB,IAAI,QAAQ;gBACV,IAAI;gBACH,CAAA,kBAAkB,SAAS,IAAI,AAAD,MAAO,QAAQ,oBAAoB,KAAK,KAAK,gBAAgB,WAAW,CAAC;YAC1G;QACF;IAEJ;AACF;AACA,SAAS,SAAS,OAAO,kBAAkB,GAAnB,EAAuB,MAAM,cAAc,GAAf;IAClD,IAAI,UAAU,OAAO,OAAO;IAC5B,IAAI,CAAC,SACH;IAEF,IAAI,MAAM,IAAI,KAAK,OACjB;SACK,IAAI,MAAM,IAAI,KAAK,MAAM;QAC9B,IAAI,OAAO,MAAM,YAAY,CAAC,OAAO,aAAa,CAAC;QACnD,IAAI,MAAM;YACR,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE;gBACrB,iEAAiE;gBACjE,oHAAoH;gBACpH,IAAI,UAAU,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE;gBAClC,IAAK,IAAI,OAAO,QACd,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,EAAE;oBAC5C,IAAI,KAAK,OAAO,CAAC,IAAI;oBACrB,IAAI,UAAU,WAAW,OAAO,MAAM,CAAC,IAAI,EAAE;oBAC7C,IAAI,QAAQ,MAAM,KAAK,GACrB,UAAU,OAAO,MAAM,CAAC,IAAI,EAAE;gBAElC;YAEJ;YACA,IAAI,mBAGF,AAFA,4DAA4D;YAC5D,+CAA+C;YAC9C,CAAA,GAAG,IAAG,EAAG,MAAM,MAAM;YAGxB,aAAa;YACb,IAAI,KAAK,OAAO,eAAe,CAAC,MAAM,EAAE,CAAC;YACzC,OAAO,CAAC,MAAM,EAAE,CAAC,GAAG;gBAAC;gBAAI;aAAK;QAChC,OAAO,IAAI,OAAO,MAAM,EACtB,SAAS,OAAO,MAAM,EAAE;IAE5B;AACF;AACA,SAAS,UAAU,MAAM,EAAE,EAAE;IAC3B,IAAI,UAAU,OAAO,OAAO;IAC5B,IAAI,CAAC,SACH;IAEF,IAAI,OAAO,CAAC,GAAG,EAAE;QACf,8EAA8E;QAC9E,IAAI,OAAO,OAAO,CAAC,GAAG,CAAC,EAAE;QACzB,IAAI,UAAU,EAAE;QAChB,IAAK,IAAI,OAAO,KAAM;YACpB,IAAI,UAAU,WAAW,OAAO,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI;YACtD,IAAI,QAAQ,MAAM,KAAK,GACrB,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI;QAE1B;QAEA,sGAAsG;QACtG,OAAO,OAAO,CAAC,GAAG;QAClB,OAAO,OAAO,KAAK,CAAC,GAAG;QAEvB,0BAA0B;QAC1B,QAAQ,OAAO,CAAC,CAAA;YACd,UAAU,OAAO,MAAM,CAAC,IAAI,EAAE;QAChC;IACF,OAAO,IAAI,OAAO,MAAM,EACtB,UAAU,OAAO,MAAM,EAAE;AAE7B;AACA,SAAS,eAAe,OAAO,kBAAkB,GAAnB,EAAuB,GAAG,WAAW,GAAZ,EAAgB,aAAa,uCAAuC,GAAxC;IACjF,IAAI,kBAAkB,QAAQ,IAAI,eAChC,OAAO;IAGT,uGAAuG;IACvG,IAAI,UAAU,WAAW,OAAO,MAAM,CAAC,IAAI,EAAE;IAC7C,IAAI,WAAW;IACf,MAAO,QAAQ,MAAM,GAAG,EAAG;QACzB,IAAI,IAAI,QAAQ,KAAK;QACrB,IAAI,IAAI,kBAAkB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE;QACtC,IAAI,GACF,+EAA+E;QAC/E,WAAW;aACN;YACL,yDAAyD;YACzD,IAAI,IAAI,WAAW,OAAO,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE;YAC3C,IAAI,EAAE,MAAM,KAAK,GAAG;gBAClB,kFAAkF;gBAClF,WAAW;gBACX;YACF;YACA,QAAQ,IAAI,IAAI;QAClB;IACF;IACA,OAAO;AACT;AACA,SAAS,kBAAkB,OAAO,kBAAkB,GAAnB,EAAuB,GAAG,WAAW,GAAZ,EAAgB,aAAa,uCAAuC,GAAxC;IACpF,IAAI,UAAU,OAAO,OAAO;IAC5B,IAAI,CAAC,SACH;IAEF,IAAI,gBAAgB,CAAC,YAAY,CAAC,OAAO,aAAa,CAAC,EAAE;QACvD,2EAA2E;QAC3E,yEAAyE;QACzE,IAAI,CAAC,OAAO,MAAM,EAChB,OAAO;QAET,OAAO,eAAe,OAAO,MAAM,EAAE,IAAI;IAC3C;IACA,IAAI,aAAa,CAAC,GAAG,EACnB,OAAO;IAET,aAAa,CAAC,GAAG,GAAG;IACpB,IAAI,SAAS,OAAO,KAAK,CAAC,GAAG;IAC7B,gBAAgB,IAAI,CAAC;QAAC;QAAQ;KAAG;IACjC,IAAI,CAAC,UAAU,OAAO,GAAG,IAAI,OAAO,GAAG,CAAC,gBAAgB,CAAC,MAAM,EAAE;QAC/D,eAAe,IAAI,CAAC;YAAC;YAAQ;SAAG;QAChC,OAAO;IACT;AACF;AACA,SAAS,WAAW,OAAO,kBAAkB,GAAnB,EAAuB,GAAG,WAAW,GAAZ;IACjD,IAAI,SAAS,OAAO,KAAK,CAAC,GAAG;IAC7B,OAAO,OAAO,CAAC,GAAG,GAAG,CAAC;IACtB,IAAI,UAAU,OAAO,GAAG,EACtB,OAAO,GAAG,CAAC,IAAI,GAAG,OAAO,OAAO,CAAC,GAAG;IAEtC,IAAI,UAAU,OAAO,GAAG,IAAI,OAAO,GAAG,CAAC,iBAAiB,CAAC,MAAM,EAC7D,OAAO,GAAG,CAAC,iBAAiB,CAAC,OAAO,CAAC,SAAU,EAAE;QAC/C,GAAG,OAAO,OAAO,CAAC,GAAG;IACvB;IAEF,OAAO,OAAO,KAAK,CAAC,GAAG;AACzB;AACA,SAAS,UAAU,OAAO,kBAAkB,GAAnB,EAAuB,GAAG,WAAW,GAAZ;IAChD,sBAAsB;IACtB,OAAO;IAEP,6DAA6D;IAC7D,IAAI,SAAS,OAAO,KAAK,CAAC,GAAG;IAC7B,IAAI,UAAU,OAAO,GAAG,IAAI,OAAO,GAAG,CAAC,gBAAgB,CAAC,MAAM,EAC5D,OAAO,GAAG,CAAC,gBAAgB,CAAC,OAAO,CAAC,SAAU,EAAE;QAC9C,IAAI,qBAAqB,GAAG;YAC1B,OAAO,WAAW,OAAO,MAAM,CAAC,IAAI,EAAE;QACxC;QACA,IAAI,sBAAsB,eAAe,MAAM,EAAE;YAC/C,mBAAmB,OAAO,CAAC,SAAU,CAAC;gBACpC,WAAW,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE;YACvB;YAEA,+BAA+B;YAC/B,eAAe,IAAI,CAAC,KAAK,CAAC,gBAAgB;QAC5C;IACF;AAEJ;;;AChfA,mCAAmC;AACnC,8DAA8D;;AAC9D;;AACA;;AAEA,IAAI,iBAAiB;AAErB,CAAA,GAAA,oCAAO,AAAD,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,IAAI,CAAC,CAAC;IACzC,MAAM,QAAQ,KAAK,OAAO,IAAI;IAC9B,WAAW;AACZ;AAEA;AACA,0BAA0B;AAE1B,MAAM,WAAW,SAAS,eAAe;AACzC,MAAM,WAAW,SAAS,aAAa,CAAC;AACxC,MAAM,WAAW,SAAS,aAAa,CAAC;AACxC,MAAM,yBAAyB,SAAS,aAAa,CAAC;AACtD,+EAA+E;AAE/E,SAAS,gBAAgB,CAAC,SAAS;AAEnC;;;;;;;GAOG,GACH,uBAAuB,gBAAgB,CAAC,SAAS,CAAC;IACjD,MAAM,cAAc,MAAM,MAAM,CAAC,OAAO,CAAC;IACzC,IAAI,CAAC,aAAa;IAElB,MAAM,QAAQ,YAAY,EAAE;IAC5B,CAAA,GAAA,oCAAO,AAAD,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;QAAE,SAAS;IAAM;IAC1C,WAAW;IACX;AACD;AAEA,SAAS;IACR,MAAM,kBAAkB,SAAS,aAAa,CAAC;IAC/C,gBAAgB,SAAS,GAAG;IAE5B,IAAI,WAAW,CAAC;;aAEJ,EAAE,CAAA,GAAA,qCAAa,AAAD,EAAE;;;;;;;;;;;CAW5B,CAAC;IAED,uCAAuC;IACvC,gBAAgB,kBAAkB,CAAC,aAAa;IAChD,SAAS,IAAI,CAAC,WAAW,CAAC;AAC3B;AAEA;;;;;;;;;;;;;;CAcC,GACD,SAAS,WAAW,KAAK;IACxB,SAAS,OAAO,CAAC,OAAO,GAAG;IAC3B,SAAS,KAAK,CAAC,WAAW,GAAG,UAAU,SAAS,SAAS;IACzD,SAAS,SAAS,GAAG,UAAU,SAAS,SAAS;IACjD,IAAI,UAAU,QAAQ,SAAS,eAAe,CAAC;AAChD;AAEA,SAAS;IACR,iBAAiB,CAAC;IAClB,SAAS,SAAS,CAAC,MAAM,CAAC,sBAAsB;IAEhD,IAAI,gBAAgB,SAAS,IAAI,CAAC,gBAAgB,CAAC,SAAS;SACvD,SAAS,IAAI,CAAC,mBAAmB,CAAC,SAAS;AACjD;AAEA,SAAS,YAAY,KAAK;IACzB,IAAI,CAAC,SAAS,QAAQ,CAAC,MAAM,MAAM,KAAK,CAAC,SAAS,QAAQ,CAAC,MAAM,MAAM,GACtE;AAEF,EAEA;;;;;;;;;;;;;;;;;;;;;;;EAuBE;;;A,C,S,M,E,O;I,I,O,W,c,O,G,E,O,yB;Q;K,E;S;Y;Q,Q;I;A,C,E,O,e,c,a,O,S,c,O,I,E,S,O;IC5HF,8DAAA,GACA,2DAAA,GACA,iCAAA,GACA;;8DAEA,GACA;IAEA,IAAI,CAACA,WAAWC,MAAX,EAAmBC,SAASC,IAC/B,MAAM,IAAIC,MAAM;IAGlB,IAAI,OAAOJ,WAAWK,OAAlB,KAA8B,eAAeC,OAAOC,cAAP,CAAsBP,WAAWK,OAAjC,MAA8CC,OAAOE,SAAtG,EAAiH;QAC/G,MAAMC,mDAAmD,2DAEzD,2EAFA;QAGA,wEAAA;QACA,6EAAA;QACA,4EAAA;QACA,8BAAA;QACA,MAAMC,WAAWC,CAAAA;YACf,+EAAA;YACA,6EAAA;YACA,aAAA;YACA,MAAMC,cAAc;gBAClB,UAAU;oBACR,SAAS;wBACP,WAAW;wBACX,WAAW;oBAFJ;oBAIT,YAAY;wBACV,WAAW;wBACX,WAAW;oBAFD;oBAIZ,OAAO;wBACL,WAAW;wBACX,WAAW;oBAFN;oBAIP,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;gBAbF;gBAkBV,aAAa;oBACX,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,OAAO;wBACL,WAAW;wBACX,WAAW;oBAFN;oBAIP,eAAe;wBACb,WAAW;wBACX,WAAW;oBAFE;oBAIf,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,cAAc;wBACZ,WAAW;wBACX,WAAW;oBAFC;oBAId,WAAW;wBACT,WAAW;wBACX,WAAW;oBAFF;oBAIX,QAAQ;wBACN,WAAW;wBACX,WAAW;oBAFL;oBAIR,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,cAAc;wBACZ,WAAW;wBACX,WAAW;oBAFC;oBAId,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;gBAzCC;gBA8Cb,iBAAiB;oBACf,WAAW;wBACT,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHf;oBAKX,UAAU;wBACR,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHhB;oBAKV,2BAA2B;wBACzB,WAAW;wBACX,WAAW;oBAFc;oBAI3B,gBAAgB;wBACd,WAAW;wBACX,WAAW;oBAFG;oBAIhB,YAAY;wBACV,WAAW;wBACX,WAAW;oBAFD;oBAIZ,YAAY;wBACV,WAAW;wBACX,WAAW;oBAFD;oBAIZ,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,2BAA2B;wBACzB,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHC;oBAK3B,gBAAgB;wBACd,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHV;oBAKhB,WAAW;wBACT,WAAW;wBACX,WAAW;oBAFF;oBAIX,YAAY;wBACV,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHd;oBAKZ,YAAY;wBACV,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHd;gBAlDG;gBAwDjB,gBAAgB;oBACd,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,eAAe;wBACb,WAAW;wBACX,WAAW;oBAFE;oBAIf,iBAAiB;wBACf,WAAW;wBACX,WAAW;oBAFI;oBAIjB,mBAAmB;wBACjB,WAAW;wBACX,WAAW;oBAFM;oBAInB,kBAAkB;wBAChB,WAAW;wBACX,WAAW;oBAFK;oBAIlB,iBAAiB;wBACf,WAAW;wBACX,WAAW;oBAFI;oBAIjB,sBAAsB;wBACpB,WAAW;wBACX,WAAW;oBAFS;oBAItB,mBAAmB;wBACjB,WAAW;wBACX,WAAW;oBAFM;oBAInB,oBAAoB;wBAClB,WAAW;wBACX,WAAW;oBAFO;oBAIpB,YAAY;wBACV,WAAW;wBACX,WAAW;oBAFD;gBArCE;gBA0ChB,YAAY;oBACV,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;gBADA;gBAMZ,gBAAgB;oBACd,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;gBATI;gBAchB,WAAW;oBACT,OAAO;wBACL,WAAW;wBACX,WAAW;oBAFN;oBAIP,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,sBAAsB;wBACpB,WAAW;wBACX,WAAW;oBAFS;oBAItB,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,OAAO;wBACL,WAAW;wBACX,WAAW;oBAFN;gBAjBE;gBAsBX,YAAY;oBACV,mBAAmB;wBACjB,QAAQ;4BACN,WAAW;4BACX,WAAW;4BACX,qBAAqB;wBAHf;oBADS;oBAOnB,UAAU;wBACR,UAAU;4BACR,WAAW;4BACX,WAAW;4BACX,qBAAqB;wBAHb;wBAKV,YAAY;4BACV,qBAAqB;gCACnB,WAAW;gCACX,WAAW;4BAFQ;wBADX;oBANJ;gBARA;gBAsBZ,aAAa;oBACX,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,YAAY;wBACV,WAAW;wBACX,WAAW;oBAFD;oBAIZ,SAAS;wBACP,WAAW;wBACX,WAAW;oBAFJ;oBAIT,eAAe;wBACb,WAAW;wBACX,WAAW;oBAFE;oBAIf,QAAQ;wBACN,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHlB;oBAKR,SAAS;wBACP,WAAW;wBACX,WAAW;oBAFJ;oBAIT,cAAc;wBACZ,WAAW;wBACX,WAAW;oBAFC;oBAId,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,QAAQ;wBACN,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHlB;gBAtCG;gBA4Cb,aAAa;oBACX,6BAA6B;wBAC3B,WAAW;wBACX,WAAW;oBAFgB;oBAI7B,4BAA4B;wBAC1B,WAAW;wBACX,WAAW;oBAFe;gBALjB;gBAUb,WAAW;oBACT,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,eAAe;wBACb,WAAW;wBACX,WAAW;oBAFE;oBAIf,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;gBArBD;gBA0BX,QAAQ;oBACN,kBAAkB;wBAChB,WAAW;wBACX,WAAW;oBAFK;oBAIlB,sBAAsB;wBACpB,WAAW;wBACX,WAAW;oBAFS;gBALhB;gBAUR,YAAY;oBACV,qBAAqB;wBACnB,WAAW;wBACX,WAAW;oBAFQ;gBADX;gBAMZ,QAAQ;oBACN,cAAc;wBACZ,WAAW;wBACX,WAAW;oBAFC;gBADR;gBAMR,cAAc;oBACZ,OAAO;wBACL,WAAW;wBACX,WAAW;oBAFN;oBAIP,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,WAAW;wBACT,WAAW;wBACX,WAAW;oBAFF;oBAIX,cAAc;wBACZ,WAAW;wBACX,WAAW;oBAFC;oBAId,iBAAiB;wBACf,WAAW;wBACX,WAAW;oBAFI;gBAjBL;gBAsBd,iBAAiB;oBACf,SAAS;wBACP,WAAW;wBACX,WAAW;oBAFJ;oBAIT,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,sBAAsB;wBACpB,WAAW;wBACX,WAAW;oBAFS;oBAItB,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;gBAjBK;gBAsBjB,cAAc;oBACZ,YAAY;wBACV,WAAW;wBACX,WAAW;oBAFD;oBAIZ,YAAY;wBACV,WAAW;wBACX,WAAW;oBAFD;oBAIZ,QAAQ;wBACN,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHlB;oBAKR,WAAW;wBACT,WAAW;wBACX,WAAW;oBAFF;oBAIX,YAAY;wBACV,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHd;oBAKZ,YAAY;wBACV,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHd;oBAKZ,QAAQ;wBACN,WAAW;wBACX,WAAW;wBACX,wBAAwB;oBAHlB;gBA5BI;gBAkCd,eAAe;oBACb,YAAY;wBACV,WAAW;wBACX,WAAW;oBAFD;oBAIZ,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,WAAW;wBACT,WAAW;wBACX,WAAW;oBAFF;gBAbE;gBAkBf,WAAW;oBACT,qBAAqB;wBACnB,WAAW;wBACX,WAAW;oBAFQ;oBAIrB,mBAAmB;wBACjB,WAAW;wBACX,WAAW;oBAFM;oBAInB,mBAAmB;wBACjB,WAAW;wBACX,WAAW;oBAFM;oBAInB,sBAAsB;wBACpB,WAAW;wBACX,WAAW;oBAFS;oBAItB,eAAe;wBACb,WAAW;wBACX,WAAW;oBAFE;oBAIf,qBAAqB;wBACnB,WAAW;wBACX,WAAW;oBAFQ;oBAIrB,mBAAmB;wBACjB,WAAW;wBACX,WAAW;oBAFM;gBAzBV;gBA8BX,YAAY;oBACV,cAAc;wBACZ,WAAW;wBACX,WAAW;oBAFC;oBAId,qBAAqB;wBACnB,WAAW;wBACX,WAAW;oBAFQ;oBAIrB,WAAW;wBACT,WAAW;wBACX,WAAW;oBAFF;gBATD;gBAcZ,WAAW;oBACT,SAAS;wBACP,SAAS;4BACP,WAAW;4BACX,WAAW;wBAFJ;wBAIT,OAAO;4BACL,WAAW;4BACX,WAAW;wBAFN;wBAIP,iBAAiB;4BACf,WAAW;4BACX,WAAW;wBAFI;wBAIjB,UAAU;4BACR,WAAW;4BACX,WAAW;wBAFH;wBAIV,OAAO;4BACL,WAAW;4BACX,WAAW;wBAFN;oBAjBA;oBAsBT,WAAW;wBACT,OAAO;4BACL,WAAW;4BACX,WAAW;wBAFN;wBAIP,iBAAiB;4BACf,WAAW;4BACX,WAAW;wBAFI;oBALR;oBAUX,QAAQ;wBACN,SAAS;4BACP,WAAW;4BACX,WAAW;wBAFJ;wBAIT,OAAO;4BACL,WAAW;4BACX,WAAW;wBAFN;wBAIP,iBAAiB;4BACf,WAAW;4BACX,WAAW;wBAFI;wBAIjB,UAAU;4BACR,WAAW;4BACX,WAAW;wBAFH;wBAIV,OAAO;4BACL,WAAW;4BACX,WAAW;wBAFN;oBAjBD;gBAjCC;gBAwDX,QAAQ;oBACN,qBAAqB;wBACnB,WAAW;wBACX,WAAW;oBAFQ;oBAIrB,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,kBAAkB;wBAChB,WAAW;wBACX,WAAW;oBAFK;oBAIlB,WAAW;wBACT,WAAW;wBACX,WAAW;oBAFF;oBAIX,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,iBAAiB;wBACf,WAAW;wBACX,WAAW;oBAFI;oBAIjB,OAAO;wBACL,WAAW;wBACX,WAAW;oBAFN;oBAIP,cAAc;wBACZ,WAAW;wBACX,WAAW;oBAFC;oBAId,WAAW;wBACT,WAAW;wBACX,WAAW;oBAFF;oBAIX,mBAAmB;wBACjB,WAAW;wBACX,WAAW;oBAFM;oBAInB,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,QAAQ;wBACN,WAAW;wBACX,WAAW;oBAFL;oBAIR,SAAS;wBACP,WAAW;wBACX,WAAW;oBAFJ;oBAIT,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,aAAa;wBACX,WAAW;wBACX,WAAW;oBAFA;oBAIb,eAAe;wBACb,WAAW;wBACX,WAAW;oBAFE;oBAIf,WAAW;wBACT,WAAW;wBACX,WAAW;oBAFF;oBAIX,mBAAmB;wBACjB,WAAW;wBACX,WAAW;oBAFM;oBAInB,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;gBAzFJ;gBA8FR,YAAY;oBACV,OAAO;wBACL,WAAW;wBACX,WAAW;oBAFN;gBADG;gBAMZ,iBAAiB;oBACf,gBAAgB;wBACd,WAAW;wBACX,WAAW;oBAFG;oBAIhB,YAAY;wBACV,WAAW;wBACX,WAAW;oBAFD;gBALG;gBAUjB,cAAc;oBACZ,0BAA0B;wBACxB,WAAW;wBACX,WAAW;oBAFa;gBADd;gBAMd,WAAW;oBACT,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,OAAO;wBACL,WAAW;wBACX,WAAW;oBAFN;oBAIP,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,cAAc;wBACZ,WAAW;wBACX,WAAW;oBAFC;oBAId,kBAAkB;wBAChB,WAAW;wBACX,WAAW;oBAFK;oBAIlB,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;oBAIV,UAAU;wBACR,WAAW;wBACX,WAAW;oBAFH;gBAzBD;YAjoBO;YAiqBpB,IAAIN,OAAOO,IAAP,CAAYD,aAAaE,MAAzB,KAAoC,GACtC,MAAM,IAAIV,MAAM;YAGlB;;;;;;;;;OASJ,GACI,MAAMW,uBAAuBC;gBAC3BC,YAAYC,UAAD,EAAaC,KAAb,CAAgC;oBACzC,KAAA,CAAMA;oBACN,IAAA,CAAKD,UAAL,GAAkBA;gBACnB;gBAEDG,IAAIC,GAAD,EAAM;oBACP,IAAI,CAAC,IAAA,CAAKC,GAAL,CAASD,MACZ,IAAA,CAAKE,GAAL,CAASF,KAAK,IAAA,CAAKJ,UAAL,CAAgBI;oBAGhC,OAAO,KAAA,CAAMD,IAAIC;gBAClB;YAZkC;YAerC;;;;;;OAMJ,GACI,MAAMG,aAAaC,CAAAA;gBACjB,OAAOA,SAAS,OAAOA,UAAU,YAAY,OAAOA,MAAMC,IAAb,KAAsB;YACpE;YAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA8BJ,GACI,MAAMC,eAAe,CAACC,SAASC;gBAC7B,OAAO,CAAC,GAAGC;oBACT,IAAIpB,cAAcT,OAAd,CAAsB8B,SAA1B,EACEH,QAAQI,MAAR,CAAe,IAAI7B,MAAMO,cAAcT,OAAd,CAAsB8B,SAAtB,CAAgCE,OAA1C;yBACV,IAAIJ,SAASK,iBAAT,IACCJ,aAAajB,MAAb,IAAuB,KAAKgB,SAASK,iBAAT,KAA+B,OACrEN,QAAQO,OAAR,CAAgBL,YAAY,CAAC,EAA7B;yBAEAF,QAAQO,OAAR,CAAgBL;gBAEnB;YACF;YAED,MAAMM,qBAAsBC,CAAAA,UAAYA,WAAW,IAAI,aAAa;YAEpE;;;;;;;;;;;;;;;;;;;;;;;;;OAyBJ,GACI,MAAMC,oBAAoB,CAACC,MAAMV;gBAC/B,OAAO,SAASW,qBAAqBC,MAA9B,EAAsC,GAAGC,IAAzC;oBACL,IAAIA,KAAK7B,MAAL,GAAcgB,SAASc,OAA3B,EACE,MAAM,IAAIxC,MAAO,CAAA,kBAAA,EAAoB0B,SAASc,OAAQ,CAAA,CAAA,EAAGP,mBAAmBP,SAASc,OAAV,EAAmB,KAAA,EAAOJ,KAAK,QAAA,EAAUG,KAAK7B,MAAO,CAAA,CAA1H;oBAGR,IAAI6B,KAAK7B,MAAL,GAAcgB,SAASe,OAA3B,EACE,MAAM,IAAIzC,MAAO,CAAA,iBAAA,EAAmB0B,SAASe,OAAQ,CAAA,CAAA,EAAGR,mBAAmBP,SAASe,OAAV,EAAmB,KAAA,EAAOL,KAAK,QAAA,EAAUG,KAAK7B,MAAO,CAAA,CAAzH;oBAGR,OAAO,IAAIgC,QAAQ,CAACV,SAASH;wBAC3B,IAAIH,SAASiB,oBAAb,EACE,2FAAA;wBACA,sFAAA;wBACA,uDAAA;wBACA,IAAI;4BACFL,MAAM,CAACF,KAAP,IAAgBG,MAAMf,aAAa;gCAACQ;gCAASH;4BAAV,GAAmBH;wBACvD,EAAC,OAAOkB,SAAS;4BAChBC,QAAQC,IAAR,CAAc,CAAA,EAAEV,KAAK,4DAAA,CAAR,GACA,gDAAgDQ;4BAE7DN,MAAM,CAACF,KAAP,IAAgBG,OAEhB,6EAFAD;4BAGA,wCAAA;4BACAZ,SAASiB,oBAAT,GAAgC;4BAChCjB,SAASqB,UAAT,GAAsB;4BAEtBf;wBACD;6BACI,IAAIN,SAASqB,UAAb,EAAyB;4BAC9BT,MAAM,CAACF,KAAP,IAAgBG;4BAChBP;wBACD,OACCM,MAAM,CAACF,KAAP,IAAgBG,MAAMf,aAAa;4BAACQ;4BAASH;wBAAV,GAAmBH;oBAEzD;gBACF;YACF;YAED;;;;;;;;;;;;;;;;;;OAkBJ,GACI,MAAMsB,aAAa,CAACV,QAAQW,QAAQC;gBAClC,OAAO,IAAIC,MAAMF,QAAQ;oBACvBG,OAAMC,YAAD,EAAeC,OAAf,EAAwBf,IAAxB;wBACH,OAAOW,QAAQK,IAAR,CAAaD,SAAShB,WAAWC;oBACzC;gBAHsB;YAK1B;YAED,IAAIiB,iBAAiBC,SAASF,IAAT,CAAcG,IAAd,CAAmBxD,OAAOE,SAAP,CAAiBoD,cAApC;YAErB;;;;;;;;;;;;;;;;;;;;;;OAsBJ,GACI,MAAMG,aAAa,CAACrB,QAAQsB,WAAW,CAAA,CAApB,EAAwBlC,WAAW,CAAA,CAAnC;gBACjB,IAAImC,QAAQ3D,OAAO4D,MAAP,CAAc;gBAC1B,IAAIC,WAAW;oBACb5C,KAAI6C,WAAD,EAAcC,IAAd;wBACD,OAAOA,QAAQ3B,UAAU2B,QAAQJ;oBAClC;oBAED5C,KAAI+C,WAAD,EAAcC,IAAd,EAAoBC,QAApB;wBACD,IAAID,QAAQJ,OACV,OAAOA,KAAK,CAACI,KAAb;wBAGF,IAAI,CAAEA,CAAAA,QAAQ3B,MAAAA,GACZ,OAAOtB;wBAGT,IAAIM,QAAQgB,MAAM,CAAC2B,KAAnB;wBAEA,IAAI,OAAO3C,UAAU,YAAY;4BAC/B,oEAAA;4BACA,gBAAA;4BAEA,IAAI,OAAOsC,QAAQ,CAACK,KAAhB,KAA0B,YAC5B,kDAAA;4BACA3C,QAAQ0B,WAAWV,QAAQA,MAAM,CAAC2B,KAAhB,EAAuBL,QAAQ,CAACK,KAAhC;iCACb,IAAIT,eAAe9B,UAAUuC,OAAO;gCACzC,8DAAA;gCACA,0BAAA;gCACA,IAAIf,UAAUf,kBAAkB8B,MAAMvC,QAAQ,CAACuC,KAAhB;gCAC/B3C,QAAQ0B,WAAWV,QAAQA,MAAM,CAAC2B,KAAhB,EAAuBf;4BAC1C,OACC,gEAAA;4BACA,mDAAA;4BACA5B,QAAQA,MAAMoC,IAAN,CAAWpB;wBAEtB,OAAM,IAAI,OAAOhB,UAAU,YAAYA,UAAU,QACtCkC,CAAAA,eAAeI,UAAUK,SACzBT,eAAe9B,UAAUuC,KAAX,GACxB,sEAAA;wBACA,oEAAA;wBACA,YAAA;wBACA3C,QAAQqC,WAAWrC,OAAOsC,QAAQ,CAACK,KAAjB,EAAwBvC,QAAQ,CAACuC,KAAjC;6BACb,IAAIT,eAAe9B,UAAU,MAClC,sCAAA;wBACAJ,QAAQqC,WAAWrC,OAAOsC,QAAQ,CAACK,KAAjB,EAAwBvC,QAAQ,CAAC,IAAjC;6BACb;4BACL,sDAAA;4BACA,uDAAA;4BACAxB,OAAOiE,cAAP,CAAsBN,OAAOI,MAAM;gCACjCG,cAAc;gCACdC,YAAY;gCACZpD;oCACE,OAAOqB,MAAM,CAAC2B,KAAd;gCACD;gCACD7C,KAAIE,KAAD;oCACDgB,MAAM,CAAC2B,KAAP,GAAe3C;gCAChB;4BARgC;4BAWnC,OAAOA;wBACR;wBAEDuC,KAAK,CAACI,KAAN,GAAc3C;wBACd,OAAOA;oBACR;oBAEDF,KAAI4C,WAAD,EAAcC,IAAd,EAAoB3C,KAApB,EAA2B4C,QAA3B;wBACD,IAAID,QAAQJ,OACVA,KAAK,CAACI,KAAN,GAAc3C;6BAEdgB,MAAM,CAAC2B,KAAP,GAAe3C;wBAEjB,OAAO;oBACR;oBAED6C,gBAAeH,WAAD,EAAcC,IAAd,EAAoBK,IAApB;wBACZ,OAAOC,QAAQJ,cAAR,CAAuBN,OAAOI,MAAMK;oBAC5C;oBAEDE,gBAAeR,WAAD,EAAcC,IAAd;wBACZ,OAAOM,QAAQC,cAAR,CAAuBX,OAAOI;oBACtC;gBA/EY,GAkFf,yEAlFe;gBAmFf,uEAAA;gBACA,kEAAA;gBACA,gEAAA;gBACA,2DAAA;gBACA,0EAAA;gBACA,EAAA;gBACA,qEAAA;gBACA,uEAAA;gBACA,yCAAA;gBACA,IAAID,cAAc9D,OAAO4D,MAAP,CAAcxB;gBAChC,OAAO,IAAIa,MAAMa,aAAaD;YAC/B;YAED;;;;;;;;;;;;;;;OAeJ,GACI,MAAMU,YAAYC,CAAAA,aAAe,CAAA;oBAC/BC,aAAYrC,MAAD,EAASsC,QAAT,EAAmB,GAAGrC,IAAtB;wBACTD,OAAOqC,WAAP,CAAmBD,WAAWzD,GAAX,CAAe2D,cAAcrC;oBACjD;oBAEDsC,aAAYvC,MAAD,EAASsC,QAAT;wBACT,OAAOtC,OAAOuC,WAAP,CAAmBH,WAAWzD,GAAX,CAAe2D;oBAC1C;oBAEDE,gBAAexC,MAAD,EAASsC,QAAT;wBACZtC,OAAOwC,cAAP,CAAsBJ,WAAWzD,GAAX,CAAe2D;oBACtC;gBAX8B,CAAA;YAcjC,MAAMG,4BAA4B,IAAIpE,eAAeiE,CAAAA;gBACnD,IAAI,OAAOA,aAAa,YACtB,OAAOA;gBAGT;;;;;;;SAON,GACM,OAAO,SAASI,kBAAkBC,GAA3B;oBACL,MAAMC,aAAavB,WAAWsB,KAAK,CAAnC,GAAsD;wBACpDE,YAAY;4BACV3C,SAAS;4BACTC,SAAS;wBAFC;oBADwC;oBAMtDmC,SAASM;gBACV;YACF;YAED,MAAME,oBAAoB,IAAIzE,eAAeiE,CAAAA;gBAC3C,IAAI,OAAOA,aAAa,YACtB,OAAOA;gBAGT;;;;;;;;;;;;;;;;SAgBN,GACM,OAAO,SAASS,UAAUvD,OAAnB,EAA4BwD,MAA5B,EAAoCC,YAApC;oBACL,IAAIC,sBAAsB;oBAE1B,IAAIC;oBACJ,IAAIC,sBAAsB,IAAIhD,QAAQV,CAAAA;wBACpCyD,sBAAsB,SAASE,QAAT;4BACpBH,sBAAsB;4BACtBxD,QAAQ2D;wBACT;oBACF;oBAED,IAAIC;oBACJ,IAAI;wBACFA,SAAShB,SAAS9C,SAASwD,QAAQG;oBACpC,EAAC,OAAOI,KAAK;wBACZD,SAASlD,QAAQb,MAAR,CAAegE;oBACzB;oBAED,MAAMC,mBAAmBF,WAAW,QAAQvE,WAAWuE,SAEvD,+DAFA;oBAGA,yDAAA;oBACA,6DAAA;oBACA,IAAIA,WAAW,QAAQ,CAACE,oBAAoB,CAACN,qBAC3C,OAAO;qBAGT,6DAFC;oBAGD,iEAAA;oBACA,iEAAA;oBACA,YAAA;oBACA,MAAMO,qBAAsBtE,CAAAA;wBAC1BA,QAAQF,IAAR,CAAayE,CAAAA;4BACX,0BAAA;4BACAT,aAAaS;wBACd,GAAEC,CAAAA;4BACD,gEAAA;4BACA,2DAAA;4BACA,IAAInE;4BACJ,IAAImE,SAAUA,CAAAA,iBAAiBjG,SAC3B,OAAOiG,MAAMnE,OAAb,KAAyB,QAAA,GAC3BA,UAAUmE,MAAMnE,OAAhB;iCAEAA,UAAU;4BAGZyD,aAAa;gCACXW,mCAAmC;gCACnCpE;4BAFW;wBAId,GAAEqE,KAlBH,CAkBSN,CAAAA;4BACP,gEAAA;4BACAhD,QAAQoD,KAAR,CAAc,2CAA2CJ;wBAC1D;oBACF,GAED,mEAFC;oBAGD,wEAAA;oBACA,iDAAA;oBACA,IAAIC,kBACFC,mBAAmBH;yBAEnBG,mBAAmBL;qBAGrB,iDAFC;oBAGD,OAAO;gBACR;YACF;YAED,MAAMU,6BAA6B,CAAC,EAACvE,MAAD,EAASG,OAAAA,EAAV,EAAoBqE;gBACrD,IAAI9F,cAAcT,OAAd,CAAsB8B,SAA1B;oBACE,gFAAA;oBACA,0CAAA;oBACA,kEAAA;oBACA,IAAIrB,cAAcT,OAAd,CAAsB8B,SAAtB,CAAgCE,OAAhC,KAA4CzB,kDAC9C2B;yBAEAH,OAAO,IAAI7B,MAAMO,cAAcT,OAAd,CAAsB8B,SAAtB,CAAgCE,OAA1C;uBAEJ,IAAIuE,SAASA,MAAMH,iCAAnB,EACL,yDAAA;gBACA,qBAAA;gBACArE,OAAO,IAAI7B,MAAMqG,MAAMvE,OAAhB;qBAEPE,QAAQqE;YAEX;YAED,MAAMC,qBAAqB,CAAClE,MAAMV,UAAU6E,iBAAiB,GAAGhE;gBAC9D,IAAIA,KAAK7B,MAAL,GAAcgB,SAASc,OAA3B,EACE,MAAM,IAAIxC,MAAO,CAAA,kBAAA,EAAoB0B,SAASc,OAAQ,CAAA,CAAA,EAAGP,mBAAmBP,SAASc,OAAV,EAAmB,KAAA,EAAOJ,KAAK,QAAA,EAAUG,KAAK7B,MAAO,CAAA,CAA1H;gBAGR,IAAI6B,KAAK7B,MAAL,GAAcgB,SAASe,OAA3B,EACE,MAAM,IAAIzC,MAAO,CAAA,iBAAA,EAAmB0B,SAASe,OAAQ,CAAA,CAAA,EAAGR,mBAAmBP,SAASe,OAAV,EAAmB,KAAA,EAAOL,KAAK,QAAA,EAAUG,KAAK7B,MAAO,CAAA,CAAzH;gBAGR,OAAO,IAAIgC,QAAQ,CAACV,SAASH;oBAC3B,MAAM2E,YAAYJ,2BAA2B1C,IAA3B,CAAgC,MAAM;wBAAC1B;wBAASH;oBAAV;oBACxDU,KAAKkE,IAAL,CAAUD;oBACVD,gBAAgBG,WAAhB,IAA+BnE;gBAChC;YACF;YAED,MAAMoE,iBAAiB;gBACrBC,UAAU;oBACRC,SAAS;wBACP7B,mBAAmBP,UAAUM;oBADtB;gBADD;gBAKVjF,SAAS;oBACPuF,WAAWZ,UAAUW;oBACrB0B,mBAAmBrC,UAAUW;oBAC7BsB,aAAaJ,mBAAmB5C,IAAnB,CAAwB,MAAM,eAAe;wBAAClB,SAAS;wBAAGC,SAAS;oBAAtB;gBAHnD;gBAKTsE,MAAM;oBACJL,aAAaJ,mBAAmB5C,IAAnB,CAAwB,MAAM,eAAe;wBAAClB,SAAS;wBAAGC,SAAS;oBAAtB;gBADtD;YAXe;YAevB,MAAMuE,kBAAkB;gBACtBC,OAAO;oBAACzE,SAAS;oBAAGC,SAAS;gBAAtB;gBACPxB,KAAK;oBAACuB,SAAS;oBAAGC,SAAS;gBAAtB;gBACLrB,KAAK;oBAACoB,SAAS;oBAAGC,SAAS;gBAAtB;YAHiB;YAKxBjC,YAAY0G,OAAZ,GAAsB;gBACpBL,SAAS;oBAAC,KAAKG;gBAAN;gBACTG,UAAU;oBAAC,KAAKH;gBAAN;gBACVI,UAAU;oBAAC,KAAKJ;gBAAN;YAHU;YAMtB,OAAOrD,WAAWpD,eAAeoG,gBAAgBnG;QAClD,GAED,yEAFC;QAGD,+BAAA;QACA6G,QAAOC,OAAP,GAAiBhH,SAAST;IAC3B,OACCwH,QAAOC,OAAP,GAAiB1H,WAAWK,OAA5B;A;;;AC7rCF,OAAO,OAAO,GAAG,QAAQ,oBAAwB,YAAY,CAAC,WAAW,sCAAsC,MAAM,KAAK,GAAG;;;ACA7H;AAEA,IAAI,YAAY,CAAC;AACjB,SAAS,mBAAmB,EAAE;IAC5B,IAAI,QAAQ,SAAS,CAAC,GAAG;IACzB,IAAI,CAAC,OAAO;QACV,QAAQ;QACR,SAAS,CAAC,GAAG,GAAG;IAClB;IACA,OAAO;AACT;AACA,SAAS;IACP,IAAI;QACF,MAAM,IAAI;IACZ,EAAE,OAAO,KAAK;QACZ,IAAI,UAAU,AAAC,CAAA,KAAK,IAAI,KAAK,AAAD,EAAG,KAAK,CAAC;QACrC,IAAI,SACF,2EAA2E;QAC3E,mEAAmE;QACnE,OAAO,WAAW,OAAO,CAAC,EAAE;IAEhC;IACA,OAAO;AACT;AACA,SAAS,WAAW,GAAG;IACrB,OAAO,AAAC,CAAA,KAAK,GAAE,EAAG,OAAO,CAAC,2EAA2E,QAAQ;AAC/G;AAEA,kFAAkF;AAClF,SAAS,UAAU,GAAG;IACpB,IAAI,UAAU,AAAC,CAAA,KAAK,GAAE,EAAG,KAAK,CAAC;IAC/B,IAAI,CAAC,SACH,MAAM,IAAI,MAAM;IAElB,OAAO,OAAO,CAAC,EAAE;AACnB;AACA,QAAQ,YAAY,GAAG;AACvB,QAAQ,UAAU,GAAG;AACrB,QAAQ,SAAS,GAAG;;;ACtCpB,QAAQ,cAAc,GAAG,SAAU,CAAC;IAClC,OAAO,KAAK,EAAE,UAAU,GAAG,IAAI;QAAC,SAAS;IAAC;AAC5C;AAEA,QAAQ,iBAAiB,GAAG,SAAU,CAAC;IACrC,OAAO,cAAc,CAAC,GAAG,cAAc;QAAC,OAAO;IAAI;AACrD;AAEA,QAAQ,SAAS,GAAG,SAAU,MAAM,EAAE,IAAI;IACxC,OAAO,IAAI,CAAC,QAAQ,OAAO,CAAC,SAAU,GAAG;QACvC,IACE,QAAQ,aACR,QAAQ,gBACR,OAAO,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,MAE3C;QAGF,OAAO,cAAc,CAAC,MAAM,KAAK;YAC/B,YAAY;YACZ,KAAK;gBACH,OAAO,MAAM,CAAC,IAAI;YACpB;QACF;IACF;IAEA,OAAO;AACT;AAEA,QAAQ,MAAM,GAAG,SAAU,IAAI,EAAE,QAAQ,EAAE,GAAG;IAC5C,OAAO,cAAc,CAAC,MAAM,UAAU;QACpC,YAAY;QACZ,KAAK;IACP;AACF","sources":["node_modules/@parcel/runtime-browser-hmr/lib/runtime-153c4e08a4ad6222.js","src/js/content.js","node_modules/webextension-polyfill/dist/browser-polyfill.js","node_modules/@parcel/runtime-js/lib/runtime-8e99fa0d17a0041e.js","node_modules/@parcel/runtime-js/lib/helpers/bundle-url.js","node_modules/@parcel/transformer-js/src/esmodule-helpers.js"],"sourcesContent":["var HMR_HOST = \"localhost\";var HMR_PORT = 1234;var HMR_SECURE = false;var HMR_ENV_HASH = \"ddf6e0724bd358bd\";module.bundle.HMR_BUNDLE_ID = \"45b44acd4a18726a\";\"use strict\";\n\n/* global HMR_HOST, HMR_PORT, HMR_ENV_HASH, HMR_SECURE, chrome, browser, __parcel__import__, __parcel__importScripts__, ServiceWorkerGlobalScope */\n/*::\nimport type {\n  HMRAsset,\n  HMRMessage,\n} from '@parcel/reporter-dev-server/src/HMRServer.js';\ninterface ParcelRequire {\n  (string): mixed;\n  cache: {|[string]: ParcelModule|};\n  hotData: {|[string]: mixed|};\n  Module: any;\n  parent: ?ParcelRequire;\n  isParcelRequire: true;\n  modules: {|[string]: [Function, {|[string]: string|}]|};\n  HMR_BUNDLE_ID: string;\n  root: ParcelRequire;\n}\ninterface ParcelModule {\n  hot: {|\n    data: mixed,\n    accept(cb: (Function) => void): void,\n    dispose(cb: (mixed) => void): void,\n    // accept(deps: Array<string> | string, cb: (Function) => void): void,\n    // decline(): void,\n    _acceptCallbacks: Array<(Function) => void>,\n    _disposeCallbacks: Array<(mixed) => void>,\n  |};\n}\ninterface ExtensionContext {\n  runtime: {|\n    reload(): void,\n    getURL(url: string): string;\n    getManifest(): {manifest_version: number, ...};\n  |};\n}\ndeclare var module: {bundle: ParcelRequire, ...};\ndeclare var HMR_HOST: string;\ndeclare var HMR_PORT: string;\ndeclare var HMR_ENV_HASH: string;\ndeclare var HMR_SECURE: boolean;\ndeclare var chrome: ExtensionContext;\ndeclare var browser: ExtensionContext;\ndeclare var __parcel__import__: (string) => Promise<void>;\ndeclare var __parcel__importScripts__: (string) => Promise<void>;\ndeclare var globalThis: typeof self;\ndeclare var ServiceWorkerGlobalScope: Object;\n*/\nvar OVERLAY_ID = '__parcel__error__overlay__';\nvar OldModule = module.bundle.Module;\nfunction Module(moduleName) {\n  OldModule.call(this, moduleName);\n  this.hot = {\n    data: module.bundle.hotData[moduleName],\n    _acceptCallbacks: [],\n    _disposeCallbacks: [],\n    accept: function (fn) {\n      this._acceptCallbacks.push(fn || function () {});\n    },\n    dispose: function (fn) {\n      this._disposeCallbacks.push(fn);\n    }\n  };\n  module.bundle.hotData[moduleName] = undefined;\n}\nmodule.bundle.Module = Module;\nmodule.bundle.hotData = {};\nvar checkedAssets /*: {|[string]: boolean|} */, assetsToDispose /*: Array<[ParcelRequire, string]> */, assetsToAccept /*: Array<[ParcelRequire, string]> */;\n\nfunction getHostname() {\n  return HMR_HOST || (location.protocol.indexOf('http') === 0 ? location.hostname : 'localhost');\n}\nfunction getPort() {\n  return HMR_PORT || location.port;\n}\n\n// eslint-disable-next-line no-redeclare\nvar parent = module.bundle.parent;\nif ((!parent || !parent.isParcelRequire) && typeof WebSocket !== 'undefined') {\n  var hostname = getHostname();\n  var port = getPort();\n  var protocol = HMR_SECURE || location.protocol == 'https:' && !['localhost', '127.0.0.1', '0.0.0.0'].includes(hostname) ? 'wss' : 'ws';\n  var ws;\n  try {\n    ws = new WebSocket(protocol + '://' + hostname + (port ? ':' + port : '') + '/');\n  } catch (err) {\n    if (err.message) {\n      console.error(err.message);\n    }\n    ws = {};\n  }\n\n  // Web extension context\n  var extCtx = typeof browser === 'undefined' ? typeof chrome === 'undefined' ? null : chrome : browser;\n\n  // Safari doesn't support sourceURL in error stacks.\n  // eval may also be disabled via CSP, so do a quick check.\n  var supportsSourceURL = false;\n  try {\n    (0, eval)('throw new Error(\"test\"); //# sourceURL=test.js');\n  } catch (err) {\n    supportsSourceURL = err.stack.includes('test.js');\n  }\n\n  // $FlowFixMe\n  ws.onmessage = async function (event /*: {data: string, ...} */) {\n    checkedAssets = {} /*: {|[string]: boolean|} */;\n    assetsToAccept = [];\n    assetsToDispose = [];\n    var data /*: HMRMessage */ = JSON.parse(event.data);\n    if (data.type === 'update') {\n      // Remove error overlay if there is one\n      if (typeof document !== 'undefined') {\n        removeErrorOverlay();\n      }\n      let assets = data.assets.filter(asset => asset.envHash === HMR_ENV_HASH);\n\n      // Handle HMR Update\n      let handled = assets.every(asset => {\n        return asset.type === 'css' || asset.type === 'js' && hmrAcceptCheck(module.bundle.root, asset.id, asset.depsByBundle);\n      });\n      if (handled) {\n        console.clear();\n\n        // Dispatch custom event so other runtimes (e.g React Refresh) are aware.\n        if (typeof window !== 'undefined' && typeof CustomEvent !== 'undefined') {\n          window.dispatchEvent(new CustomEvent('parcelhmraccept'));\n        }\n        await hmrApplyUpdates(assets);\n\n        // Dispose all old assets.\n        let processedAssets = {} /*: {|[string]: boolean|} */;\n        for (let i = 0; i < assetsToDispose.length; i++) {\n          let id = assetsToDispose[i][1];\n          if (!processedAssets[id]) {\n            hmrDispose(assetsToDispose[i][0], id);\n            processedAssets[id] = true;\n          }\n        }\n\n        // Run accept callbacks. This will also re-execute other disposed assets in topological order.\n        processedAssets = {};\n        for (let i = 0; i < assetsToAccept.length; i++) {\n          let id = assetsToAccept[i][1];\n          if (!processedAssets[id]) {\n            hmrAccept(assetsToAccept[i][0], id);\n            processedAssets[id] = true;\n          }\n        }\n      } else fullReload();\n    }\n    if (data.type === 'error') {\n      // Log parcel errors to console\n      for (let ansiDiagnostic of data.diagnostics.ansi) {\n        let stack = ansiDiagnostic.codeframe ? ansiDiagnostic.codeframe : ansiDiagnostic.stack;\n        console.error('🚨 [parcel]: ' + ansiDiagnostic.message + '\\n' + stack + '\\n\\n' + ansiDiagnostic.hints.join('\\n'));\n      }\n      if (typeof document !== 'undefined') {\n        // Render the fancy html overlay\n        removeErrorOverlay();\n        var overlay = createErrorOverlay(data.diagnostics.html);\n        // $FlowFixMe\n        document.body.appendChild(overlay);\n      }\n    }\n  };\n  ws.onerror = function (e) {\n    if (e.message) {\n      console.error(e.message);\n    }\n  };\n  ws.onclose = function () {\n    console.warn('[parcel] 🚨 Connection to the HMR server was lost');\n  };\n}\nfunction removeErrorOverlay() {\n  var overlay = document.getElementById(OVERLAY_ID);\n  if (overlay) {\n    overlay.remove();\n    console.log('[parcel] ✨ Error resolved');\n  }\n}\nfunction createErrorOverlay(diagnostics) {\n  var overlay = document.createElement('div');\n  overlay.id = OVERLAY_ID;\n  let errorHTML = '<div style=\"background: black; opacity: 0.85; font-size: 16px; color: white; position: fixed; height: 100%; width: 100%; top: 0px; left: 0px; padding: 30px; font-family: Menlo, Consolas, monospace; z-index: 9999;\">';\n  for (let diagnostic of diagnostics) {\n    let stack = diagnostic.frames.length ? diagnostic.frames.reduce((p, frame) => {\n      return `${p}\n<a href=\"/__parcel_launch_editor?file=${encodeURIComponent(frame.location)}\" style=\"text-decoration: underline; color: #888\" onclick=\"fetch(this.href); return false\">${frame.location}</a>\n${frame.code}`;\n    }, '') : diagnostic.stack;\n    errorHTML += `\n      <div>\n        <div style=\"font-size: 18px; font-weight: bold; margin-top: 20px;\">\n          🚨 ${diagnostic.message}\n        </div>\n        <pre>${stack}</pre>\n        <div>\n          ${diagnostic.hints.map(hint => '<div>💡 ' + hint + '</div>').join('')}\n        </div>\n        ${diagnostic.documentation ? `<div>📝 <a style=\"color: violet\" href=\"${diagnostic.documentation}\" target=\"_blank\">Learn more</a></div>` : ''}\n      </div>\n    `;\n  }\n  errorHTML += '</div>';\n  overlay.innerHTML = errorHTML;\n  return overlay;\n}\nfunction fullReload() {\n  if ('reload' in location) {\n    location.reload();\n  } else if (extCtx && extCtx.runtime && extCtx.runtime.reload) {\n    extCtx.runtime.reload();\n  }\n}\nfunction getParents(bundle, id) /*: Array<[ParcelRequire, string]> */{\n  var modules = bundle.modules;\n  if (!modules) {\n    return [];\n  }\n  var parents = [];\n  var k, d, dep;\n  for (k in modules) {\n    for (d in modules[k][1]) {\n      dep = modules[k][1][d];\n      if (dep === id || Array.isArray(dep) && dep[dep.length - 1] === id) {\n        parents.push([bundle, k]);\n      }\n    }\n  }\n  if (bundle.parent) {\n    parents = parents.concat(getParents(bundle.parent, id));\n  }\n  return parents;\n}\nfunction updateLink(link) {\n  var href = link.getAttribute('href');\n  if (!href) {\n    return;\n  }\n  var newLink = link.cloneNode();\n  newLink.onload = function () {\n    if (link.parentNode !== null) {\n      // $FlowFixMe\n      link.parentNode.removeChild(link);\n    }\n  };\n  newLink.setAttribute('href',\n  // $FlowFixMe\n  href.split('?')[0] + '?' + Date.now());\n  // $FlowFixMe\n  link.parentNode.insertBefore(newLink, link.nextSibling);\n}\nvar cssTimeout = null;\nfunction reloadCSS() {\n  if (cssTimeout) {\n    return;\n  }\n  cssTimeout = setTimeout(function () {\n    var links = document.querySelectorAll('link[rel=\"stylesheet\"]');\n    for (var i = 0; i < links.length; i++) {\n      // $FlowFixMe[incompatible-type]\n      var href /*: string */ = links[i].getAttribute('href');\n      var hostname = getHostname();\n      var servedFromHMRServer = hostname === 'localhost' ? new RegExp('^(https?:\\\\/\\\\/(0.0.0.0|127.0.0.1)|localhost):' + getPort()).test(href) : href.indexOf(hostname + ':' + getPort());\n      var absolute = /^https?:\\/\\//i.test(href) && href.indexOf(location.origin) !== 0 && !servedFromHMRServer;\n      if (!absolute) {\n        updateLink(links[i]);\n      }\n    }\n    cssTimeout = null;\n  }, 50);\n}\nfunction hmrDownload(asset) {\n  if (asset.type === 'js') {\n    if (typeof document !== 'undefined') {\n      let script = document.createElement('script');\n      script.src = asset.url + '?t=' + Date.now();\n      if (asset.outputFormat === 'esmodule') {\n        script.type = 'module';\n      }\n      return new Promise((resolve, reject) => {\n        var _document$head;\n        script.onload = () => resolve(script);\n        script.onerror = reject;\n        (_document$head = document.head) === null || _document$head === void 0 || _document$head.appendChild(script);\n      });\n    } else if (typeof importScripts === 'function') {\n      // Worker scripts\n      if (asset.outputFormat === 'esmodule') {\n        return __parcel__import__(asset.url + '?t=' + Date.now());\n      } else {\n        return new Promise((resolve, reject) => {\n          try {\n            __parcel__importScripts__(asset.url + '?t=' + Date.now());\n            resolve();\n          } catch (err) {\n            reject(err);\n          }\n        });\n      }\n    }\n  }\n}\nasync function hmrApplyUpdates(assets) {\n  global.parcelHotUpdate = Object.create(null);\n  let scriptsToRemove;\n  try {\n    // If sourceURL comments aren't supported in eval, we need to load\n    // the update from the dev server over HTTP so that stack traces\n    // are correct in errors/logs. This is much slower than eval, so\n    // we only do it if needed (currently just Safari).\n    // https://bugs.webkit.org/show_bug.cgi?id=137297\n    // This path is also taken if a CSP disallows eval.\n    if (!supportsSourceURL) {\n      let promises = assets.map(asset => {\n        var _hmrDownload;\n        return (_hmrDownload = hmrDownload(asset)) === null || _hmrDownload === void 0 ? void 0 : _hmrDownload.catch(err => {\n          // Web extension fix\n          if (extCtx && extCtx.runtime && extCtx.runtime.getManifest().manifest_version == 3 && typeof ServiceWorkerGlobalScope != 'undefined' && global instanceof ServiceWorkerGlobalScope) {\n            extCtx.runtime.reload();\n            return;\n          }\n          throw err;\n        });\n      });\n      scriptsToRemove = await Promise.all(promises);\n    }\n    assets.forEach(function (asset) {\n      hmrApply(module.bundle.root, asset);\n    });\n  } finally {\n    delete global.parcelHotUpdate;\n    if (scriptsToRemove) {\n      scriptsToRemove.forEach(script => {\n        if (script) {\n          var _document$head2;\n          (_document$head2 = document.head) === null || _document$head2 === void 0 || _document$head2.removeChild(script);\n        }\n      });\n    }\n  }\n}\nfunction hmrApply(bundle /*: ParcelRequire */, asset /*:  HMRAsset */) {\n  var modules = bundle.modules;\n  if (!modules) {\n    return;\n  }\n  if (asset.type === 'css') {\n    reloadCSS();\n  } else if (asset.type === 'js') {\n    let deps = asset.depsByBundle[bundle.HMR_BUNDLE_ID];\n    if (deps) {\n      if (modules[asset.id]) {\n        // Remove dependencies that are removed and will become orphaned.\n        // This is necessary so that if the asset is added back again, the cache is gone, and we prevent a full page reload.\n        let oldDeps = modules[asset.id][1];\n        for (let dep in oldDeps) {\n          if (!deps[dep] || deps[dep] !== oldDeps[dep]) {\n            let id = oldDeps[dep];\n            let parents = getParents(module.bundle.root, id);\n            if (parents.length === 1) {\n              hmrDelete(module.bundle.root, id);\n            }\n          }\n        }\n      }\n      if (supportsSourceURL) {\n        // Global eval. We would use `new Function` here but browser\n        // support for source maps is better with eval.\n        (0, eval)(asset.output);\n      }\n\n      // $FlowFixMe\n      let fn = global.parcelHotUpdate[asset.id];\n      modules[asset.id] = [fn, deps];\n    } else if (bundle.parent) {\n      hmrApply(bundle.parent, asset);\n    }\n  }\n}\nfunction hmrDelete(bundle, id) {\n  let modules = bundle.modules;\n  if (!modules) {\n    return;\n  }\n  if (modules[id]) {\n    // Collect dependencies that will become orphaned when this module is deleted.\n    let deps = modules[id][1];\n    let orphans = [];\n    for (let dep in deps) {\n      let parents = getParents(module.bundle.root, deps[dep]);\n      if (parents.length === 1) {\n        orphans.push(deps[dep]);\n      }\n    }\n\n    // Delete the module. This must be done before deleting dependencies in case of circular dependencies.\n    delete modules[id];\n    delete bundle.cache[id];\n\n    // Now delete the orphans.\n    orphans.forEach(id => {\n      hmrDelete(module.bundle.root, id);\n    });\n  } else if (bundle.parent) {\n    hmrDelete(bundle.parent, id);\n  }\n}\nfunction hmrAcceptCheck(bundle /*: ParcelRequire */, id /*: string */, depsByBundle /*: ?{ [string]: { [string]: string } }*/) {\n  if (hmrAcceptCheckOne(bundle, id, depsByBundle)) {\n    return true;\n  }\n\n  // Traverse parents breadth first. All possible ancestries must accept the HMR update, or we'll reload.\n  let parents = getParents(module.bundle.root, id);\n  let accepted = false;\n  while (parents.length > 0) {\n    let v = parents.shift();\n    let a = hmrAcceptCheckOne(v[0], v[1], null);\n    if (a) {\n      // If this parent accepts, stop traversing upward, but still consider siblings.\n      accepted = true;\n    } else {\n      // Otherwise, queue the parents in the next level upward.\n      let p = getParents(module.bundle.root, v[1]);\n      if (p.length === 0) {\n        // If there are no parents, then we've reached an entry without accepting. Reload.\n        accepted = false;\n        break;\n      }\n      parents.push(...p);\n    }\n  }\n  return accepted;\n}\nfunction hmrAcceptCheckOne(bundle /*: ParcelRequire */, id /*: string */, depsByBundle /*: ?{ [string]: { [string]: string } }*/) {\n  var modules = bundle.modules;\n  if (!modules) {\n    return;\n  }\n  if (depsByBundle && !depsByBundle[bundle.HMR_BUNDLE_ID]) {\n    // If we reached the root bundle without finding where the asset should go,\n    // there's nothing to do. Mark as \"accepted\" so we don't reload the page.\n    if (!bundle.parent) {\n      return true;\n    }\n    return hmrAcceptCheck(bundle.parent, id, depsByBundle);\n  }\n  if (checkedAssets[id]) {\n    return true;\n  }\n  checkedAssets[id] = true;\n  var cached = bundle.cache[id];\n  assetsToDispose.push([bundle, id]);\n  if (!cached || cached.hot && cached.hot._acceptCallbacks.length) {\n    assetsToAccept.push([bundle, id]);\n    return true;\n  }\n}\nfunction hmrDispose(bundle /*: ParcelRequire */, id /*: string */) {\n  var cached = bundle.cache[id];\n  bundle.hotData[id] = {};\n  if (cached && cached.hot) {\n    cached.hot.data = bundle.hotData[id];\n  }\n  if (cached && cached.hot && cached.hot._disposeCallbacks.length) {\n    cached.hot._disposeCallbacks.forEach(function (cb) {\n      cb(bundle.hotData[id]);\n    });\n  }\n  delete bundle.cache[id];\n}\nfunction hmrAccept(bundle /*: ParcelRequire */, id /*: string */) {\n  // Execute the module.\n  bundle(id);\n\n  // Run the accept callbacks in the new version of the module.\n  var cached = bundle.cache[id];\n  if (cached && cached.hot && cached.hot._acceptCallbacks.length) {\n    cached.hot._acceptCallbacks.forEach(function (cb) {\n      var assetsToAlsoAccept = cb(function () {\n        return getParents(module.bundle.root, id);\n      });\n      if (assetsToAlsoAccept && assetsToAccept.length) {\n        assetsToAlsoAccept.forEach(function (a) {\n          hmrDispose(a[0], a[1]);\n        });\n\n        // $FlowFixMe[method-unbinding]\n        assetsToAccept.push.apply(assetsToAccept, assetsToAlsoAccept);\n      }\n    });\n  }\n}","// Use a cross-browser storage API:\r\n// const storage = chrome.storage.sync || browser.storage.sync\r\nimport browser from 'webextension-polyfill'\r\nimport gpthToggleImg from '../img/gpth-toggle-circled.webp'\r\n\r\nlet isOptionsShown = false\r\n\r\nbrowser.storage.sync.get('gptheme').then((data) => {\r\n\tconst theme = data.gptheme || 'light'\r\n\tapplyTheme(theme)\r\n})\r\n\r\ncreateAndAppendSVGStickyBtn()\r\n// trackHtmlClassChanges()\r\n\r\nconst $htmlTag = document.documentElement\r\nconst $options = document.querySelector('.gpth__options')\r\nconst $svgIcon = document.querySelector('.gpth__svg-icon')\r\nconst $themeButtonsContainer = document.querySelector('.gpth__themes-btns')\r\n// const $themeButtons = document.querySelectorAll('.gpth__themes-btns button')\r\n\r\n$svgIcon.addEventListener('click', toggleOptions)\r\n\r\n/* $themeButtons.forEach((btn) => {\r\n\tbtn.addEventListener('click', ({ target }) => {\r\n\t\tconst theme = target.id\r\n\t\tbrowser.storage.sync.set({ gptheme: theme })\r\n\t\tapplyTheme(theme)\r\n\t\ttoggleOptions()\r\n\t})\r\n}) */\r\n$themeButtonsContainer.addEventListener('click', (event) => {\r\n\tconst themeButton = event.target.closest('button')\r\n\tif (!themeButton) return\r\n\r\n\tconst theme = themeButton.id\r\n\tbrowser.storage.sync.set({ gptheme: theme })\r\n\tapplyTheme(theme)\r\n\ttoggleOptions()\r\n})\r\n\r\nfunction createAndAppendSVGStickyBtn() {\r\n\tconst gpthFloatingBtn = document.createElement('div')\r\n\tgpthFloatingBtn.className = 'gpth__svg'\r\n\r\n\tlet htmlCode = `\r\n\t\t<div class=\"gpth__svg-icon\">\r\n\t\t\t<img src=\"${gpthToggleImg}\" alt=\"gpth-toggle\"/>\r\n\t\t</div>\r\n\t\t<div class=\"gpth__options\">\r\n\t\t\t<div class=\"gpth__themes\">\r\n\t\t\t\t<div class=\"gpth__themes-btns\">\r\n\t\t\t\t\t<button id=\"light\" data-gpth-theme=\"light\">☀️</button>\r\n\t\t\t\t\t<button id=\"dark\" data-gpth-theme=\"dark\">🌙</button>\r\n\t\t\t\t\t<button id=\"oled\" data-gpth-theme=\"black\">🌖</button>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t`\r\n\r\n\t// gpthFloatingBtn.innerHTML = htmlCode\r\n\tgpthFloatingBtn.insertAdjacentHTML('beforeend', htmlCode)\r\n\tdocument.body.appendChild(gpthFloatingBtn)\r\n}\r\n\r\n/* function applyTheme(theme) {\r\n\tlet htmlTag = document.documentElement\r\n\r\n\t// document.documentElement.className = theme === 'oled' ? 'oled dark' : theme\r\n\tif (theme === 'oled') {\r\n\t\thtmlTag.dataset.gptheme = theme\r\n\t\thtmlTag.style.colorScheme = 'dark'\r\n\t\thtmlTag.className = 'dark'\r\n\t} else {\r\n\t\thtmlTag.style.colorScheme = theme\r\n\t\thtmlTag.className = theme\r\n\t\thtmlTag.hasAttribute('data-gptheme') && htmlTag.removeAttribute('data-gptheme')\r\n\t}\r\n}\r\n */\r\nfunction applyTheme(theme) {\r\n\t$htmlTag.dataset.gptheme = theme\r\n\t$htmlTag.style.colorScheme = theme === 'oled' ? 'dark' : theme\r\n\t$htmlTag.className = theme === 'oled' ? 'dark' : theme\r\n\tif (theme !== 'oled') $htmlTag.removeAttribute('data-gptheme')\r\n}\r\n\r\nfunction toggleOptions() {\r\n\tisOptionsShown = !isOptionsShown\r\n\t$options.classList.toggle('gpth-options-shown', isOptionsShown)\r\n\r\n\tif (isOptionsShown) document.body.addEventListener('click', hideOptions)\r\n\telse document.body.removeEventListener('click', hideOptions)\r\n}\r\n\r\nfunction hideOptions(event) {\r\n\tif (!$svgIcon.contains(event.target) && !$options.contains(event.target)) {\r\n\t\ttoggleOptions()\r\n\t}\r\n}\r\n\r\n/* function trackHtmlClassChanges() {\r\n\t// Select the target element\r\n\tconst target = document.documentElement\r\n\r\n\t// Create an observer instance\r\n\tconst observer = new MutationObserver(function (mutations) {\r\n\t\tmutations.forEach(function (mutation) {\r\n\t\t\tif (mutation.type === 'attributes' && mutation.attributeName === 'class') {\r\n\t\t\t\t// Do something when the class attribute changes\r\n\t\t\t\t// console.log('Class attribute has changed')\r\n\t\t\t\t// alert('Class attribute has changed')\r\n\t\t\t\t// alert(target.className)\r\n\t\t\t\tbrowser.storage.sync.set({ gptheme: target.className })\r\n\t\t\t\tapplyTheme(target.className)\r\n\t\t\t}\r\n\t\t})\r\n\t})\r\n\r\n\t// Configuration of the observer:\r\n\tconst config = { attributes: true, attributeFilter: ['class'] }\r\n\r\n\t// Pass in the target node, as well as the observer options\r\n\tobserver.observe(target, config)\r\n} */\r\n","/* webextension-polyfill - v0.10.0 - Fri Aug 12 2022 19:42:44 */\n/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */\n/* vim: set sts=2 sw=2 et tw=80: */\n/* This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at http://mozilla.org/MPL/2.0/. */\n\"use strict\";\n\nif (!globalThis.chrome?.runtime?.id) {\n  throw new Error(\"This script should only be loaded in a browser extension.\");\n}\n\nif (typeof globalThis.browser === \"undefined\" || Object.getPrototypeOf(globalThis.browser) !== Object.prototype) {\n  const CHROME_SEND_MESSAGE_CALLBACK_NO_RESPONSE_MESSAGE = \"The message port closed before a response was received.\";\n\n  // Wrapping the bulk of this polyfill in a one-time-use function is a minor\n  // optimization for Firefox. Since Spidermonkey does not fully parse the\n  // contents of a function until the first time it's called, and since it will\n  // never actually need to be called, this allows the polyfill to be included\n  // in Firefox nearly for free.\n  const wrapAPIs = extensionAPIs => {\n    // NOTE: apiMetadata is associated to the content of the api-metadata.json file\n    // at build time by replacing the following \"include\" with the content of the\n    // JSON file.\n    const apiMetadata = {\n      \"alarms\": {\n        \"clear\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"clearAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"get\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"bookmarks\": {\n        \"create\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getChildren\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getRecent\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getSubTree\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getTree\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"move\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeTree\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"search\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"update\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        }\n      },\n      \"browserAction\": {\n        \"disable\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"enable\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"getBadgeBackgroundColor\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getBadgeText\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getPopup\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getTitle\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"openPopup\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"setBadgeBackgroundColor\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setBadgeText\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setIcon\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"setPopup\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setTitle\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        }\n      },\n      \"browsingData\": {\n        \"remove\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"removeCache\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeCookies\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeDownloads\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeFormData\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeHistory\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeLocalStorage\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removePasswords\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removePluginData\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"settings\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"commands\": {\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"contextMenus\": {\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"update\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        }\n      },\n      \"cookies\": {\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAll\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAllCookieStores\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"set\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"devtools\": {\n        \"inspectedWindow\": {\n          \"eval\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 2,\n            \"singleCallbackArg\": false\n          }\n        },\n        \"panels\": {\n          \"create\": {\n            \"minArgs\": 3,\n            \"maxArgs\": 3,\n            \"singleCallbackArg\": true\n          },\n          \"elements\": {\n            \"createSidebarPane\": {\n              \"minArgs\": 1,\n              \"maxArgs\": 1\n            }\n          }\n        }\n      },\n      \"downloads\": {\n        \"cancel\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"download\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"erase\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getFileIcon\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"open\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"pause\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeFile\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"resume\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"search\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"show\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        }\n      },\n      \"extension\": {\n        \"isAllowedFileSchemeAccess\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"isAllowedIncognitoAccess\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"history\": {\n        \"addUrl\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"deleteAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"deleteRange\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"deleteUrl\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getVisits\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"search\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"i18n\": {\n        \"detectLanguage\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAcceptLanguages\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"identity\": {\n        \"launchWebAuthFlow\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"idle\": {\n        \"queryState\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"management\": {\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"getSelf\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"setEnabled\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"uninstallSelf\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        }\n      },\n      \"notifications\": {\n        \"clear\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"create\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"getPermissionLevel\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"update\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        }\n      },\n      \"pageAction\": {\n        \"getPopup\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getTitle\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"hide\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setIcon\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"setPopup\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setTitle\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"show\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        }\n      },\n      \"permissions\": {\n        \"contains\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"request\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"runtime\": {\n        \"getBackgroundPage\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"getPlatformInfo\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"openOptionsPage\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"requestUpdateCheck\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"sendMessage\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 3\n        },\n        \"sendNativeMessage\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"setUninstallURL\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"sessions\": {\n        \"getDevices\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getRecentlyClosed\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"restore\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        }\n      },\n      \"storage\": {\n        \"local\": {\n          \"clear\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 0\n          },\n          \"get\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"getBytesInUse\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"remove\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 1\n          },\n          \"set\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 1\n          }\n        },\n        \"managed\": {\n          \"get\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"getBytesInUse\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          }\n        },\n        \"sync\": {\n          \"clear\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 0\n          },\n          \"get\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"getBytesInUse\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"remove\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 1\n          },\n          \"set\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 1\n          }\n        }\n      },\n      \"tabs\": {\n        \"captureVisibleTab\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 2\n        },\n        \"create\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"detectLanguage\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"discard\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"duplicate\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"executeScript\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getCurrent\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"getZoom\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getZoomSettings\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"goBack\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"goForward\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"highlight\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"insertCSS\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"move\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"query\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"reload\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 2\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeCSS\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"sendMessage\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 3\n        },\n        \"setZoom\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"setZoomSettings\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"update\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        }\n      },\n      \"topSites\": {\n        \"get\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"webNavigation\": {\n        \"getAllFrames\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getFrame\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"webRequest\": {\n        \"handlerBehaviorChanged\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"windows\": {\n        \"create\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getCurrent\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getLastFocused\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"update\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        }\n      }\n    };\n\n    if (Object.keys(apiMetadata).length === 0) {\n      throw new Error(\"api-metadata.json has not been included in browser-polyfill\");\n    }\n\n    /**\n     * A WeakMap subclass which creates and stores a value for any key which does\n     * not exist when accessed, but behaves exactly as an ordinary WeakMap\n     * otherwise.\n     *\n     * @param {function} createItem\n     *        A function which will be called in order to create the value for any\n     *        key which does not exist, the first time it is accessed. The\n     *        function receives, as its only argument, the key being created.\n     */\n    class DefaultWeakMap extends WeakMap {\n      constructor(createItem, items = undefined) {\n        super(items);\n        this.createItem = createItem;\n      }\n\n      get(key) {\n        if (!this.has(key)) {\n          this.set(key, this.createItem(key));\n        }\n\n        return super.get(key);\n      }\n    }\n\n    /**\n     * Returns true if the given object is an object with a `then` method, and can\n     * therefore be assumed to behave as a Promise.\n     *\n     * @param {*} value The value to test.\n     * @returns {boolean} True if the value is thenable.\n     */\n    const isThenable = value => {\n      return value && typeof value === \"object\" && typeof value.then === \"function\";\n    };\n\n    /**\n     * Creates and returns a function which, when called, will resolve or reject\n     * the given promise based on how it is called:\n     *\n     * - If, when called, `chrome.runtime.lastError` contains a non-null object,\n     *   the promise is rejected with that value.\n     * - If the function is called with exactly one argument, the promise is\n     *   resolved to that value.\n     * - Otherwise, the promise is resolved to an array containing all of the\n     *   function's arguments.\n     *\n     * @param {object} promise\n     *        An object containing the resolution and rejection functions of a\n     *        promise.\n     * @param {function} promise.resolve\n     *        The promise's resolution function.\n     * @param {function} promise.reject\n     *        The promise's rejection function.\n     * @param {object} metadata\n     *        Metadata about the wrapped method which has created the callback.\n     * @param {boolean} metadata.singleCallbackArg\n     *        Whether or not the promise is resolved with only the first\n     *        argument of the callback, alternatively an array of all the\n     *        callback arguments is resolved. By default, if the callback\n     *        function is invoked with only a single argument, that will be\n     *        resolved to the promise, while all arguments will be resolved as\n     *        an array if multiple are given.\n     *\n     * @returns {function}\n     *        The generated callback function.\n     */\n    const makeCallback = (promise, metadata) => {\n      return (...callbackArgs) => {\n        if (extensionAPIs.runtime.lastError) {\n          promise.reject(new Error(extensionAPIs.runtime.lastError.message));\n        } else if (metadata.singleCallbackArg ||\n                   (callbackArgs.length <= 1 && metadata.singleCallbackArg !== false)) {\n          promise.resolve(callbackArgs[0]);\n        } else {\n          promise.resolve(callbackArgs);\n        }\n      };\n    };\n\n    const pluralizeArguments = (numArgs) => numArgs == 1 ? \"argument\" : \"arguments\";\n\n    /**\n     * Creates a wrapper function for a method with the given name and metadata.\n     *\n     * @param {string} name\n     *        The name of the method which is being wrapped.\n     * @param {object} metadata\n     *        Metadata about the method being wrapped.\n     * @param {integer} metadata.minArgs\n     *        The minimum number of arguments which must be passed to the\n     *        function. If called with fewer than this number of arguments, the\n     *        wrapper will raise an exception.\n     * @param {integer} metadata.maxArgs\n     *        The maximum number of arguments which may be passed to the\n     *        function. If called with more than this number of arguments, the\n     *        wrapper will raise an exception.\n     * @param {boolean} metadata.singleCallbackArg\n     *        Whether or not the promise is resolved with only the first\n     *        argument of the callback, alternatively an array of all the\n     *        callback arguments is resolved. By default, if the callback\n     *        function is invoked with only a single argument, that will be\n     *        resolved to the promise, while all arguments will be resolved as\n     *        an array if multiple are given.\n     *\n     * @returns {function(object, ...*)}\n     *       The generated wrapper function.\n     */\n    const wrapAsyncFunction = (name, metadata) => {\n      return function asyncFunctionWrapper(target, ...args) {\n        if (args.length < metadata.minArgs) {\n          throw new Error(`Expected at least ${metadata.minArgs} ${pluralizeArguments(metadata.minArgs)} for ${name}(), got ${args.length}`);\n        }\n\n        if (args.length > metadata.maxArgs) {\n          throw new Error(`Expected at most ${metadata.maxArgs} ${pluralizeArguments(metadata.maxArgs)} for ${name}(), got ${args.length}`);\n        }\n\n        return new Promise((resolve, reject) => {\n          if (metadata.fallbackToNoCallback) {\n            // This API method has currently no callback on Chrome, but it return a promise on Firefox,\n            // and so the polyfill will try to call it with a callback first, and it will fallback\n            // to not passing the callback if the first call fails.\n            try {\n              target[name](...args, makeCallback({resolve, reject}, metadata));\n            } catch (cbError) {\n              console.warn(`${name} API method doesn't seem to support the callback parameter, ` +\n                           \"falling back to call it without a callback: \", cbError);\n\n              target[name](...args);\n\n              // Update the API method metadata, so that the next API calls will not try to\n              // use the unsupported callback anymore.\n              metadata.fallbackToNoCallback = false;\n              metadata.noCallback = true;\n\n              resolve();\n            }\n          } else if (metadata.noCallback) {\n            target[name](...args);\n            resolve();\n          } else {\n            target[name](...args, makeCallback({resolve, reject}, metadata));\n          }\n        });\n      };\n    };\n\n    /**\n     * Wraps an existing method of the target object, so that calls to it are\n     * intercepted by the given wrapper function. The wrapper function receives,\n     * as its first argument, the original `target` object, followed by each of\n     * the arguments passed to the original method.\n     *\n     * @param {object} target\n     *        The original target object that the wrapped method belongs to.\n     * @param {function} method\n     *        The method being wrapped. This is used as the target of the Proxy\n     *        object which is created to wrap the method.\n     * @param {function} wrapper\n     *        The wrapper function which is called in place of a direct invocation\n     *        of the wrapped method.\n     *\n     * @returns {Proxy<function>}\n     *        A Proxy object for the given method, which invokes the given wrapper\n     *        method in its place.\n     */\n    const wrapMethod = (target, method, wrapper) => {\n      return new Proxy(method, {\n        apply(targetMethod, thisObj, args) {\n          return wrapper.call(thisObj, target, ...args);\n        },\n      });\n    };\n\n    let hasOwnProperty = Function.call.bind(Object.prototype.hasOwnProperty);\n\n    /**\n     * Wraps an object in a Proxy which intercepts and wraps certain methods\n     * based on the given `wrappers` and `metadata` objects.\n     *\n     * @param {object} target\n     *        The target object to wrap.\n     *\n     * @param {object} [wrappers = {}]\n     *        An object tree containing wrapper functions for special cases. Any\n     *        function present in this object tree is called in place of the\n     *        method in the same location in the `target` object tree. These\n     *        wrapper methods are invoked as described in {@see wrapMethod}.\n     *\n     * @param {object} [metadata = {}]\n     *        An object tree containing metadata used to automatically generate\n     *        Promise-based wrapper functions for asynchronous. Any function in\n     *        the `target` object tree which has a corresponding metadata object\n     *        in the same location in the `metadata` tree is replaced with an\n     *        automatically-generated wrapper function, as described in\n     *        {@see wrapAsyncFunction}\n     *\n     * @returns {Proxy<object>}\n     */\n    const wrapObject = (target, wrappers = {}, metadata = {}) => {\n      let cache = Object.create(null);\n      let handlers = {\n        has(proxyTarget, prop) {\n          return prop in target || prop in cache;\n        },\n\n        get(proxyTarget, prop, receiver) {\n          if (prop in cache) {\n            return cache[prop];\n          }\n\n          if (!(prop in target)) {\n            return undefined;\n          }\n\n          let value = target[prop];\n\n          if (typeof value === \"function\") {\n            // This is a method on the underlying object. Check if we need to do\n            // any wrapping.\n\n            if (typeof wrappers[prop] === \"function\") {\n              // We have a special-case wrapper for this method.\n              value = wrapMethod(target, target[prop], wrappers[prop]);\n            } else if (hasOwnProperty(metadata, prop)) {\n              // This is an async method that we have metadata for. Create a\n              // Promise wrapper for it.\n              let wrapper = wrapAsyncFunction(prop, metadata[prop]);\n              value = wrapMethod(target, target[prop], wrapper);\n            } else {\n              // This is a method that we don't know or care about. Return the\n              // original method, bound to the underlying object.\n              value = value.bind(target);\n            }\n          } else if (typeof value === \"object\" && value !== null &&\n                     (hasOwnProperty(wrappers, prop) ||\n                      hasOwnProperty(metadata, prop))) {\n            // This is an object that we need to do some wrapping for the children\n            // of. Create a sub-object wrapper for it with the appropriate child\n            // metadata.\n            value = wrapObject(value, wrappers[prop], metadata[prop]);\n          } else if (hasOwnProperty(metadata, \"*\")) {\n            // Wrap all properties in * namespace.\n            value = wrapObject(value, wrappers[prop], metadata[\"*\"]);\n          } else {\n            // We don't need to do any wrapping for this property,\n            // so just forward all access to the underlying object.\n            Object.defineProperty(cache, prop, {\n              configurable: true,\n              enumerable: true,\n              get() {\n                return target[prop];\n              },\n              set(value) {\n                target[prop] = value;\n              },\n            });\n\n            return value;\n          }\n\n          cache[prop] = value;\n          return value;\n        },\n\n        set(proxyTarget, prop, value, receiver) {\n          if (prop in cache) {\n            cache[prop] = value;\n          } else {\n            target[prop] = value;\n          }\n          return true;\n        },\n\n        defineProperty(proxyTarget, prop, desc) {\n          return Reflect.defineProperty(cache, prop, desc);\n        },\n\n        deleteProperty(proxyTarget, prop) {\n          return Reflect.deleteProperty(cache, prop);\n        },\n      };\n\n      // Per contract of the Proxy API, the \"get\" proxy handler must return the\n      // original value of the target if that value is declared read-only and\n      // non-configurable. For this reason, we create an object with the\n      // prototype set to `target` instead of using `target` directly.\n      // Otherwise we cannot return a custom object for APIs that\n      // are declared read-only and non-configurable, such as `chrome.devtools`.\n      //\n      // The proxy handlers themselves will still use the original `target`\n      // instead of the `proxyTarget`, so that the methods and properties are\n      // dereferenced via the original targets.\n      let proxyTarget = Object.create(target);\n      return new Proxy(proxyTarget, handlers);\n    };\n\n    /**\n     * Creates a set of wrapper functions for an event object, which handles\n     * wrapping of listener functions that those messages are passed.\n     *\n     * A single wrapper is created for each listener function, and stored in a\n     * map. Subsequent calls to `addListener`, `hasListener`, or `removeListener`\n     * retrieve the original wrapper, so that  attempts to remove a\n     * previously-added listener work as expected.\n     *\n     * @param {DefaultWeakMap<function, function>} wrapperMap\n     *        A DefaultWeakMap object which will create the appropriate wrapper\n     *        for a given listener function when one does not exist, and retrieve\n     *        an existing one when it does.\n     *\n     * @returns {object}\n     */\n    const wrapEvent = wrapperMap => ({\n      addListener(target, listener, ...args) {\n        target.addListener(wrapperMap.get(listener), ...args);\n      },\n\n      hasListener(target, listener) {\n        return target.hasListener(wrapperMap.get(listener));\n      },\n\n      removeListener(target, listener) {\n        target.removeListener(wrapperMap.get(listener));\n      },\n    });\n\n    const onRequestFinishedWrappers = new DefaultWeakMap(listener => {\n      if (typeof listener !== \"function\") {\n        return listener;\n      }\n\n      /**\n       * Wraps an onRequestFinished listener function so that it will return a\n       * `getContent()` property which returns a `Promise` rather than using a\n       * callback API.\n       *\n       * @param {object} req\n       *        The HAR entry object representing the network request.\n       */\n      return function onRequestFinished(req) {\n        const wrappedReq = wrapObject(req, {} /* wrappers */, {\n          getContent: {\n            minArgs: 0,\n            maxArgs: 0,\n          },\n        });\n        listener(wrappedReq);\n      };\n    });\n\n    const onMessageWrappers = new DefaultWeakMap(listener => {\n      if (typeof listener !== \"function\") {\n        return listener;\n      }\n\n      /**\n       * Wraps a message listener function so that it may send responses based on\n       * its return value, rather than by returning a sentinel value and calling a\n       * callback. If the listener function returns a Promise, the response is\n       * sent when the promise either resolves or rejects.\n       *\n       * @param {*} message\n       *        The message sent by the other end of the channel.\n       * @param {object} sender\n       *        Details about the sender of the message.\n       * @param {function(*)} sendResponse\n       *        A callback which, when called with an arbitrary argument, sends\n       *        that value as a response.\n       * @returns {boolean}\n       *        True if the wrapped listener returned a Promise, which will later\n       *        yield a response. False otherwise.\n       */\n      return function onMessage(message, sender, sendResponse) {\n        let didCallSendResponse = false;\n\n        let wrappedSendResponse;\n        let sendResponsePromise = new Promise(resolve => {\n          wrappedSendResponse = function(response) {\n            didCallSendResponse = true;\n            resolve(response);\n          };\n        });\n\n        let result;\n        try {\n          result = listener(message, sender, wrappedSendResponse);\n        } catch (err) {\n          result = Promise.reject(err);\n        }\n\n        const isResultThenable = result !== true && isThenable(result);\n\n        // If the listener didn't returned true or a Promise, or called\n        // wrappedSendResponse synchronously, we can exit earlier\n        // because there will be no response sent from this listener.\n        if (result !== true && !isResultThenable && !didCallSendResponse) {\n          return false;\n        }\n\n        // A small helper to send the message if the promise resolves\n        // and an error if the promise rejects (a wrapped sendMessage has\n        // to translate the message into a resolved promise or a rejected\n        // promise).\n        const sendPromisedResult = (promise) => {\n          promise.then(msg => {\n            // send the message value.\n            sendResponse(msg);\n          }, error => {\n            // Send a JSON representation of the error if the rejected value\n            // is an instance of error, or the object itself otherwise.\n            let message;\n            if (error && (error instanceof Error ||\n                typeof error.message === \"string\")) {\n              message = error.message;\n            } else {\n              message = \"An unexpected error occurred\";\n            }\n\n            sendResponse({\n              __mozWebExtensionPolyfillReject__: true,\n              message,\n            });\n          }).catch(err => {\n            // Print an error on the console if unable to send the response.\n            console.error(\"Failed to send onMessage rejected reply\", err);\n          });\n        };\n\n        // If the listener returned a Promise, send the resolved value as a\n        // result, otherwise wait the promise related to the wrappedSendResponse\n        // callback to resolve and send it as a response.\n        if (isResultThenable) {\n          sendPromisedResult(result);\n        } else {\n          sendPromisedResult(sendResponsePromise);\n        }\n\n        // Let Chrome know that the listener is replying.\n        return true;\n      };\n    });\n\n    const wrappedSendMessageCallback = ({reject, resolve}, reply) => {\n      if (extensionAPIs.runtime.lastError) {\n        // Detect when none of the listeners replied to the sendMessage call and resolve\n        // the promise to undefined as in Firefox.\n        // See https://github.com/mozilla/webextension-polyfill/issues/130\n        if (extensionAPIs.runtime.lastError.message === CHROME_SEND_MESSAGE_CALLBACK_NO_RESPONSE_MESSAGE) {\n          resolve();\n        } else {\n          reject(new Error(extensionAPIs.runtime.lastError.message));\n        }\n      } else if (reply && reply.__mozWebExtensionPolyfillReject__) {\n        // Convert back the JSON representation of the error into\n        // an Error instance.\n        reject(new Error(reply.message));\n      } else {\n        resolve(reply);\n      }\n    };\n\n    const wrappedSendMessage = (name, metadata, apiNamespaceObj, ...args) => {\n      if (args.length < metadata.minArgs) {\n        throw new Error(`Expected at least ${metadata.minArgs} ${pluralizeArguments(metadata.minArgs)} for ${name}(), got ${args.length}`);\n      }\n\n      if (args.length > metadata.maxArgs) {\n        throw new Error(`Expected at most ${metadata.maxArgs} ${pluralizeArguments(metadata.maxArgs)} for ${name}(), got ${args.length}`);\n      }\n\n      return new Promise((resolve, reject) => {\n        const wrappedCb = wrappedSendMessageCallback.bind(null, {resolve, reject});\n        args.push(wrappedCb);\n        apiNamespaceObj.sendMessage(...args);\n      });\n    };\n\n    const staticWrappers = {\n      devtools: {\n        network: {\n          onRequestFinished: wrapEvent(onRequestFinishedWrappers),\n        },\n      },\n      runtime: {\n        onMessage: wrapEvent(onMessageWrappers),\n        onMessageExternal: wrapEvent(onMessageWrappers),\n        sendMessage: wrappedSendMessage.bind(null, \"sendMessage\", {minArgs: 1, maxArgs: 3}),\n      },\n      tabs: {\n        sendMessage: wrappedSendMessage.bind(null, \"sendMessage\", {minArgs: 2, maxArgs: 3}),\n      },\n    };\n    const settingMetadata = {\n      clear: {minArgs: 1, maxArgs: 1},\n      get: {minArgs: 1, maxArgs: 1},\n      set: {minArgs: 1, maxArgs: 1},\n    };\n    apiMetadata.privacy = {\n      network: {\"*\": settingMetadata},\n      services: {\"*\": settingMetadata},\n      websites: {\"*\": settingMetadata},\n    };\n\n    return wrapObject(extensionAPIs, staticWrappers, apiMetadata);\n  };\n\n  // The build process adds a UMD wrapper around this file, which makes the\n  // `module` variable available.\n  module.exports = wrapAPIs(chrome);\n} else {\n  module.exports = globalThis.browser;\n}\n","module.exports = require('./helpers/bundle-url').getBundleURL('5Z27m') + \"gpth-toggle-circled.d97c3e75.webp\" + \"?\" + Date.now();","\"use strict\";\n\nvar bundleURL = {};\nfunction getBundleURLCached(id) {\n  var value = bundleURL[id];\n  if (!value) {\n    value = getBundleURL();\n    bundleURL[id] = value;\n  }\n  return value;\n}\nfunction getBundleURL() {\n  try {\n    throw new Error();\n  } catch (err) {\n    var matches = ('' + err.stack).match(/(https?|file|ftp|(chrome|moz|safari-web)-extension):\\/\\/[^)\\n]+/g);\n    if (matches) {\n      // The first two stack frames will be this function and getBundleURLCached.\n      // Use the 3rd one, which will be a runtime in the original bundle.\n      return getBaseURL(matches[2]);\n    }\n  }\n  return '/';\n}\nfunction getBaseURL(url) {\n  return ('' + url).replace(/^((?:https?|file|ftp|(chrome|moz|safari-web)-extension):\\/\\/.+)\\/[^/]+$/, '$1') + '/';\n}\n\n// TODO: Replace uses with `new URL(url).origin` when ie11 is no longer supported.\nfunction getOrigin(url) {\n  var matches = ('' + url).match(/(https?|file|ftp|(chrome|moz|safari-web)-extension):\\/\\/[^/]+/);\n  if (!matches) {\n    throw new Error('Origin not found');\n  }\n  return matches[0];\n}\nexports.getBundleURL = getBundleURLCached;\nexports.getBaseURL = getBaseURL;\nexports.getOrigin = getOrigin;","exports.interopDefault = function (a) {\n  return a && a.__esModule ? a : {default: a};\n};\n\nexports.defineInteropFlag = function (a) {\n  Object.defineProperty(a, '__esModule', {value: true});\n};\n\nexports.exportAll = function (source, dest) {\n  Object.keys(source).forEach(function (key) {\n    if (\n      key === 'default' ||\n      key === '__esModule' ||\n      Object.prototype.hasOwnProperty.call(dest, key)\n    ) {\n      return;\n    }\n\n    Object.defineProperty(dest, key, {\n      enumerable: true,\n      get: function () {\n        return source[key];\n      },\n    });\n  });\n\n  return dest;\n};\n\nexports.export = function (dest, destName, get) {\n  Object.defineProperty(dest, destName, {\n    enumerable: true,\n    get: get,\n  });\n};\n"],"names":["globalThis","chrome","runtime","id","Error","browser","Object","getPrototypeOf","prototype","CHROME_SEND_MESSAGE_CALLBACK_NO_RESPONSE_MESSAGE","wrapAPIs","extensionAPIs","apiMetadata","keys","length","DefaultWeakMap","WeakMap","constructor","createItem","items","undefined","get","key","has","set","isThenable","value","then","makeCallback","promise","metadata","callbackArgs","lastError","reject","message","singleCallbackArg","resolve","pluralizeArguments","numArgs","wrapAsyncFunction","name","asyncFunctionWrapper","target","args","minArgs","maxArgs","Promise","fallbackToNoCallback","cbError","console","warn","noCallback","wrapMethod","method","wrapper","Proxy","apply","targetMethod","thisObj","call","hasOwnProperty","Function","bind","wrapObject","wrappers","cache","create","handlers","proxyTarget","prop","receiver","defineProperty","configurable","enumerable","desc","Reflect","deleteProperty","wrapEvent","wrapperMap","addListener","listener","hasListener","removeListener","onRequestFinishedWrappers","onRequestFinished","req","wrappedReq","getContent","onMessageWrappers","onMessage","sender","sendResponse","didCallSendResponse","wrappedSendResponse","sendResponsePromise","response","result","err","isResultThenable","sendPromisedResult","msg","error","__mozWebExtensionPolyfillReject__","catch","wrappedSendMessageCallback","reply","wrappedSendMessage","apiNamespaceObj","wrappedCb","push","sendMessage","staticWrappers","devtools","network","onMessageExternal","tabs","settingMetadata","clear","privacy","services","websites","module","exports"],"version":3,"file":"content.4a18726a.js.map"} +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"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","sources":["node_modules/@parcel/runtime-browser-hmr/lib/runtime-153c4e08a4ad6222.js","src/js/content.js","node_modules/webextension-polyfill/dist/browser-polyfill.js","node_modules/@parcel/runtime-js/lib/runtime-8e99fa0d17a0041e.js","node_modules/@parcel/runtime-js/lib/helpers/bundle-url.js","node_modules/@parcel/transformer-js/src/esmodule-helpers.js"],"sourcesContent":["var HMR_HOST = \"localhost\";var HMR_PORT = 1234;var HMR_SECURE = false;var HMR_ENV_HASH = \"ddf6e0724bd358bd\";module.bundle.HMR_BUNDLE_ID = \"45b44acd4a18726a\";\"use strict\";\n\n/* global HMR_HOST, HMR_PORT, HMR_ENV_HASH, HMR_SECURE, chrome, browser, __parcel__import__, __parcel__importScripts__, ServiceWorkerGlobalScope */\n/*::\nimport type {\n  HMRAsset,\n  HMRMessage,\n} from '@parcel/reporter-dev-server/src/HMRServer.js';\ninterface ParcelRequire {\n  (string): mixed;\n  cache: {|[string]: ParcelModule|};\n  hotData: {|[string]: mixed|};\n  Module: any;\n  parent: ?ParcelRequire;\n  isParcelRequire: true;\n  modules: {|[string]: [Function, {|[string]: string|}]|};\n  HMR_BUNDLE_ID: string;\n  root: ParcelRequire;\n}\ninterface ParcelModule {\n  hot: {|\n    data: mixed,\n    accept(cb: (Function) => void): void,\n    dispose(cb: (mixed) => void): void,\n    // accept(deps: Array<string> | string, cb: (Function) => void): void,\n    // decline(): void,\n    _acceptCallbacks: Array<(Function) => void>,\n    _disposeCallbacks: Array<(mixed) => void>,\n  |};\n}\ninterface ExtensionContext {\n  runtime: {|\n    reload(): void,\n    getURL(url: string): string;\n    getManifest(): {manifest_version: number, ...};\n  |};\n}\ndeclare var module: {bundle: ParcelRequire, ...};\ndeclare var HMR_HOST: string;\ndeclare var HMR_PORT: string;\ndeclare var HMR_ENV_HASH: string;\ndeclare var HMR_SECURE: boolean;\ndeclare var chrome: ExtensionContext;\ndeclare var browser: ExtensionContext;\ndeclare var __parcel__import__: (string) => Promise<void>;\ndeclare var __parcel__importScripts__: (string) => Promise<void>;\ndeclare var globalThis: typeof self;\ndeclare var ServiceWorkerGlobalScope: Object;\n*/\nvar OVERLAY_ID = '__parcel__error__overlay__';\nvar OldModule = module.bundle.Module;\nfunction Module(moduleName) {\n  OldModule.call(this, moduleName);\n  this.hot = {\n    data: module.bundle.hotData[moduleName],\n    _acceptCallbacks: [],\n    _disposeCallbacks: [],\n    accept: function (fn) {\n      this._acceptCallbacks.push(fn || function () {});\n    },\n    dispose: function (fn) {\n      this._disposeCallbacks.push(fn);\n    }\n  };\n  module.bundle.hotData[moduleName] = undefined;\n}\nmodule.bundle.Module = Module;\nmodule.bundle.hotData = {};\nvar checkedAssets /*: {|[string]: boolean|} */, assetsToDispose /*: Array<[ParcelRequire, string]> */, assetsToAccept /*: Array<[ParcelRequire, string]> */;\n\nfunction getHostname() {\n  return HMR_HOST || (location.protocol.indexOf('http') === 0 ? location.hostname : 'localhost');\n}\nfunction getPort() {\n  return HMR_PORT || location.port;\n}\n\n// eslint-disable-next-line no-redeclare\nvar parent = module.bundle.parent;\nif ((!parent || !parent.isParcelRequire) && typeof WebSocket !== 'undefined') {\n  var hostname = getHostname();\n  var port = getPort();\n  var protocol = HMR_SECURE || location.protocol == 'https:' && !['localhost', '127.0.0.1', '0.0.0.0'].includes(hostname) ? 'wss' : 'ws';\n  var ws;\n  try {\n    ws = new WebSocket(protocol + '://' + hostname + (port ? ':' + port : '') + '/');\n  } catch (err) {\n    if (err.message) {\n      console.error(err.message);\n    }\n    ws = {};\n  }\n\n  // Web extension context\n  var extCtx = typeof browser === 'undefined' ? typeof chrome === 'undefined' ? null : chrome : browser;\n\n  // Safari doesn't support sourceURL in error stacks.\n  // eval may also be disabled via CSP, so do a quick check.\n  var supportsSourceURL = false;\n  try {\n    (0, eval)('throw new Error(\"test\"); //# sourceURL=test.js');\n  } catch (err) {\n    supportsSourceURL = err.stack.includes('test.js');\n  }\n\n  // $FlowFixMe\n  ws.onmessage = async function (event /*: {data: string, ...} */) {\n    checkedAssets = {} /*: {|[string]: boolean|} */;\n    assetsToAccept = [];\n    assetsToDispose = [];\n    var data /*: HMRMessage */ = JSON.parse(event.data);\n    if (data.type === 'update') {\n      // Remove error overlay if there is one\n      if (typeof document !== 'undefined') {\n        removeErrorOverlay();\n      }\n      let assets = data.assets.filter(asset => asset.envHash === HMR_ENV_HASH);\n\n      // Handle HMR Update\n      let handled = assets.every(asset => {\n        return asset.type === 'css' || asset.type === 'js' && hmrAcceptCheck(module.bundle.root, asset.id, asset.depsByBundle);\n      });\n      if (handled) {\n        console.clear();\n\n        // Dispatch custom event so other runtimes (e.g React Refresh) are aware.\n        if (typeof window !== 'undefined' && typeof CustomEvent !== 'undefined') {\n          window.dispatchEvent(new CustomEvent('parcelhmraccept'));\n        }\n        await hmrApplyUpdates(assets);\n\n        // Dispose all old assets.\n        let processedAssets = {} /*: {|[string]: boolean|} */;\n        for (let i = 0; i < assetsToDispose.length; i++) {\n          let id = assetsToDispose[i][1];\n          if (!processedAssets[id]) {\n            hmrDispose(assetsToDispose[i][0], id);\n            processedAssets[id] = true;\n          }\n        }\n\n        // Run accept callbacks. This will also re-execute other disposed assets in topological order.\n        processedAssets = {};\n        for (let i = 0; i < assetsToAccept.length; i++) {\n          let id = assetsToAccept[i][1];\n          if (!processedAssets[id]) {\n            hmrAccept(assetsToAccept[i][0], id);\n            processedAssets[id] = true;\n          }\n        }\n      } else fullReload();\n    }\n    if (data.type === 'error') {\n      // Log parcel errors to console\n      for (let ansiDiagnostic of data.diagnostics.ansi) {\n        let stack = ansiDiagnostic.codeframe ? ansiDiagnostic.codeframe : ansiDiagnostic.stack;\n        console.error('🚨 [parcel]: ' + ansiDiagnostic.message + '\\n' + stack + '\\n\\n' + ansiDiagnostic.hints.join('\\n'));\n      }\n      if (typeof document !== 'undefined') {\n        // Render the fancy html overlay\n        removeErrorOverlay();\n        var overlay = createErrorOverlay(data.diagnostics.html);\n        // $FlowFixMe\n        document.body.appendChild(overlay);\n      }\n    }\n  };\n  ws.onerror = function (e) {\n    if (e.message) {\n      console.error(e.message);\n    }\n  };\n  ws.onclose = function () {\n    console.warn('[parcel] 🚨 Connection to the HMR server was lost');\n  };\n}\nfunction removeErrorOverlay() {\n  var overlay = document.getElementById(OVERLAY_ID);\n  if (overlay) {\n    overlay.remove();\n    console.log('[parcel] ✨ Error resolved');\n  }\n}\nfunction createErrorOverlay(diagnostics) {\n  var overlay = document.createElement('div');\n  overlay.id = OVERLAY_ID;\n  let errorHTML = '<div style=\"background: black; opacity: 0.85; font-size: 16px; color: white; position: fixed; height: 100%; width: 100%; top: 0px; left: 0px; padding: 30px; font-family: Menlo, Consolas, monospace; z-index: 9999;\">';\n  for (let diagnostic of diagnostics) {\n    let stack = diagnostic.frames.length ? diagnostic.frames.reduce((p, frame) => {\n      return `${p}\n<a href=\"/__parcel_launch_editor?file=${encodeURIComponent(frame.location)}\" style=\"text-decoration: underline; color: #888\" onclick=\"fetch(this.href); return false\">${frame.location}</a>\n${frame.code}`;\n    }, '') : diagnostic.stack;\n    errorHTML += `\n      <div>\n        <div style=\"font-size: 18px; font-weight: bold; margin-top: 20px;\">\n          🚨 ${diagnostic.message}\n        </div>\n        <pre>${stack}</pre>\n        <div>\n          ${diagnostic.hints.map(hint => '<div>💡 ' + hint + '</div>').join('')}\n        </div>\n        ${diagnostic.documentation ? `<div>📝 <a style=\"color: violet\" href=\"${diagnostic.documentation}\" target=\"_blank\">Learn more</a></div>` : ''}\n      </div>\n    `;\n  }\n  errorHTML += '</div>';\n  overlay.innerHTML = errorHTML;\n  return overlay;\n}\nfunction fullReload() {\n  if ('reload' in location) {\n    location.reload();\n  } else if (extCtx && extCtx.runtime && extCtx.runtime.reload) {\n    extCtx.runtime.reload();\n  }\n}\nfunction getParents(bundle, id) /*: Array<[ParcelRequire, string]> */{\n  var modules = bundle.modules;\n  if (!modules) {\n    return [];\n  }\n  var parents = [];\n  var k, d, dep;\n  for (k in modules) {\n    for (d in modules[k][1]) {\n      dep = modules[k][1][d];\n      if (dep === id || Array.isArray(dep) && dep[dep.length - 1] === id) {\n        parents.push([bundle, k]);\n      }\n    }\n  }\n  if (bundle.parent) {\n    parents = parents.concat(getParents(bundle.parent, id));\n  }\n  return parents;\n}\nfunction updateLink(link) {\n  var href = link.getAttribute('href');\n  if (!href) {\n    return;\n  }\n  var newLink = link.cloneNode();\n  newLink.onload = function () {\n    if (link.parentNode !== null) {\n      // $FlowFixMe\n      link.parentNode.removeChild(link);\n    }\n  };\n  newLink.setAttribute('href',\n  // $FlowFixMe\n  href.split('?')[0] + '?' + Date.now());\n  // $FlowFixMe\n  link.parentNode.insertBefore(newLink, link.nextSibling);\n}\nvar cssTimeout = null;\nfunction reloadCSS() {\n  if (cssTimeout) {\n    return;\n  }\n  cssTimeout = setTimeout(function () {\n    var links = document.querySelectorAll('link[rel=\"stylesheet\"]');\n    for (var i = 0; i < links.length; i++) {\n      // $FlowFixMe[incompatible-type]\n      var href /*: string */ = links[i].getAttribute('href');\n      var hostname = getHostname();\n      var servedFromHMRServer = hostname === 'localhost' ? new RegExp('^(https?:\\\\/\\\\/(0.0.0.0|127.0.0.1)|localhost):' + getPort()).test(href) : href.indexOf(hostname + ':' + getPort());\n      var absolute = /^https?:\\/\\//i.test(href) && href.indexOf(location.origin) !== 0 && !servedFromHMRServer;\n      if (!absolute) {\n        updateLink(links[i]);\n      }\n    }\n    cssTimeout = null;\n  }, 50);\n}\nfunction hmrDownload(asset) {\n  if (asset.type === 'js') {\n    if (typeof document !== 'undefined') {\n      let script = document.createElement('script');\n      script.src = asset.url + '?t=' + Date.now();\n      if (asset.outputFormat === 'esmodule') {\n        script.type = 'module';\n      }\n      return new Promise((resolve, reject) => {\n        var _document$head;\n        script.onload = () => resolve(script);\n        script.onerror = reject;\n        (_document$head = document.head) === null || _document$head === void 0 || _document$head.appendChild(script);\n      });\n    } else if (typeof importScripts === 'function') {\n      // Worker scripts\n      if (asset.outputFormat === 'esmodule') {\n        return __parcel__import__(asset.url + '?t=' + Date.now());\n      } else {\n        return new Promise((resolve, reject) => {\n          try {\n            __parcel__importScripts__(asset.url + '?t=' + Date.now());\n            resolve();\n          } catch (err) {\n            reject(err);\n          }\n        });\n      }\n    }\n  }\n}\nasync function hmrApplyUpdates(assets) {\n  global.parcelHotUpdate = Object.create(null);\n  let scriptsToRemove;\n  try {\n    // If sourceURL comments aren't supported in eval, we need to load\n    // the update from the dev server over HTTP so that stack traces\n    // are correct in errors/logs. This is much slower than eval, so\n    // we only do it if needed (currently just Safari).\n    // https://bugs.webkit.org/show_bug.cgi?id=137297\n    // This path is also taken if a CSP disallows eval.\n    if (!supportsSourceURL) {\n      let promises = assets.map(asset => {\n        var _hmrDownload;\n        return (_hmrDownload = hmrDownload(asset)) === null || _hmrDownload === void 0 ? void 0 : _hmrDownload.catch(err => {\n          // Web extension fix\n          if (extCtx && extCtx.runtime && extCtx.runtime.getManifest().manifest_version == 3 && typeof ServiceWorkerGlobalScope != 'undefined' && global instanceof ServiceWorkerGlobalScope) {\n            extCtx.runtime.reload();\n            return;\n          }\n          throw err;\n        });\n      });\n      scriptsToRemove = await Promise.all(promises);\n    }\n    assets.forEach(function (asset) {\n      hmrApply(module.bundle.root, asset);\n    });\n  } finally {\n    delete global.parcelHotUpdate;\n    if (scriptsToRemove) {\n      scriptsToRemove.forEach(script => {\n        if (script) {\n          var _document$head2;\n          (_document$head2 = document.head) === null || _document$head2 === void 0 || _document$head2.removeChild(script);\n        }\n      });\n    }\n  }\n}\nfunction hmrApply(bundle /*: ParcelRequire */, asset /*:  HMRAsset */) {\n  var modules = bundle.modules;\n  if (!modules) {\n    return;\n  }\n  if (asset.type === 'css') {\n    reloadCSS();\n  } else if (asset.type === 'js') {\n    let deps = asset.depsByBundle[bundle.HMR_BUNDLE_ID];\n    if (deps) {\n      if (modules[asset.id]) {\n        // Remove dependencies that are removed and will become orphaned.\n        // This is necessary so that if the asset is added back again, the cache is gone, and we prevent a full page reload.\n        let oldDeps = modules[asset.id][1];\n        for (let dep in oldDeps) {\n          if (!deps[dep] || deps[dep] !== oldDeps[dep]) {\n            let id = oldDeps[dep];\n            let parents = getParents(module.bundle.root, id);\n            if (parents.length === 1) {\n              hmrDelete(module.bundle.root, id);\n            }\n          }\n        }\n      }\n      if (supportsSourceURL) {\n        // Global eval. We would use `new Function` here but browser\n        // support for source maps is better with eval.\n        (0, eval)(asset.output);\n      }\n\n      // $FlowFixMe\n      let fn = global.parcelHotUpdate[asset.id];\n      modules[asset.id] = [fn, deps];\n    } else if (bundle.parent) {\n      hmrApply(bundle.parent, asset);\n    }\n  }\n}\nfunction hmrDelete(bundle, id) {\n  let modules = bundle.modules;\n  if (!modules) {\n    return;\n  }\n  if (modules[id]) {\n    // Collect dependencies that will become orphaned when this module is deleted.\n    let deps = modules[id][1];\n    let orphans = [];\n    for (let dep in deps) {\n      let parents = getParents(module.bundle.root, deps[dep]);\n      if (parents.length === 1) {\n        orphans.push(deps[dep]);\n      }\n    }\n\n    // Delete the module. This must be done before deleting dependencies in case of circular dependencies.\n    delete modules[id];\n    delete bundle.cache[id];\n\n    // Now delete the orphans.\n    orphans.forEach(id => {\n      hmrDelete(module.bundle.root, id);\n    });\n  } else if (bundle.parent) {\n    hmrDelete(bundle.parent, id);\n  }\n}\nfunction hmrAcceptCheck(bundle /*: ParcelRequire */, id /*: string */, depsByBundle /*: ?{ [string]: { [string]: string } }*/) {\n  if (hmrAcceptCheckOne(bundle, id, depsByBundle)) {\n    return true;\n  }\n\n  // Traverse parents breadth first. All possible ancestries must accept the HMR update, or we'll reload.\n  let parents = getParents(module.bundle.root, id);\n  let accepted = false;\n  while (parents.length > 0) {\n    let v = parents.shift();\n    let a = hmrAcceptCheckOne(v[0], v[1], null);\n    if (a) {\n      // If this parent accepts, stop traversing upward, but still consider siblings.\n      accepted = true;\n    } else {\n      // Otherwise, queue the parents in the next level upward.\n      let p = getParents(module.bundle.root, v[1]);\n      if (p.length === 0) {\n        // If there are no parents, then we've reached an entry without accepting. Reload.\n        accepted = false;\n        break;\n      }\n      parents.push(...p);\n    }\n  }\n  return accepted;\n}\nfunction hmrAcceptCheckOne(bundle /*: ParcelRequire */, id /*: string */, depsByBundle /*: ?{ [string]: { [string]: string } }*/) {\n  var modules = bundle.modules;\n  if (!modules) {\n    return;\n  }\n  if (depsByBundle && !depsByBundle[bundle.HMR_BUNDLE_ID]) {\n    // If we reached the root bundle without finding where the asset should go,\n    // there's nothing to do. Mark as \"accepted\" so we don't reload the page.\n    if (!bundle.parent) {\n      return true;\n    }\n    return hmrAcceptCheck(bundle.parent, id, depsByBundle);\n  }\n  if (checkedAssets[id]) {\n    return true;\n  }\n  checkedAssets[id] = true;\n  var cached = bundle.cache[id];\n  assetsToDispose.push([bundle, id]);\n  if (!cached || cached.hot && cached.hot._acceptCallbacks.length) {\n    assetsToAccept.push([bundle, id]);\n    return true;\n  }\n}\nfunction hmrDispose(bundle /*: ParcelRequire */, id /*: string */) {\n  var cached = bundle.cache[id];\n  bundle.hotData[id] = {};\n  if (cached && cached.hot) {\n    cached.hot.data = bundle.hotData[id];\n  }\n  if (cached && cached.hot && cached.hot._disposeCallbacks.length) {\n    cached.hot._disposeCallbacks.forEach(function (cb) {\n      cb(bundle.hotData[id]);\n    });\n  }\n  delete bundle.cache[id];\n}\nfunction hmrAccept(bundle /*: ParcelRequire */, id /*: string */) {\n  // Execute the module.\n  bundle(id);\n\n  // Run the accept callbacks in the new version of the module.\n  var cached = bundle.cache[id];\n  if (cached && cached.hot && cached.hot._acceptCallbacks.length) {\n    cached.hot._acceptCallbacks.forEach(function (cb) {\n      var assetsToAlsoAccept = cb(function () {\n        return getParents(module.bundle.root, id);\n      });\n      if (assetsToAlsoAccept && assetsToAccept.length) {\n        assetsToAlsoAccept.forEach(function (a) {\n          hmrDispose(a[0], a[1]);\n        });\n\n        // $FlowFixMe[method-unbinding]\n        assetsToAccept.push.apply(assetsToAccept, assetsToAlsoAccept);\n      }\n    });\n  }\n}","// Use a cross-browser storage API:\r\n// const storage = chrome.storage.sync || browser.storage.sync\r\nimport browser from 'webextension-polyfill'\r\nimport gpthToggleImg from '../img/gpth-toggle-circled.webp'\r\n\r\nlet isOptionsShown = false\r\n\r\nbrowser.storage.sync.get('gptheme').then((data) => {\r\n\t/* \tconst theme = data.gptheme || 'dark'\r\n\tapplyTheme(theme) */\r\n\tlet theme = ''\r\n\tconst storedTheme = data.gptheme\r\n\r\n\tif (storedTheme) {\r\n\t\ttheme = storedTheme\r\n\t\tapplyTheme(theme)\r\n\r\n\t\treturn\r\n\t}\r\n\r\n\t// Check if the dark or light theme preference is set\r\n\tconst lightThemeQuery = window.matchMedia('(prefers-color-scheme: light)')\r\n\r\n\tlightThemeQuery.matches ? (theme = 'light') : (theme = 'dark') // Fallback theme\r\n\r\n\tapplyTheme(theme)\r\n})\r\n\r\ncreateAndAppendSVGStickyBtn()\r\n// trackHtmlClassChanges()\r\n\r\nconst $htmlTag = document.documentElement\r\nconst $options = document.querySelector('.gpth__options')\r\nconst $svgIcon = document.querySelector('.gpth__svg-icon')\r\nconst $themeButtonsContainer = document.querySelector('.gpth__themes-btns')\r\n// const $themeButtons = document.querySelectorAll('.gpth__themes-btns button')\r\n\r\n$svgIcon.addEventListener('click', toggleOptions)\r\n\r\n/* $themeButtons.forEach((btn) => {\r\n\tbtn.addEventListener('click', ({ target }) => {\r\n\t\tconst theme = target.id\r\n\t\tbrowser.storage.sync.set({ gptheme: theme })\r\n\t\tapplyTheme(theme)\r\n\t\ttoggleOptions()\r\n\t})\r\n}) */\r\n$themeButtonsContainer.addEventListener('click', (event) => {\r\n\tconst themeButton = event.target.closest('button')\r\n\tif (!themeButton) return\r\n\r\n\tconst theme = themeButton.id\r\n\tbrowser.storage.sync.set({ gptheme: theme })\r\n\tapplyTheme(theme)\r\n\ttoggleOptions()\r\n})\r\n\r\nfunction createAndAppendSVGStickyBtn() {\r\n\tconst gpthFloatingBtn = document.createElement('div')\r\n\tgpthFloatingBtn.className = 'gpth__svg'\r\n\r\n\tlet htmlCode = `\r\n\t\t<div class=\"gpth__svg-icon\">\r\n\t\t\t<img src=\"${gpthToggleImg}\" alt=\"gpth-toggle\"/>\r\n\t\t</div>\r\n\t\t<div class=\"gpth__options\">\r\n\t\t\t<div class=\"gpth__themes\">\r\n\t\t\t\t<div class=\"gpth__themes-btns\">\r\n\t\t\t\t\t<button id=\"light\" data-gpth-theme=\"light\">☀️</button>\r\n\t\t\t\t\t<button id=\"dark\" data-gpth-theme=\"dark\">🌙</button>\r\n\t\t\t\t\t<button id=\"oled\" data-gpth-theme=\"black\">🌖</button>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t`\r\n\r\n\t// gpthFloatingBtn.innerHTML = htmlCode\r\n\tgpthFloatingBtn.insertAdjacentHTML('beforeend', htmlCode)\r\n\tdocument.body.appendChild(gpthFloatingBtn)\r\n}\r\n\r\n/* function applyTheme(theme) {\r\n\tlet htmlTag = document.documentElement\r\n\r\n\t// document.documentElement.className = theme === 'oled' ? 'oled dark' : theme\r\n\tif (theme === 'oled') {\r\n\t\thtmlTag.dataset.gptheme = theme\r\n\t\thtmlTag.style.colorScheme = 'dark'\r\n\t\thtmlTag.className = 'dark'\r\n\t} else {\r\n\t\thtmlTag.style.colorScheme = theme\r\n\t\thtmlTag.className = theme\r\n\t\thtmlTag.hasAttribute('data-gptheme') && htmlTag.removeAttribute('data-gptheme')\r\n\t}\r\n}\r\n */\r\nfunction applyTheme(theme) {\r\n\t$htmlTag.dataset.gptheme = theme\r\n\t$htmlTag.style.colorScheme = theme === 'oled' ? 'dark' : theme\r\n\t$htmlTag.className = theme === 'oled' ? 'dark' : theme\r\n\tif (theme !== 'oled') $htmlTag.removeAttribute('data-gptheme')\r\n}\r\n\r\nfunction toggleOptions() {\r\n\tisOptionsShown = !isOptionsShown\r\n\t$options.classList.toggle('gpth-options-shown', isOptionsShown)\r\n\r\n\tif (isOptionsShown) document.body.addEventListener('click', hideOptions)\r\n\telse document.body.removeEventListener('click', hideOptions)\r\n}\r\n\r\nfunction hideOptions(event) {\r\n\tif (!$svgIcon.contains(event.target) && !$options.contains(event.target)) {\r\n\t\ttoggleOptions()\r\n\t}\r\n}\r\n\r\n/* function trackHtmlClassChanges() {\r\n\t// Select the target element\r\n\tconst target = document.documentElement\r\n\r\n\t// Create an observer instance\r\n\tconst observer = new MutationObserver(function (mutations) {\r\n\t\tmutations.forEach(function (mutation) {\r\n\t\t\tif (mutation.type === 'attributes' && mutation.attributeName === 'class') {\r\n\t\t\t\t// Do something when the class attribute changes\r\n\t\t\t\t// console.log('Class attribute has changed')\r\n\t\t\t\t// alert('Class attribute has changed')\r\n\t\t\t\t// alert(target.className)\r\n\t\t\t\tbrowser.storage.sync.set({ gptheme: target.className })\r\n\t\t\t\tapplyTheme(target.className)\r\n\t\t\t}\r\n\t\t})\r\n\t})\r\n\r\n\t// Configuration of the observer:\r\n\tconst config = { attributes: true, attributeFilter: ['class'] }\r\n\r\n\t// Pass in the target node, as well as the observer options\r\n\tobserver.observe(target, config)\r\n} */\r\n","/* webextension-polyfill - v0.10.0 - Fri Aug 12 2022 19:42:44 */\n/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */\n/* vim: set sts=2 sw=2 et tw=80: */\n/* This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at http://mozilla.org/MPL/2.0/. */\n\"use strict\";\n\nif (!globalThis.chrome?.runtime?.id) {\n  throw new Error(\"This script should only be loaded in a browser extension.\");\n}\n\nif (typeof globalThis.browser === \"undefined\" || Object.getPrototypeOf(globalThis.browser) !== Object.prototype) {\n  const CHROME_SEND_MESSAGE_CALLBACK_NO_RESPONSE_MESSAGE = \"The message port closed before a response was received.\";\n\n  // Wrapping the bulk of this polyfill in a one-time-use function is a minor\n  // optimization for Firefox. Since Spidermonkey does not fully parse the\n  // contents of a function until the first time it's called, and since it will\n  // never actually need to be called, this allows the polyfill to be included\n  // in Firefox nearly for free.\n  const wrapAPIs = extensionAPIs => {\n    // NOTE: apiMetadata is associated to the content of the api-metadata.json file\n    // at build time by replacing the following \"include\" with the content of the\n    // JSON file.\n    const apiMetadata = {\n      \"alarms\": {\n        \"clear\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"clearAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"get\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"bookmarks\": {\n        \"create\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getChildren\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getRecent\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getSubTree\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getTree\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"move\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeTree\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"search\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"update\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        }\n      },\n      \"browserAction\": {\n        \"disable\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"enable\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"getBadgeBackgroundColor\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getBadgeText\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getPopup\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getTitle\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"openPopup\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"setBadgeBackgroundColor\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setBadgeText\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setIcon\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"setPopup\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setTitle\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        }\n      },\n      \"browsingData\": {\n        \"remove\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"removeCache\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeCookies\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeDownloads\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeFormData\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeHistory\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeLocalStorage\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removePasswords\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removePluginData\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"settings\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"commands\": {\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"contextMenus\": {\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"update\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        }\n      },\n      \"cookies\": {\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAll\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAllCookieStores\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"set\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"devtools\": {\n        \"inspectedWindow\": {\n          \"eval\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 2,\n            \"singleCallbackArg\": false\n          }\n        },\n        \"panels\": {\n          \"create\": {\n            \"minArgs\": 3,\n            \"maxArgs\": 3,\n            \"singleCallbackArg\": true\n          },\n          \"elements\": {\n            \"createSidebarPane\": {\n              \"minArgs\": 1,\n              \"maxArgs\": 1\n            }\n          }\n        }\n      },\n      \"downloads\": {\n        \"cancel\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"download\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"erase\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getFileIcon\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"open\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"pause\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeFile\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"resume\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"search\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"show\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        }\n      },\n      \"extension\": {\n        \"isAllowedFileSchemeAccess\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"isAllowedIncognitoAccess\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"history\": {\n        \"addUrl\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"deleteAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"deleteRange\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"deleteUrl\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getVisits\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"search\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"i18n\": {\n        \"detectLanguage\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAcceptLanguages\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"identity\": {\n        \"launchWebAuthFlow\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"idle\": {\n        \"queryState\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"management\": {\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"getSelf\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"setEnabled\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"uninstallSelf\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        }\n      },\n      \"notifications\": {\n        \"clear\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"create\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"getPermissionLevel\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"update\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        }\n      },\n      \"pageAction\": {\n        \"getPopup\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getTitle\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"hide\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setIcon\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"setPopup\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"setTitle\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        },\n        \"show\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1,\n          \"fallbackToNoCallback\": true\n        }\n      },\n      \"permissions\": {\n        \"contains\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"request\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"runtime\": {\n        \"getBackgroundPage\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"getPlatformInfo\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"openOptionsPage\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"requestUpdateCheck\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"sendMessage\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 3\n        },\n        \"sendNativeMessage\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"setUninstallURL\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"sessions\": {\n        \"getDevices\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getRecentlyClosed\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"restore\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        }\n      },\n      \"storage\": {\n        \"local\": {\n          \"clear\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 0\n          },\n          \"get\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"getBytesInUse\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"remove\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 1\n          },\n          \"set\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 1\n          }\n        },\n        \"managed\": {\n          \"get\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"getBytesInUse\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          }\n        },\n        \"sync\": {\n          \"clear\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 0\n          },\n          \"get\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"getBytesInUse\": {\n            \"minArgs\": 0,\n            \"maxArgs\": 1\n          },\n          \"remove\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 1\n          },\n          \"set\": {\n            \"minArgs\": 1,\n            \"maxArgs\": 1\n          }\n        }\n      },\n      \"tabs\": {\n        \"captureVisibleTab\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 2\n        },\n        \"create\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"detectLanguage\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"discard\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"duplicate\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"executeScript\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getCurrent\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        },\n        \"getZoom\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getZoomSettings\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"goBack\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"goForward\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"highlight\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"insertCSS\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"move\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        },\n        \"query\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"reload\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 2\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"removeCSS\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"sendMessage\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 3\n        },\n        \"setZoom\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"setZoomSettings\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"update\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        }\n      },\n      \"topSites\": {\n        \"get\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"webNavigation\": {\n        \"getAllFrames\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"getFrame\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        }\n      },\n      \"webRequest\": {\n        \"handlerBehaviorChanged\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 0\n        }\n      },\n      \"windows\": {\n        \"create\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"get\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 2\n        },\n        \"getAll\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getCurrent\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"getLastFocused\": {\n          \"minArgs\": 0,\n          \"maxArgs\": 1\n        },\n        \"remove\": {\n          \"minArgs\": 1,\n          \"maxArgs\": 1\n        },\n        \"update\": {\n          \"minArgs\": 2,\n          \"maxArgs\": 2\n        }\n      }\n    };\n\n    if (Object.keys(apiMetadata).length === 0) {\n      throw new Error(\"api-metadata.json has not been included in browser-polyfill\");\n    }\n\n    /**\n     * A WeakMap subclass which creates and stores a value for any key which does\n     * not exist when accessed, but behaves exactly as an ordinary WeakMap\n     * otherwise.\n     *\n     * @param {function} createItem\n     *        A function which will be called in order to create the value for any\n     *        key which does not exist, the first time it is accessed. The\n     *        function receives, as its only argument, the key being created.\n     */\n    class DefaultWeakMap extends WeakMap {\n      constructor(createItem, items = undefined) {\n        super(items);\n        this.createItem = createItem;\n      }\n\n      get(key) {\n        if (!this.has(key)) {\n          this.set(key, this.createItem(key));\n        }\n\n        return super.get(key);\n      }\n    }\n\n    /**\n     * Returns true if the given object is an object with a `then` method, and can\n     * therefore be assumed to behave as a Promise.\n     *\n     * @param {*} value The value to test.\n     * @returns {boolean} True if the value is thenable.\n     */\n    const isThenable = value => {\n      return value && typeof value === \"object\" && typeof value.then === \"function\";\n    };\n\n    /**\n     * Creates and returns a function which, when called, will resolve or reject\n     * the given promise based on how it is called:\n     *\n     * - If, when called, `chrome.runtime.lastError` contains a non-null object,\n     *   the promise is rejected with that value.\n     * - If the function is called with exactly one argument, the promise is\n     *   resolved to that value.\n     * - Otherwise, the promise is resolved to an array containing all of the\n     *   function's arguments.\n     *\n     * @param {object} promise\n     *        An object containing the resolution and rejection functions of a\n     *        promise.\n     * @param {function} promise.resolve\n     *        The promise's resolution function.\n     * @param {function} promise.reject\n     *        The promise's rejection function.\n     * @param {object} metadata\n     *        Metadata about the wrapped method which has created the callback.\n     * @param {boolean} metadata.singleCallbackArg\n     *        Whether or not the promise is resolved with only the first\n     *        argument of the callback, alternatively an array of all the\n     *        callback arguments is resolved. By default, if the callback\n     *        function is invoked with only a single argument, that will be\n     *        resolved to the promise, while all arguments will be resolved as\n     *        an array if multiple are given.\n     *\n     * @returns {function}\n     *        The generated callback function.\n     */\n    const makeCallback = (promise, metadata) => {\n      return (...callbackArgs) => {\n        if (extensionAPIs.runtime.lastError) {\n          promise.reject(new Error(extensionAPIs.runtime.lastError.message));\n        } else if (metadata.singleCallbackArg ||\n                   (callbackArgs.length <= 1 && metadata.singleCallbackArg !== false)) {\n          promise.resolve(callbackArgs[0]);\n        } else {\n          promise.resolve(callbackArgs);\n        }\n      };\n    };\n\n    const pluralizeArguments = (numArgs) => numArgs == 1 ? \"argument\" : \"arguments\";\n\n    /**\n     * Creates a wrapper function for a method with the given name and metadata.\n     *\n     * @param {string} name\n     *        The name of the method which is being wrapped.\n     * @param {object} metadata\n     *        Metadata about the method being wrapped.\n     * @param {integer} metadata.minArgs\n     *        The minimum number of arguments which must be passed to the\n     *        function. If called with fewer than this number of arguments, the\n     *        wrapper will raise an exception.\n     * @param {integer} metadata.maxArgs\n     *        The maximum number of arguments which may be passed to the\n     *        function. If called with more than this number of arguments, the\n     *        wrapper will raise an exception.\n     * @param {boolean} metadata.singleCallbackArg\n     *        Whether or not the promise is resolved with only the first\n     *        argument of the callback, alternatively an array of all the\n     *        callback arguments is resolved. By default, if the callback\n     *        function is invoked with only a single argument, that will be\n     *        resolved to the promise, while all arguments will be resolved as\n     *        an array if multiple are given.\n     *\n     * @returns {function(object, ...*)}\n     *       The generated wrapper function.\n     */\n    const wrapAsyncFunction = (name, metadata) => {\n      return function asyncFunctionWrapper(target, ...args) {\n        if (args.length < metadata.minArgs) {\n          throw new Error(`Expected at least ${metadata.minArgs} ${pluralizeArguments(metadata.minArgs)} for ${name}(), got ${args.length}`);\n        }\n\n        if (args.length > metadata.maxArgs) {\n          throw new Error(`Expected at most ${metadata.maxArgs} ${pluralizeArguments(metadata.maxArgs)} for ${name}(), got ${args.length}`);\n        }\n\n        return new Promise((resolve, reject) => {\n          if (metadata.fallbackToNoCallback) {\n            // This API method has currently no callback on Chrome, but it return a promise on Firefox,\n            // and so the polyfill will try to call it with a callback first, and it will fallback\n            // to not passing the callback if the first call fails.\n            try {\n              target[name](...args, makeCallback({resolve, reject}, metadata));\n            } catch (cbError) {\n              console.warn(`${name} API method doesn't seem to support the callback parameter, ` +\n                           \"falling back to call it without a callback: \", cbError);\n\n              target[name](...args);\n\n              // Update the API method metadata, so that the next API calls will not try to\n              // use the unsupported callback anymore.\n              metadata.fallbackToNoCallback = false;\n              metadata.noCallback = true;\n\n              resolve();\n            }\n          } else if (metadata.noCallback) {\n            target[name](...args);\n            resolve();\n          } else {\n            target[name](...args, makeCallback({resolve, reject}, metadata));\n          }\n        });\n      };\n    };\n\n    /**\n     * Wraps an existing method of the target object, so that calls to it are\n     * intercepted by the given wrapper function. The wrapper function receives,\n     * as its first argument, the original `target` object, followed by each of\n     * the arguments passed to the original method.\n     *\n     * @param {object} target\n     *        The original target object that the wrapped method belongs to.\n     * @param {function} method\n     *        The method being wrapped. This is used as the target of the Proxy\n     *        object which is created to wrap the method.\n     * @param {function} wrapper\n     *        The wrapper function which is called in place of a direct invocation\n     *        of the wrapped method.\n     *\n     * @returns {Proxy<function>}\n     *        A Proxy object for the given method, which invokes the given wrapper\n     *        method in its place.\n     */\n    const wrapMethod = (target, method, wrapper) => {\n      return new Proxy(method, {\n        apply(targetMethod, thisObj, args) {\n          return wrapper.call(thisObj, target, ...args);\n        },\n      });\n    };\n\n    let hasOwnProperty = Function.call.bind(Object.prototype.hasOwnProperty);\n\n    /**\n     * Wraps an object in a Proxy which intercepts and wraps certain methods\n     * based on the given `wrappers` and `metadata` objects.\n     *\n     * @param {object} target\n     *        The target object to wrap.\n     *\n     * @param {object} [wrappers = {}]\n     *        An object tree containing wrapper functions for special cases. Any\n     *        function present in this object tree is called in place of the\n     *        method in the same location in the `target` object tree. These\n     *        wrapper methods are invoked as described in {@see wrapMethod}.\n     *\n     * @param {object} [metadata = {}]\n     *        An object tree containing metadata used to automatically generate\n     *        Promise-based wrapper functions for asynchronous. Any function in\n     *        the `target` object tree which has a corresponding metadata object\n     *        in the same location in the `metadata` tree is replaced with an\n     *        automatically-generated wrapper function, as described in\n     *        {@see wrapAsyncFunction}\n     *\n     * @returns {Proxy<object>}\n     */\n    const wrapObject = (target, wrappers = {}, metadata = {}) => {\n      let cache = Object.create(null);\n      let handlers = {\n        has(proxyTarget, prop) {\n          return prop in target || prop in cache;\n        },\n\n        get(proxyTarget, prop, receiver) {\n          if (prop in cache) {\n            return cache[prop];\n          }\n\n          if (!(prop in target)) {\n            return undefined;\n          }\n\n          let value = target[prop];\n\n          if (typeof value === \"function\") {\n            // This is a method on the underlying object. Check if we need to do\n            // any wrapping.\n\n            if (typeof wrappers[prop] === \"function\") {\n              // We have a special-case wrapper for this method.\n              value = wrapMethod(target, target[prop], wrappers[prop]);\n            } else if (hasOwnProperty(metadata, prop)) {\n              // This is an async method that we have metadata for. Create a\n              // Promise wrapper for it.\n              let wrapper = wrapAsyncFunction(prop, metadata[prop]);\n              value = wrapMethod(target, target[prop], wrapper);\n            } else {\n              // This is a method that we don't know or care about. Return the\n              // original method, bound to the underlying object.\n              value = value.bind(target);\n            }\n          } else if (typeof value === \"object\" && value !== null &&\n                     (hasOwnProperty(wrappers, prop) ||\n                      hasOwnProperty(metadata, prop))) {\n            // This is an object that we need to do some wrapping for the children\n            // of. Create a sub-object wrapper for it with the appropriate child\n            // metadata.\n            value = wrapObject(value, wrappers[prop], metadata[prop]);\n          } else if (hasOwnProperty(metadata, \"*\")) {\n            // Wrap all properties in * namespace.\n            value = wrapObject(value, wrappers[prop], metadata[\"*\"]);\n          } else {\n            // We don't need to do any wrapping for this property,\n            // so just forward all access to the underlying object.\n            Object.defineProperty(cache, prop, {\n              configurable: true,\n              enumerable: true,\n              get() {\n                return target[prop];\n              },\n              set(value) {\n                target[prop] = value;\n              },\n            });\n\n            return value;\n          }\n\n          cache[prop] = value;\n          return value;\n        },\n\n        set(proxyTarget, prop, value, receiver) {\n          if (prop in cache) {\n            cache[prop] = value;\n          } else {\n            target[prop] = value;\n          }\n          return true;\n        },\n\n        defineProperty(proxyTarget, prop, desc) {\n          return Reflect.defineProperty(cache, prop, desc);\n        },\n\n        deleteProperty(proxyTarget, prop) {\n          return Reflect.deleteProperty(cache, prop);\n        },\n      };\n\n      // Per contract of the Proxy API, the \"get\" proxy handler must return the\n      // original value of the target if that value is declared read-only and\n      // non-configurable. For this reason, we create an object with the\n      // prototype set to `target` instead of using `target` directly.\n      // Otherwise we cannot return a custom object for APIs that\n      // are declared read-only and non-configurable, such as `chrome.devtools`.\n      //\n      // The proxy handlers themselves will still use the original `target`\n      // instead of the `proxyTarget`, so that the methods and properties are\n      // dereferenced via the original targets.\n      let proxyTarget = Object.create(target);\n      return new Proxy(proxyTarget, handlers);\n    };\n\n    /**\n     * Creates a set of wrapper functions for an event object, which handles\n     * wrapping of listener functions that those messages are passed.\n     *\n     * A single wrapper is created for each listener function, and stored in a\n     * map. Subsequent calls to `addListener`, `hasListener`, or `removeListener`\n     * retrieve the original wrapper, so that  attempts to remove a\n     * previously-added listener work as expected.\n     *\n     * @param {DefaultWeakMap<function, function>} wrapperMap\n     *        A DefaultWeakMap object which will create the appropriate wrapper\n     *        for a given listener function when one does not exist, and retrieve\n     *        an existing one when it does.\n     *\n     * @returns {object}\n     */\n    const wrapEvent = wrapperMap => ({\n      addListener(target, listener, ...args) {\n        target.addListener(wrapperMap.get(listener), ...args);\n      },\n\n      hasListener(target, listener) {\n        return target.hasListener(wrapperMap.get(listener));\n      },\n\n      removeListener(target, listener) {\n        target.removeListener(wrapperMap.get(listener));\n      },\n    });\n\n    const onRequestFinishedWrappers = new DefaultWeakMap(listener => {\n      if (typeof listener !== \"function\") {\n        return listener;\n      }\n\n      /**\n       * Wraps an onRequestFinished listener function so that it will return a\n       * `getContent()` property which returns a `Promise` rather than using a\n       * callback API.\n       *\n       * @param {object} req\n       *        The HAR entry object representing the network request.\n       */\n      return function onRequestFinished(req) {\n        const wrappedReq = wrapObject(req, {} /* wrappers */, {\n          getContent: {\n            minArgs: 0,\n            maxArgs: 0,\n          },\n        });\n        listener(wrappedReq);\n      };\n    });\n\n    const onMessageWrappers = new DefaultWeakMap(listener => {\n      if (typeof listener !== \"function\") {\n        return listener;\n      }\n\n      /**\n       * Wraps a message listener function so that it may send responses based on\n       * its return value, rather than by returning a sentinel value and calling a\n       * callback. If the listener function returns a Promise, the response is\n       * sent when the promise either resolves or rejects.\n       *\n       * @param {*} message\n       *        The message sent by the other end of the channel.\n       * @param {object} sender\n       *        Details about the sender of the message.\n       * @param {function(*)} sendResponse\n       *        A callback which, when called with an arbitrary argument, sends\n       *        that value as a response.\n       * @returns {boolean}\n       *        True if the wrapped listener returned a Promise, which will later\n       *        yield a response. False otherwise.\n       */\n      return function onMessage(message, sender, sendResponse) {\n        let didCallSendResponse = false;\n\n        let wrappedSendResponse;\n        let sendResponsePromise = new Promise(resolve => {\n          wrappedSendResponse = function(response) {\n            didCallSendResponse = true;\n            resolve(response);\n          };\n        });\n\n        let result;\n        try {\n          result = listener(message, sender, wrappedSendResponse);\n        } catch (err) {\n          result = Promise.reject(err);\n        }\n\n        const isResultThenable = result !== true && isThenable(result);\n\n        // If the listener didn't returned true or a Promise, or called\n        // wrappedSendResponse synchronously, we can exit earlier\n        // because there will be no response sent from this listener.\n        if (result !== true && !isResultThenable && !didCallSendResponse) {\n          return false;\n        }\n\n        // A small helper to send the message if the promise resolves\n        // and an error if the promise rejects (a wrapped sendMessage has\n        // to translate the message into a resolved promise or a rejected\n        // promise).\n        const sendPromisedResult = (promise) => {\n          promise.then(msg => {\n            // send the message value.\n            sendResponse(msg);\n          }, error => {\n            // Send a JSON representation of the error if the rejected value\n            // is an instance of error, or the object itself otherwise.\n            let message;\n            if (error && (error instanceof Error ||\n                typeof error.message === \"string\")) {\n              message = error.message;\n            } else {\n              message = \"An unexpected error occurred\";\n            }\n\n            sendResponse({\n              __mozWebExtensionPolyfillReject__: true,\n              message,\n            });\n          }).catch(err => {\n            // Print an error on the console if unable to send the response.\n            console.error(\"Failed to send onMessage rejected reply\", err);\n          });\n        };\n\n        // If the listener returned a Promise, send the resolved value as a\n        // result, otherwise wait the promise related to the wrappedSendResponse\n        // callback to resolve and send it as a response.\n        if (isResultThenable) {\n          sendPromisedResult(result);\n        } else {\n          sendPromisedResult(sendResponsePromise);\n        }\n\n        // Let Chrome know that the listener is replying.\n        return true;\n      };\n    });\n\n    const wrappedSendMessageCallback = ({reject, resolve}, reply) => {\n      if (extensionAPIs.runtime.lastError) {\n        // Detect when none of the listeners replied to the sendMessage call and resolve\n        // the promise to undefined as in Firefox.\n        // See https://github.com/mozilla/webextension-polyfill/issues/130\n        if (extensionAPIs.runtime.lastError.message === CHROME_SEND_MESSAGE_CALLBACK_NO_RESPONSE_MESSAGE) {\n          resolve();\n        } else {\n          reject(new Error(extensionAPIs.runtime.lastError.message));\n        }\n      } else if (reply && reply.__mozWebExtensionPolyfillReject__) {\n        // Convert back the JSON representation of the error into\n        // an Error instance.\n        reject(new Error(reply.message));\n      } else {\n        resolve(reply);\n      }\n    };\n\n    const wrappedSendMessage = (name, metadata, apiNamespaceObj, ...args) => {\n      if (args.length < metadata.minArgs) {\n        throw new Error(`Expected at least ${metadata.minArgs} ${pluralizeArguments(metadata.minArgs)} for ${name}(), got ${args.length}`);\n      }\n\n      if (args.length > metadata.maxArgs) {\n        throw new Error(`Expected at most ${metadata.maxArgs} ${pluralizeArguments(metadata.maxArgs)} for ${name}(), got ${args.length}`);\n      }\n\n      return new Promise((resolve, reject) => {\n        const wrappedCb = wrappedSendMessageCallback.bind(null, {resolve, reject});\n        args.push(wrappedCb);\n        apiNamespaceObj.sendMessage(...args);\n      });\n    };\n\n    const staticWrappers = {\n      devtools: {\n        network: {\n          onRequestFinished: wrapEvent(onRequestFinishedWrappers),\n        },\n      },\n      runtime: {\n        onMessage: wrapEvent(onMessageWrappers),\n        onMessageExternal: wrapEvent(onMessageWrappers),\n        sendMessage: wrappedSendMessage.bind(null, \"sendMessage\", {minArgs: 1, maxArgs: 3}),\n      },\n      tabs: {\n        sendMessage: wrappedSendMessage.bind(null, \"sendMessage\", {minArgs: 2, maxArgs: 3}),\n      },\n    };\n    const settingMetadata = {\n      clear: {minArgs: 1, maxArgs: 1},\n      get: {minArgs: 1, maxArgs: 1},\n      set: {minArgs: 1, maxArgs: 1},\n    };\n    apiMetadata.privacy = {\n      network: {\"*\": settingMetadata},\n      services: {\"*\": settingMetadata},\n      websites: {\"*\": settingMetadata},\n    };\n\n    return wrapObject(extensionAPIs, staticWrappers, apiMetadata);\n  };\n\n  // The build process adds a UMD wrapper around this file, which makes the\n  // `module` variable available.\n  module.exports = wrapAPIs(chrome);\n} else {\n  module.exports = globalThis.browser;\n}\n","module.exports = require('./helpers/bundle-url').getBundleURL('5Z27m') + \"gpth-toggle-circled.d97c3e75.webp\" + \"?\" + Date.now();","\"use strict\";\n\nvar bundleURL = {};\nfunction getBundleURLCached(id) {\n  var value = bundleURL[id];\n  if (!value) {\n    value = getBundleURL();\n    bundleURL[id] = value;\n  }\n  return value;\n}\nfunction getBundleURL() {\n  try {\n    throw new Error();\n  } catch (err) {\n    var matches = ('' + err.stack).match(/(https?|file|ftp|(chrome|moz|safari-web)-extension):\\/\\/[^)\\n]+/g);\n    if (matches) {\n      // The first two stack frames will be this function and getBundleURLCached.\n      // Use the 3rd one, which will be a runtime in the original bundle.\n      return getBaseURL(matches[2]);\n    }\n  }\n  return '/';\n}\nfunction getBaseURL(url) {\n  return ('' + url).replace(/^((?:https?|file|ftp|(chrome|moz|safari-web)-extension):\\/\\/.+)\\/[^/]+$/, '$1') + '/';\n}\n\n// TODO: Replace uses with `new URL(url).origin` when ie11 is no longer supported.\nfunction getOrigin(url) {\n  var matches = ('' + url).match(/(https?|file|ftp|(chrome|moz|safari-web)-extension):\\/\\/[^/]+/);\n  if (!matches) {\n    throw new Error('Origin not found');\n  }\n  return matches[0];\n}\nexports.getBundleURL = getBundleURLCached;\nexports.getBaseURL = getBaseURL;\nexports.getOrigin = getOrigin;","exports.interopDefault = function (a) {\n  return a && a.__esModule ? a : {default: a};\n};\n\nexports.defineInteropFlag = function (a) {\n  Object.defineProperty(a, '__esModule', {value: true});\n};\n\nexports.exportAll = function (source, dest) {\n  Object.keys(source).forEach(function (key) {\n    if (\n      key === 'default' ||\n      key === '__esModule' ||\n      Object.prototype.hasOwnProperty.call(dest, key)\n    ) {\n      return;\n    }\n\n    Object.defineProperty(dest, key, {\n      enumerable: true,\n      get: function () {\n        return source[key];\n      },\n    });\n  });\n\n  return dest;\n};\n\nexports.export = function (dest, destName, get) {\n  Object.defineProperty(dest, destName, {\n    enumerable: true,\n    get: get,\n  });\n};\n"],"names":["globalThis","chrome","runtime","id","Error","browser","Object","getPrototypeOf","prototype","CHROME_SEND_MESSAGE_CALLBACK_NO_RESPONSE_MESSAGE","wrapAPIs","extensionAPIs","apiMetadata","keys","length","DefaultWeakMap","WeakMap","constructor","createItem","items","undefined","get","key","has","set","isThenable","value","then","makeCallback","promise","metadata","callbackArgs","lastError","reject","message","singleCallbackArg","resolve","pluralizeArguments","numArgs","wrapAsyncFunction","name","asyncFunctionWrapper","target","args","minArgs","maxArgs","Promise","fallbackToNoCallback","cbError","console","warn","noCallback","wrapMethod","method","wrapper","Proxy","apply","targetMethod","thisObj","call","hasOwnProperty","Function","bind","wrapObject","wrappers","cache","create","handlers","proxyTarget","prop","receiver","defineProperty","configurable","enumerable","desc","Reflect","deleteProperty","wrapEvent","wrapperMap","addListener","listener","hasListener","removeListener","onRequestFinishedWrappers","onRequestFinished","req","wrappedReq","getContent","onMessageWrappers","onMessage","sender","sendResponse","didCallSendResponse","wrappedSendResponse","sendResponsePromise","response","result","err","isResultThenable","sendPromisedResult","msg","error","__mozWebExtensionPolyfillReject__","catch","wrappedSendMessageCallback","reply","wrappedSendMessage","apiNamespaceObj","wrappedCb","push","sendMessage","staticWrappers","devtools","network","onMessageExternal","tabs","settingMetadata","clear","privacy","services","websites","module","exports"],"version":3,"file":"content.4a18726a.js.map"} diff --git a/extension-dev/firefox-mv2/sass.faed8373.css b/extension-dev/firefox-mv2/sass.faed8373.css index 50de0be..b4c8fa6 100644 --- a/extension-dev/firefox-mv2/sass.faed8373.css +++ b/extension-dev/firefox-mv2/sass.faed8373.css @@ -232,20 +232,6 @@ html.dark[data-gptheme="oled"] { --box-shadow-textarea: inset 0px 0px 15px 1px hsla(var(--accent-hsl) / .05) !important; } -@keyframes animFadeInClipPathCircle { - 0% { - opacity: 0; - -webkit-clip-path: circle(0%); - clip-path: circle(0%); - } - - 100% { - opacity: 1; - -webkit-clip-path: circle(100%); - clip-path: circle(100%); - } -} - @keyframes animFadeInClipPath { 0% { opacity: 0; @@ -280,7 +266,7 @@ div[data-radix-popper-content-wrapper]:not(div[data-radix-popper-content-wrapper animation: .2s linear forwards animFadeInClipPath; } -.js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-1m-2w-2p-37-14-38-2t-3c-38-2p-36-2t-2p-15-w-1a-2v-36-33-39-34-w-1a-38-2t-3c-38-19-2r-2t-32-38-2t-36-1a-31-38-19-1e-1a-2u-30-2t-3c-1a-2y-39-37-38-2x-2u-3d-19-2r-2t-32-38-2t-36]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist), .js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-1m-2w-2p-37-14-38-2t-3c-38-2p-36-2t-2p-15-w-1a-2v-36-33-39-34-w-38-2t-3c-38-2p-36-2t-2p]:not(.does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist), [role="dialog"] [id*="-content-"], [role="dialog"], .js-has-pseudo [csstools-has-2s-2x-3a-2j-2s-2p-38-2p-19-36-2p-2s-2x-3c-19-34-33-34-34-2t-36-19-2r-33-32-38-2t-32-38-19-3b-36-2p-34-34-2t-36-2l-1m-2w-2p-37-14-2j-36-33-30-2t-1p-38-33-33-30-38-2x-34-2l-15]:not(.does-not-exist):not(does-not-exist), [role="dialog"] [id*="-content-"], [role="dialog"] { +.js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-1m-2w-2p-37-14-38-2t-3c-38-2p-36-2t-2p-15-w-1a-2v-36-33-39-34-w-1a-38-2t-3c-38-19-2r-2t-32-38-2t-36-1a-31-38-19-1e-1a-2u-30-2t-3c-1a-2y-39-37-38-2x-2u-3d-19-2r-2t-32-38-2t-36]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist), .js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-1m-2w-2p-37-14-38-2t-3c-38-2p-36-2t-2p-15-w-1a-2v-36-33-39-34-w-38-2t-3c-38-2p-36-2t-2p]:not(.does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist), [role="dialog"] [id*="-content-"], .js-has-pseudo [csstools-has-2s-2x-3a-2j-2s-2p-38-2p-19-36-2p-2s-2x-3c-19-34-33-34-34-2t-36-19-2r-33-32-38-2t-32-38-19-3b-36-2p-34-34-2t-36-2l-1m-2w-2p-37-14-2j-36-33-30-2t-1p-38-33-33-30-38-2x-34-2l-15]:not(.does-not-exist):not(does-not-exist), [role="dialog"] [id*="-content-"] { will-change: opacity; animation: .2s linear forwards animFadeIn; animation: animFadeIn var(--anim-duration, .2s) linear forwards; @@ -711,6 +697,18 @@ input[type="checkbox"]:checked { background-color: var(--c-accent) !important; } +button[role="radio"] { + border-color: var(--c-accent) !important; +} + +button[role="radio"][data-state="checked"] { + background-color: var(--c-accent); +} + +button[role="radio"] svg { + color: var(--c-on-accent) !important; +} + [role="menu"] { background-color: var(--c-bg-contextmenu) !important; border-radius: 1.27273rem !important; @@ -759,6 +757,14 @@ div[data-radix-popper-content-wrapper] { z-index: calc(var(--z-modal) + 50) !important; } +.js-has-pseudo [csstools-has-2s-2x-3a-2j-2s-2p-38-2p-19-36-2p-2s-2x-3c-19-34-33-34-34-2t-36-19-2r-33-32-38-2t-32-38-19-3b-36-2p-34-34-2t-36-2l-1m-2w-2p-37-14-2j-36-33-30-2t-1p-2s-2x-2p-30-33-2v-2l-15-w-2j-36-33-30-2t-1p-2s-2x-2p-30-33-2v-2l]:not(.does-not-exist):not(.does-not-exist):not(does-not-exist) { + --box-shadow: var(--box-shadow-contextmenu) !important; +} + +div[data-radix-popper-content-wrapper]:has([role="dialog"]) [role="dialog"] { + --box-shadow: var(--box-shadow-contextmenu) !important; +} + div[data-radix-popper-content-wrapper] [role="listbox"] { border: none; padding: .8rem !important; @@ -1316,7 +1322,6 @@ html.dark div[data-radix-popper-content-wrapper]:has([role="tooltip"]) [class*=" [role="dialog"] { box-shadow: var(--box-shadow); - --anim-duration: .28s; padding: 2rem !important; padding: var(--p-dialog) !important; background-color: var(--c-bg-dialog) !important; @@ -1359,20 +1364,20 @@ html.dark div[data-radix-popper-content-wrapper]:has([role="tooltip"]) [class*=" .js-has-pseudo [csstools-has-2j-36-33-30-2t-1p-2s-2x-2p-30-33-2v-2l-1m-2w-2p-37-14-2p-2j-2w-36-2t-2u-1p-y-2w-38-38-34-37-1m-1b-1b-33-34-2t-32-2p-2x-1a-2r-33-31-1b-2t-32-38-2t-36-34-36-2x-37-2t-y-2l-15]:not(.does-not-exist):not(does-not-exist) { max-width: max-content; + --popover-surface-primary: var(--c-bg-dialog) !important; + --main-surface-primary: transparent !important; border: none !important; padding: 0 !important; } [role="dialog"]:has(a[href="https://openai.com/enterprise"]) { max-width: max-content; + --popover-surface-primary: var(--c-bg-dialog) !important; + --main-surface-primary: transparent !important; border: none !important; padding: 0 !important; } -.js-has-pseudo [csstools-has-2j-36-33-30-2t-1p-2s-2x-2p-30-33-2v-2l-1m-2w-2p-37-14-2p-2j-2w-36-2t-2u-1p-y-2w-38-38-34-37-1m-1b-1b-33-34-2t-32-2p-2x-1a-2r-33-31-1b-2t-32-38-2t-36-34-36-2x-37-2t-y-2l-15-w-1a-2q-2v-19-3b-2w-2x-38-2t]:not(.does-not-exist):not(.does-not-exist):not(does-not-exist), .js-has-pseudo [csstools-has-2j-36-33-30-2t-1p-2s-2x-2p-30-33-2v-2l-1m-2w-2p-37-14-2p-2j-2w-36-2t-2u-1p-y-2w-38-38-34-37-1m-1b-1b-33-34-2t-32-2p-2x-1a-2r-33-31-1b-2t-32-38-2t-36-34-36-2x-37-2t-y-2l-15-w-1a-2q-2v-19-2v-36-2p-3d-19-1l-1c-1c]:not(.does-not-exist):not(.does-not-exist):not(does-not-exist), :is([role="dialog"]:has(a[href="https://openai.com/enterprise"]) .bg-white, [role="dialog"]:has(a[href="https://openai.com/enterprise"]) .bg-gray-900) { - background-color: var(--c-surface-2) !important; -} - .js-has-pseudo [csstools-has-2j-36-33-30-2t-1p-2s-2x-2p-30-33-2v-2l-1m-2w-2p-37-14-2p-2j-2w-36-2t-2u-1p-y-2w-38-38-34-37-1m-1b-1b-33-34-2t-32-2p-2x-1a-2r-33-31-1b-2t-32-38-2t-36-34-36-2x-37-2t-y-2l-15-w-1a-36-33-39-32-2s-2t-2s-19-31-2s]:not(.does-not-exist):not(.does-not-exist):not(does-not-exist) { border-radius: 2.55rem !important; border-radius: var(--br-chat-bubble) !important; @@ -1465,14 +1470,11 @@ html.dark div[data-radix-popper-content-wrapper]:has([role="tooltip"]) [class*=" } [role="dialog"] table { + --main-surface-primary: transparent !important; padding: .8rem !important; padding: var(--p-contextmenu) !important; } -[role="dialog"] table .bg-white, [role="dialog"] table .bg-gray-900 { - background-color: #0000 !important; -} - [role="dialog"] table th, [role="dialog"] table td { padding-top: 1rem !important; padding-top: var(--py-btn) !important; @@ -1525,6 +1527,30 @@ html.dark div[data-radix-popper-content-wrapper]:has([role="tooltip"]) [class*=" color: var(--c-subtext-1) !important; } +.js-has-pseudo [csstools-has-2j-36-33-30-2t-1p-2s-2x-2p-30-33-2v-2l-1m-2w-2p-37-14-2x-32-34-39-38-z-3b-33-36-2z-37-34-2p-2r-2t-19-32-2p-31-2t-15]:not(#does-not-exist):not(does-not-exist) { + --main-surface-primary: transparent !important; +} + +[role="dialog"]:has(input#workspace-name) { + --main-surface-primary: transparent !important; +} + +.js-has-pseudo [csstools-has-2j-36-33-30-2t-1p-2s-2x-2p-30-33-2v-2l-1m-2w-2p-37-14-2x-32-34-39-38-2j-32-2p-31-2t-1p-37-2t-2p-38-37-2l-15-w-2x-32-34-39-38-2j-32-2p-31-2t-1p-37-2t-2p-38-37-2l]:not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist) { + margin: 0 .8rem; + background-color: hsla(var(--accent-hsl) / .3) !important; + padding: .77rem !important; + padding: var(--p-btn) !important; + height: 100% !important; +} + +[role="dialog"]:has(input[name="seats"]) input[name="seats"] { + margin: 0 .8rem; + background-color: hsla(var(--accent-hsl) / .3) !important; + padding: .77rem !important; + padding: var(--p-btn) !important; + height: 100% !important; +} + main [role="presentation"], main [role="presentation"] .bg-token-main-surface-primary.h-full { background-color: var(--c-bg-chats-container) !important; } @@ -1562,7 +1588,7 @@ main [data-testid^="conversation-turn-"] .group div[class*="lg:w-[calc(100%-115p flex-grow: 1 !important; } -main [data-testid^="conversation-turn-"] .group .bg-gray-100, main [data-testid^="conversation-turn-"] .group [class*=":bg-gray-700"] { +.js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-w-1a-2v-36-33-39-34-w-1a-2q-2v-19-38-33-2z-2t-32-19-31-2p-2x-32-19-37-39-36-2u-2p-2r-2t-19-37-2t-2r-33-32-2s-2p-36-3d-1m-2w-2p-37-14-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2m-1p-y-2c-2w-2x-37-w-36-2t-37-34-33-32-37-2t-w-3b-2p-37-y-2l-15]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist) { border: 1px solid var(--c-border); border-radius: 1.27273rem; border-radius: var(--br-contextmenu); @@ -1570,29 +1596,63 @@ main [data-testid^="conversation-turn-"] .group .bg-gray-100, main [data-testid^ background-color: #0000 !important; } -main [data-testid^="conversation-turn-"] .group .bg-gray-100 svg.rounded-full, main [data-testid^="conversation-turn-"] .group [class*=":bg-gray-700"] svg.rounded-full { +main [data-testid^="conversation-turn-"] .group .bg-token-main-surface-secondary:has(button[title^="This response was"]) { + border: 1px solid var(--c-border); + border-radius: 1.27273rem; + border-radius: var(--br-contextmenu); + color: var(--c-subtext-2) !important; + background-color: #0000 !important; +} + +.js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-w-1a-2v-36-33-39-34-w-1a-2q-2v-19-38-33-2z-2t-32-19-31-2p-2x-32-19-37-39-36-2u-2p-2r-2t-19-37-2t-2r-33-32-2s-2p-36-3d-1m-2w-2p-37-14-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2m-1p-y-2c-2w-2x-37-w-36-2t-37-34-33-32-37-2t-w-3b-2p-37-y-2l-15-w-37-3a-2v-1a-36-33-39-32-2s-2t-2s-19-2u-39-30-30]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist) { border-color: var(--avatar-color); } -main [data-testid^="conversation-turn-"] .group .bg-gray-100 button[title], main [data-testid^="conversation-turn-"] .group [class*=":bg-gray-700"] button[title] { +main [data-testid^="conversation-turn-"] .group .bg-token-main-surface-secondary:has(button[title^="This response was"]) svg.rounded-full { + border-color: var(--avatar-color); +} + +.js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-w-1a-2v-36-33-39-34-w-1a-2q-2v-19-38-33-2z-2t-32-19-31-2p-2x-32-19-37-39-36-2u-2p-2r-2t-19-37-2t-2r-33-32-2s-2p-36-3d-1m-2w-2p-37-14-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2m-1p-y-2c-2w-2x-37-w-36-2t-37-34-33-32-37-2t-w-3b-2p-37-y-2l-15-w-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2l]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist) { + border: 1px solid #0000; + transition: transform .2s cubic-bezier(.445, .05, .55, .95); + border-radius: .909091rem !important; + border-radius: var(--br-btn) !important; +} + +main [data-testid^="conversation-turn-"] .group .bg-token-main-surface-secondary:has(button[title^="This response was"]) button[title] { border: 1px solid #0000; transition: transform .2s cubic-bezier(.445, .05, .55, .95); border-radius: .909091rem !important; border-radius: var(--br-btn) !important; } -main [data-testid^="conversation-turn-"] .group .bg-gray-100 button[title] span, main [data-testid^="conversation-turn-"] .group [class*=":bg-gray-700"] button[title] span { +.js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-w-1a-2v-36-33-39-34-w-1a-2q-2v-19-38-33-2z-2t-32-19-31-2p-2x-32-19-37-39-36-2u-2p-2r-2t-19-37-2t-2r-33-32-2s-2p-36-3d-1m-2w-2p-37-14-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2m-1p-y-2c-2w-2x-37-w-36-2t-37-34-33-32-37-2t-w-3b-2p-37-y-2l-15-w-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2l-w-37-34-2p-32]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist) { + transition: color .2s cubic-bezier(.445, .05, .55, .95); + color: var(--c-subtext-2) !important; +} + +main [data-testid^="conversation-turn-"] .group .bg-token-main-surface-secondary:has(button[title^="This response was"]) button[title] span { transition: color .2s cubic-bezier(.445, .05, .55, .95); color: var(--c-subtext-2) !important; } -main [data-testid^="conversation-turn-"] .group .bg-gray-100 button[title]:hover, main [data-testid^="conversation-turn-"] .group [class*=":bg-gray-700"] button[title]:hover { +.js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-w-1a-2v-36-33-39-34-w-1a-2q-2v-19-38-33-2z-2t-32-19-31-2p-2x-32-19-37-39-36-2u-2p-2r-2t-19-37-2t-2r-33-32-2s-2p-36-3d-1m-2w-2p-37-14-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2m-1p-y-2c-2w-2x-37-w-36-2t-37-34-33-32-37-2t-w-3b-2p-37-y-2l-15-w-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2l-1m-2w-33-3a-2t-36]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist) { transform: translateY(-4%); border-color: var(--c-border) !important; background-color: #0000 !important; } -main [data-testid^="conversation-turn-"] .group .bg-gray-100 button[title]:hover span, main [data-testid^="conversation-turn-"] .group [class*=":bg-gray-700"] button[title]:hover span { +main [data-testid^="conversation-turn-"] .group .bg-token-main-surface-secondary:has(button[title^="This response was"]) button[title]:hover { + transform: translateY(-4%); + border-color: var(--c-border) !important; + background-color: #0000 !important; +} + +.js-has-pseudo [csstools-has-31-2p-2x-32-w-2j-2s-2p-38-2p-19-38-2t-37-38-2x-2s-2m-1p-2r-33-32-3a-2t-36-37-2p-38-2x-33-32-19-38-39-36-32-19-2l-w-1a-2v-36-33-39-34-w-1a-2q-2v-19-38-33-2z-2t-32-19-31-2p-2x-32-19-37-39-36-2u-2p-2r-2t-19-37-2t-2r-33-32-2s-2p-36-3d-1m-2w-2p-37-14-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2m-1p-y-2c-2w-2x-37-w-36-2t-37-34-33-32-37-2t-w-3b-2p-37-y-2l-15-w-2q-39-38-38-33-32-2j-38-2x-38-30-2t-2l-1m-2w-33-3a-2t-36-w-37-34-2p-32]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist) { + color: var(--avatar-color) !important; +} + +main [data-testid^="conversation-turn-"] .group .bg-token-main-surface-secondary:has(button[title^="This response was"]) button[title]:hover span { color: var(--avatar-color) !important; } @@ -2676,4 +2736,4 @@ html.dark [data-gpth-theme]:after, html.dark .gpth__svg-icon:after { color: var(--c-on-accent); } -/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"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A;;;;AAKA;;;;;;;AAUD;;;;;A;;;;;;;;;AC/IA;;;;AAIA;;;;;;;;AAQC;;;;;;;;ACvBH;;;;AAIC;;;;;;;A;;;;;AAaA;;;;;;AASC;;;;AAMF;;;;A;;;;A;;;;;ACXE;;;;;AAOA;;;;AAGA;;;;AAGA;;;;AAIA;;;;A;;;;;;;AEID;;;;;;;AATC;;;;AAtBA;;;;A;;;;;AASC;;;;;AAIC;;;;;AAMD;;;;;AAAA;;;;;A;;;;AA6BF;;;;AAOC;;;;AAGA;;;;A;;;;A;;;;A;;;;AAqBC;;;;A;;;;AAKH;;;;;;;;;AChFC;;;;;;;;;AAAA;;;;;;;;;AAAA;;;;AAcD;;;;AAAA;;;;AAAA;;;;;;AAAA;;;;;;AAAA;;;;;;AAwBC;;;;AAAA;;;;AAAA;;;;AAKA;;;;;;A;;;;;A;;;;;A;;;;AAmBD;;;;AAIG;;;;AAGA;;;;AAAA;;;;AAKH;;;;A;;;;A;;;;A;;;;AAkBC;;;;;;;;;;;AAWE;;;;;;;;;;;AAeC;;;;A;;;;AAUJ;;;;AAGC;;;;A;;;;;;;;;;A;;;;;;;;;;AAuBE;;;;AAIA;;;;AAGC;;;;AAMD;;;;AAIC;;;;A;;;;A;;;;;AAkBD;;;;A;;;;A;;;;;AAiDH;;;;;;AASE;;;;;;AALA;;;;AAMA;;;;AAGC;;;;;A;;;;;AAeA;;;;;AASA;;;;;A;;;;;AC/RD;;;;;AAIA;;;;AAIA;;;;A;;;;AAKC;;;;AAGA;;;;;;;AAQA;;;;;;;AAQC;;;;;;AAMA;;;;;;AAKA;;;;AAGA;;;;AAUA;;;;;;AAMC;;;;;;AAAA;;;;;;AAAA;;;;;;AAAA;;;;;;AAAA;;;;;;AAiBH;;;;AAyCE;;;;AAGA;;;;AAGA;;;;;AAIA;;;;;AAOA;;;;;AAIC;;;;;AAQA;;;;;;;A;;;;A;;;;AAyBA;;;;AAIA;;;;AAAA;;;;AAQH;;;;;AAKC;;;;;AAAA;;;;;AAOD;;;;;AAIC;;;;;AAAA;;;;;AAIA;;;;;A;;;;;A;;;;;A;;;;;AAoBC;;;;;AAAA;;;;;AAOD;;;;AAIA;;;;AAgBA;;;;;AAIA;;;;;AAIA;;;;AAGA;;;;AAKC;;;;AAIC;;;;;;AAMA;;;;;;AAOC;;;;;AAUL;;;;;AAMA;;;;A;;;;A;;;;A;;;;A;;;;;;A;;;;;;A;;;;A;;;;A;;;;A;;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;;;A;;;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;;;;;;;;;A;E;;;;;A;;;;;;;;;;;;;;;A;;;;;;;;;A;;;;;;;;;;;;;;;;;A;;;;;;;;;A;;;;;A;;;;;;;;;;;;;;;;;;;;;;;;;A;;;;;;;A;;;;A;;;;;;;;A;;;;;A;;;;;;;;A;;;;;;;;;;;;;;;;;;;;;A;;;;;;;;;;;;;;;A;;;;A;;;;A;;;;;A;;;;A;;;;;;A;;;;;A;;;;;A;;;;;;;A;;;;A;;;;;;;;;;;;;;;A;;;;A;;;;;A;;;;;;A;;;;;;;;;;;;;A;;;;;;;;;A;;;;;;;;;;A;;;;A;;;;;;;;A;;;;;A;;;;A;;;;;A;;;;A;;;;A","sources":["src/sass/index.scss","src/sass/abstract/_easing.scss","src/sass/abstract/_vars.scss","src/sass/abstract/_anims.scss","src/sass/abstract/_extends.scss","src/sass/global/_base.scss","src/sass/global/_colors-txts.scss","src/sass/global/_colors-bgs.scss","src/sass/global/_colors-borders.scss","src/sass/global/_rounded.scss","src/sass/hljs/_ros-pine-moon.scss","src/sass/hljs/oled/_ir-black.scss","src/sass/elements/_accessibility.scss","src/sass/elements/_separators.scss","src/sass/elements/_forms.scss","src/sass/elements/_menu.scss","src/sass/elements/_sidebar.scss","src/sass/elements/_prose.scss","src/sass/elements/_pre.scss","src/sass/elements/_btn.scss","src/sass/elements/_toast.scss","src/sass/elements/_tooltips.scss","src/sass/elements/_logo.scss","src/sass/elements/_modal.scss","src/sass/elements/_dialogs.scss","src/sass/elements/_right--main.scss","src/sass/elements/_right--new-chat.scss","src/sass/elements/_right--sticky.scss","src/sass/elements/_right--textarea.scss","src/sass/pages/_shared-links.scss","src/sass/pages/_gpt-store.scss","src/sass/elements/_transitions.scss","src/sass/gpthemes-els/_gpth-v2.scss"],"sourcesContent":["// @import 'font-face/_roboto';\r\n// @import 'font-face/_jetbrains';\r\n@import 'abstract/_easing';\r\n@import 'abstract/_vars';\r\n@import 'abstract/_anims';\r\n@import 'abstract/_extends';\r\n\r\n// @import 'dev/_mixins';\r\n\r\n@import 'global/_base';\r\n@import 'global/_colors-txts';\r\n@import 'global/_colors-bgs';\r\n@import 'global/_colors-borders';\r\n@import 'global/_rounded';\r\n\r\n/* Highlight,js Theme Styles */\r\n@import 'hljs/_ros-pine-moon';\r\n\r\n/* OLED hljs Themes */\r\n@import 'hljs/oled/_ir-black'; // favorit. yellowish/pink/blue jace boje\r\n// @import 'hljs/oled/_black-metal'; // fino. nije toliko colorful. pink/peach/darkteal/grey\r\n// @import 'hljs/oled/_black-metal-bathory'; // kao i ovo gore, skoro, malo jace boje, nisu tako zagasite\r\n// @import 'hljs/oled/_dark-violet'; // pinkish\r\n// @import 'hljs/oled/_pico'; // orange/green darkest\r\n\r\n// @import 'elements/_forms';\r\n@import 'elements/_accessibility';\r\n@import 'elements/_separators';\r\n@import 'elements/_forms';\r\n@import 'elements/_menu';\r\n@import 'elements/_sidebar';\r\n@import 'elements/_prose';\r\n@import 'elements/_pre';\r\n@import 'elements/_btn';\r\n@import 'elements/_toast';\r\n@import 'elements/_tooltips';\r\n@import 'elements/_logo';\r\n@import 'elements/_modal';\r\n@import 'elements/_dialogs';\r\n@import 'elements/_right--main';\r\n@import 'elements/_right--new-chat';\r\n@import 'elements/_right--sticky';\r\n@import 'elements/_right--textarea';\r\n@import 'pages/_shared-links';\r\n@import 'pages/_gpt-store';\r\n@import 'elements/_transitions';\r\n\r\n// @import 'gpthemes-els/_gpth';\r\n@import 'gpthemes-els/_gpth-v2';\r\n","/* Sine */\r\n$easeInSine: cubic-bezier(0.12, 0, 0.39, 0);\r\n$easeOutSine: cubic-bezier(0.39, 0.575, 0.565, 1);\r\n$easeInOutSine: cubic-bezier(0.445, 0.05, 0.55, 0.95);\r\n\r\n/* Quad */\r\n$easeInQuad: cubic-bezier(0.55, 0.085, 0.68, 0.53);\r\n$easeOutQuad: cubic-bezier(0.25, 0.46, 0.45, 0.94);\r\n$easeInOutQuad: cubic-bezier(0.455, 0.03, 0.515, 0.955);\r\n\r\n/* Cubic */\r\n$easeInCubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);\r\n$easeOutCubic: cubic-bezier(0.215, 0.61, 0.355, 1);\r\n$easeInOutCubic: cubic-bezier(0.645, 0.045, 0.355, 1);\r\n\r\n/* Quart */\r\n$easeInQuart: cubic-bezier(0.165, 0.84, 0.44, 1);\r\n$easeOutQuart: cubic-bezier(0.165, 0.84, 0.44, 1);\r\n$easeInOutQuart: cubic-bezier(0.77, 0, 0.175, 1);\r\n\r\n/* Quint */\r\n$easeInQuint: cubic-bezier(0.755, 0.05, 0.855, 0.06);\r\n$easeOutQuint: cubic-bezier(0.23, 1, 0.32, 1);\r\n$easeInOutQuint: cubic-bezier(0.86, 0, 0.07, 1);\r\n\r\n/* Expo */\r\n$easeInExpo: cubic-bezier(0.95, 0.05, 0.795, 0.035);\r\n$easeOutExpo: cubic-bezier(0.19, 1, 0.22, 1);\r\n$easeInOutExpo: cubic-bezier(1, 0, 0, 1);\r\n\r\n/* Cicr */\r\n$easeInCirc: cubic-bezier(0.6, 0.04, 0.98, 0.335);\r\n$easeOutCirc: cubic-bezier(0.075, 0.82, 0.165, 1);\r\n$easeInOutCirc: cubic-bezier(0.785, 0.135, 0.15, 0.86);\r\n\r\n/* Back */\r\n$easeInBack: cubic-bezier(0.6, -0.28, 0.735, 0.045);\r\n$easeOutBack: cubic-bezier(0.175, 0.885, 0.32, 1.275);\r\n$easeInOutBack: cubic-bezier(0.68, -0.55, 0.265, 1.55);",":root {\r\n\t/* ? --- Fonts --- */\r\n\t--f-fm: 'Inter', sans-serif, Söhne, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell,\r\n\t\tNoto Sans, sans-serif, Helvetica Neue, Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol,\r\n\t\tNoto Color Emoji;\r\n\t--fsz-error-404: 3rem;\r\n\r\n\t--h-header: calc(3.5rem + 0.5rem + 0.375rem);\r\n\r\n\t/* ? --- Border-radius --- */\r\n\t--br: 1rem;\r\n\t--br-chat-bubble: calc(var(--br) * 2.55);\r\n\t--br-prompt-textarea: calc(var(--br) * 2.25);\r\n\t--br-btn: calc(var(--br) / 1.1);\r\n\t--br-btn-big: calc(var(--br) * 1.2);\r\n\t--br-nav-a: var(--br-btn);\r\n\t--br-dialog: calc(var(--br) * 2.5);\r\n\t--br-contextmenu: calc(var(--br-btn) * 1.4);\r\n\t--br-pre: calc(var(--br) * 1.5);\r\n\t--br-tooltips: var(--br-btn);\r\n\r\n\t/* ? --- Paddings --- */\r\n\t--p-chat-bubble: 1.8rem;\r\n\t--p-contextmenu: 0.8rem;\r\n\t--p-contextmenu-item: 0.9rem 1rem;\r\n\t--p-prompt-textarea: 0.7rem;\r\n\t--p-tooltips: 0.2rem;\r\n\t--p-btn: 0.77rem;\r\n\t--py-btn: 1rem;\r\n\t--px-btn: 1rem;\r\n\r\n\t--p-sidebar-nav: 0.5rem;\r\n\t--p-sidebar-nav-a-new-chat: 2rem;\r\n\t--p-sidebar-nav-a: 0.6rem;\r\n\t--p-dialog: 2rem;\r\n\r\n\t/* ? --- Margins --- */\r\n\t--mt-chat-txt: 0.5rem;\r\n\t--mb-chat-txt: 1rem;\r\n\t--mb-chat-bubble: 2rem;\r\n\t--mb-sidebar-nav-li: 0.2rem;\r\n\t--my-pre: 1.5rem;\r\n\r\n\t/* ? --- Blurs --- */\r\n\t--blur-sticky: 20px;\r\n\t--blur-modal: 8px;\r\n\r\n\t/* ? --- Width --- */\r\n\t--min-w-btn: 5.5rem;\r\n\r\n\t/* ? --- Shadow things --- */\r\n\t--box-shadow-values: 0px 0px 100px 0px;\r\n\r\n\t--z-modal: 100;\r\n\r\n\t--sidebar-surface-primary: var(\r\n\t\t--c-bg-sidebar\r\n\t) !important; // GPT's variable in .bg-token-sidebar-surface-primary class. sidebar bg, nav item bg on hover\r\n\t--sidebar-surface-secondary: var(\r\n\t\t--c-surface-2\r\n\t) !important; // GPT's variable in .bg-token-sidebar-surface-secondary nav item bg on hover\r\n\t--main-surface-primary: var(\r\n\t\t--c-surface-2\r\n\t) !important; // header of tables in \"Shared links\" and \"Archived chats\". Arrow btn in new chat big buttons\r\n\t--main-surface-secondary: var(\r\n\t\t--c-surface-2\r\n\t) !important; // markdown header bg, footer of mini chat preview in \"Share Link to Chat\"\r\n\r\n\t--main-surface-tertiary: var(\r\n\t\t--c-surface-3\r\n\t) !important; // border-clr of footer of mini chat preview in \"Share Link to Chat\"\r\n\t--text-quaternary: var(--c-surface-2) !important; // sidebar collapse btn\r\n\r\n\t--popover-surface-primary: var(\r\n\t\t--c-bg-contextmenu\r\n\t) !important; // .bg-token-popover-surface-primary  - contextmenu in theme dropdown chooser\r\n\r\n\t--border-light: transparent !important; // border oko \"Uprade\" btn-a: .border-token-border-light, border oko inputa u GPTs page\r\n}\r\n\r\n/* @ ================== LIGHT ================== */\r\nhtml.light {\r\n\t/* ? ========== HSL ========== */\r\n\t/* --accent-hsl: 250 99% 65%; */\r\n\t--accent-h: 250;\r\n\t--accent-s: 99%;\r\n\t--accent-l: 65%;\r\n\t--accent-hsl: var(--accent-h) var(--accent-s) var(--accent-l);\r\n\r\n\t/* --txt-hsl: 255 86% 92%; */\r\n\t--txt-h: 0;\r\n\t--txt-s: 0%;\r\n\t--txt-l: 0%;\r\n\t--txt-hsl: var(--txt-h) var(--txt-s) var(--txt-l);\r\n\r\n\t--surface-h: 0;\r\n\t--surface-s: 0%;\r\n\t--surface-l: 85%;\r\n\t--surface-hsl: hsl(var(--surface-h) var(--surface-s) var(--surface-l));\r\n\r\n\t/* --danger-hsl: 346 51% 45% */\r\n\t--danger-h: 346;\r\n\t--danger-s: 51%;\r\n\t--danger-l: 45%;\r\n\t--danger-hsl: var(--danger-h) var(--danger-s) var(--danger-l);\r\n\t--c-danger: hsl(var(--danger-hsl));\r\n\r\n\t/* ? ========== COLORS ========== */\r\n\t--c-accent: hsl(var(--accent-hsl));\r\n\t--c-accent-light: hsl(var(--accent-h), calc(var(--accent-s) / 2), calc(var(--accent-l) * 1.3));\r\n\t--c-on-accent: hsl(var(--accent-h), var(--accent-s), calc(var(--accent-l) * 1.5));\r\n\r\n\t/* ? ========== Text colors ========== */\r\n\t--c-txt: hsl(var(--txt-hsl));\r\n\t--c-subtext-1: hsla(0, 0%, 20%);\r\n\t--c-subtext-2: hsl(0, 0%, 40%);\r\n\r\n\t/* ? ========== Surface colors ========== */\r\n\t--c-surface-1: hsl(0, 0%, var(--surface-l)); // dark\r\n\t--c-surface-2: hsl(0, 0%, calc(var(--surface-l) / 1.089)); // darker - 78.05\r\n\t--c-surface-3: hsl(0, 0%, calc(var(--surface-l) / 1.18)); // darkest - 72.03\r\n\r\n\t/* ? ========== Layout colors ========== */\r\n\t--c-bg-sidebar: var(--c-surface-1);\r\n\t--c-bg-chats-container: hsl(var(--accent-h) var(--surface-s) calc(var(--surface-l) * 1.025));\r\n\t--c-bg-chats-sticky: hsla(var(--accent-hsl) / 0.02);\r\n\r\n\t/* ? ========== Chat bubbles colors ========== */\r\n\t--c-bg-msg-user: hsla(var(--accent-hsl) / 0.08);\r\n\t--c-bg-msg-gpt: hsl(0 0% 84%);\r\n\t--c-msg-name-user: var(--c-accent);\r\n\r\n\t/* ? ========== Type message textarea colors ========== */\r\n\t--c-bg-textarea: hsla(0, 0%, calc(var(--surface-l) / 1.05));\r\n\t--c-border-textarea: var(--c-bg-textarea);\r\n\t--c-placeholder-textarea: hsla(var(--txt-hsl) / 0.6);\r\n\r\n\t/* ? ========== modal, dialog, contextmenu bg ========== */\r\n\t--c-bg-modal: hsla(var(--txt-hsl) / 0.3);\r\n\t--c-bg-dialog: var(--c-surface-2);\r\n\t--c-bg-contextmenu: var(--c-surface-3);\r\n\r\n\t/* ? ========== Tooltip bg ========== */\r\n\t--c-bg-tooltip: var(--c-accent-light);\r\n\r\n\t/* ? ========== border colors ========== */\r\n\t--c-border: hsla(var(--txt-hsl) / 0.05);\r\n\t--c-border-accent: hsla(var(--accent-hsl) / 0.1);\r\n\r\n\t/* ? ========== btn colors ========== */\r\n\t--c-btn: var(--c-on-accent);\r\n\t--c-bg-btn: var(--c-accent);\r\n\r\n\t/* ? ========== <pre>/markdown things colors ========== */\r\n\t--c-bg-pre: hsl(0, 0%, 0%);\r\n\t--c-bg-pre-header: transparent;\r\n\t--c-bg-pre-header-btn: var(--c-accent);\r\n\t--c-markdown-a: var(--c-accent);\r\n\r\n\t/* ? ========== Scrollbar colors ========== */\r\n\t--c-scrollbar-thumb: var(--c-surface-3);\r\n\t--c-scrollbar-track: transparent;\r\n\r\n\t/* ? ========== OpenAI surface colors ========== */\r\n\t/* btn u biranju teme kad nemaa nikake pozadine */\r\n\t--surface-primary: var(--c-surface-1) !important;\r\n\r\n\t/* border oko context-menu, .bg-token-surface-secondary (za active link u sidebaru)*/\r\n\t--surface-secondary: transparent !important;\r\n\r\n\t/* Selected button/link/list in settings: \"General\", \"Data controls\" */\r\n\t--surface-tertiary: var(--c-bg-msg-gpt) !important;\r\n\r\n\t/* ? ========== OpenAI text colors ========== */\r\n\t/*``` --text-primary \r\n        - body txt\r\n        - ??\r\n    */\r\n\t--text-primary: var(--c-txt) !important;\r\n\r\n\t/*``` --text-secondary \r\n        - txt ispod \"Upgrade\"\r\n        - txt ispod \"Chat history & training\" u Settingsu\r\n        - txt \"3.5\" u sticky pored \"ChatGPT 3.5\"\r\n        - kad je recimo focused sa tabom Dark u \"Themes\"\r\n        - text kad se ode na \"Upgrade\" pa ono \"Have an existing plan? See billing help\"\r\n    */\r\n\t--text-secondary: var(--c-subtext-1) !important;\r\n\r\n\t/*``` --text-tertiary \r\n        - strelica na dole pored 3.5 u sticky pored ChatGPT 3.5\r\n        - kad je nesto focused sa tabom - accessibility - npr Clear u clear all chats\r\n        - text u contextmenu kad se klikne na ChatGPT 3.5\r\n        - text kad odemo u  UPgrade pa ono USD $0/month i USD $20/month \r\n    */\r\n\t--text-tertiary: var(--c-subtext-2) !important;\r\n\r\n\t/* ? ========== PROVERITI - gray ========== */\r\n\t--gray-300: var(--text-secondary) !important;\r\n\r\n\t/* 3 tacke u listi u sidebar */\r\n\t--gray-500: var(--c-txt) !important;\r\n\r\n\t/* ? ========== BOX-SHADOW ==========*/\r\n\t--box-shadow: var(--box-shadow-values) hsla(var(--accent-hsl) / 0.1);\r\n\t// --box-shadow-contextmenu: 0px 0px 5px -2px hsla(0, 0%, 0%, 0.18);\r\n\t--box-shadow-contextmenu: inset 0px 0px 10px 2px hsla(0, 0%, 0%, 0.1);\r\n\t--box-shadow-textarea: inset 0px 0px 15px 1px hsla(0, 0%, 0%, 0.1) !important;\r\n}\r\n\r\n/* @ ================== DARK ================== */\r\nhtml.dark {\r\n\t/* ? ========== HSL ========== */\r\n\r\n\t/* --accent-hsl: 272 93% 78%; */\r\n\t--accent-h: 272;\r\n\t--accent-s: 93%;\r\n\t--accent-l: 78%;\r\n\t--accent-hsl: var(--accent-h) var(--accent-s) var(--accent-l);\r\n\r\n\t/* --txt-hsl: 255 86% 92%; */\r\n\t--txt-h: 255;\r\n\t--txt-s: 86%;\r\n\t--txt-l: 92%;\r\n\t--txt-hsl: var(--txt-h) var(--txt-s) var(--txt-l);\r\n\r\n\t--surface-h: 249;\r\n\t--surface-s: 19%;\r\n\t--surface-l: 13%;\r\n\t--surface-hsl: hsl(var(--accent-h) var(--surface-s) var(--surface-l));\r\n\r\n\t/* --danger-hsl: 356 77% 76% */\r\n\t--danger-h: 356;\r\n\t--danger-s: 77%;\r\n\t--danger-l: 76%;\r\n\t--danger-hsl: var(--danger-h) var(--danger-s) var(--danger-l);\r\n\t--c-danger: hsl(var(--danger-hsl));\r\n\r\n\t/* ? ========== COLORS ========== */\r\n\t--c-accent: hsl(var(--accent-hsl));\r\n\t--c-accent-light: hsl(var(--accent-h), calc(var(--accent-s) / 1.3), var(--accent-l));\r\n\t--c-on-accent: hsl(var(--accent-h), var(--accent-s), 10%);\r\n\r\n\t/* ? ========== Text colors ========== */\r\n\t--c-txt: hsl(var(--txt-hsl));\r\n\t--c-subtext-1: var(--c-accent-light);\r\n\t--c-subtext-2: hsl(var(--accent-h) calc(var(--accent-s) / 2) var(--accent-l)) !important;\r\n\r\n\t/* ? ========== Surface colors ========== */\r\n\t--c-surface-1: hsl(var(--accent-h), var(--surface-s), var(--surface-l)); // darkest\r\n\t--c-surface-2: hsl(var(--accent-h), var(--surface-s), calc(var(--surface-l) * 1.5)); // darker\r\n\t--c-surface-3: hsl(var(--accent-h), var(--surface-s), calc(var(--surface-l) * 2)); // dark\r\n\r\n\t/* ? ========== Layout colors ========== */\r\n\t--c-bg-sidebar: var(--c-surface-1);\r\n\t--c-bg-chats-container: hsl(var(--accent-h) var(--surface-s) calc(var(--surface-l) * 1.076));\r\n\t--c-bg-chats-sticky: hsla(var(--surface-hsl) / 0.02);\r\n\r\n\t/* ? ========== Chat bubbles colors ========== */\r\n\t--c-bg-msg-user: hsla(var(--accent-hsl) / 0.04);\r\n\t--c-bg-msg-gpt: hsla(var(--accent-hsl) / 0.08);\r\n\t--c-msg-name-user: var(--c-accent);\r\n\t// --c-msg-name-gpt: var(--c-green);\r\n\r\n\t/* ? ========== Type message textarea colors ========== */\r\n\t--c-bg-textarea: var(--c-surface-2);\r\n\t--c-border-textarea: var(--c-surface-2);\r\n\t--c-placeholder-textarea: hsl(var(--accent-hsl) / 0.8);\r\n\r\n\t/* ? ========== modal, dialog, contextmenu bg ========== */\r\n\t--c-bg-modal: hsla(var(--accent-hsl) / 0.22);\r\n\t--c-bg-dialog: var(--c-surface-2);\r\n\t--c-bg-contextmenu: var(--c-surface-3);\r\n\r\n\t/* ? ========== Tooltip bg ========== */\r\n\t--c-bg-tooltip: var(--c-accent-light);\r\n\r\n\t/* ? ========== border colors ========== */\r\n\t--c-border: var(--c-surface-3);\r\n\t--c-border-accent: hsla(var(--accent-hsl) / 0.05);\r\n\r\n\t/* ? ========== btn colors ========== */\r\n\t--c-btn: var(--c-on-accent);\r\n\t--c-bg-btn: var(--c-accent);\r\n\r\n\t/* ? ========== <pre>/markdown things colors ========== */\r\n\t--c-bg-pre: hsl(0, 0%, 0%);\r\n\t--c-bg-pre-header: transparent;\r\n\t--c-bg-pre-header-btn: var(--c-accent);\r\n\t--c-markdown-a: var(--c-accent);\r\n\r\n\t/* ? ========== Scrollbar colors ========== */\r\n\t--c-scrollbar-thumb: var(--c-surface-3);\r\n\t--c-scrollbar-track: transparent;\r\n\r\n\t/* ? ========== OpenAI surface colors ========== */\r\n\t/* btn u biranju teme kad nema nikake pozadine */\r\n\t--surface-primary: var(--c-surface-1) !important;\r\n\r\n\t/* border oko context-menu */\r\n\t--surface-secondary: transparent !important;\r\n\r\n\t/* Selected button/link/list in settings: \"General\", \"Data controls\" */\r\n\t--surface-tertiary: var(--c-bg-msg-gpt) !important;\r\n\r\n\t/* ? ========== OpenAI text colors ========== */\r\n\t/*``` --text-primary \r\n        - body txt\r\n        - ??\r\n    */\r\n\t--text-primary: var(--c-txt) !important;\r\n\r\n\t/*``` --text-secondary \r\n        - txt ispod \"Upgrade\"\r\n        - txt ispod \"Chat history & training\" u Settingsu\r\n        - txt \"3.5\" u sticky pored \"ChatGPT 3.5\"\r\n        - kad je recimo focused sa tabom Dark u \"Themes\"\r\n        - text kad se ode na \"Upgrade\" pa ono \"Have an existing plan? See billing help\"\r\n    */\r\n\t--text-secondary: var(--c-subtext-1) !important;\r\n\r\n\t/*``` --text-tertiary \r\n        - strelica na dole pored 3.5 u sticky pored ChatGPT 3.5\r\n        - kad je nesto focused sa tabom - accessibility - npr Clear u clear all chats\r\n        - text u contextmenu kad se klikne na ChatGPT 3.5\r\n        - text kad odemo u  UPgrade pa ono USD $0/month i USD $20/month \r\n    */\r\n\t--text-tertiary: var(--c-subtext-2) !important;\r\n\r\n\t/* ? ========== PROVERITI - gray ========== */\r\n\t--gray-300: var(--text-secondary) !important;\r\n\r\n\t/* 3 tacke u listi u sidebar */\r\n\t--gray-500: var(--c-txt) !important;\r\n\r\n\t/* ? ========== BOX-SHADOW ==========*/\r\n\t--box-shadow: var(--box-shadow-values) hsla(var(--accent-hsl) / 0.1);\r\n\t// --box-shadow-contextmenu: 0px 0px 30px -10px hsla(var(--accent-hsl) / 0.18);\r\n\t--box-shadow-contextmenu: inset 0px 0px 12px 1px hsla(var(--accent-hsl) / 0.13);\r\n\t--box-shadow-textarea: inset 0px 0px 15px 1px hsla(var(--accent-hsl) / 0.05) !important;\r\n}\r\n\r\n/* @ ================== OLED ================== */\r\nhtml.dark[data-gptheme='oled'] {\r\n\t/* ? ========== HSL ========== */\r\n\r\n\t/* --accent-hsl: 272 93% 78%; */\r\n\t--accent-h: 272;\r\n\t--accent-s: 93%;\r\n\t--accent-l: 78%;\r\n\t--accent-hsl: var(--accent-h) var(--accent-s) var(--accent-l);\r\n\r\n\t/* --txt-hsl: 255 86% 92%; */\r\n\t--txt-h: 255;\r\n\t--txt-s: 86%;\r\n\t--txt-l: 92%;\r\n\t--txt-hsl: var(--txt-h) var(--txt-s) var(--txt-l);\r\n\r\n\t--surface-h: 0;\r\n\t--surface-s: 0%;\r\n\t--surface-l: 0%;\r\n\t--surface-hsl: hsl(var(--accent-h) var(--surface-s) var(--surface-l));\r\n\r\n\t/* --danger-hsl: 356 77% 76% */\r\n\t--danger-h: 356;\r\n\t--danger-s: 77%;\r\n\t--danger-l: 76%;\r\n\t--danger-hsl: var(--danger-h) var(--danger-s) var(--danger-l);\r\n\t--c-danger: hsl(var(--danger-hsl));\r\n\r\n\t/* ? ========== COLORS ========== */\r\n\t--c-accent: hsl(var(--accent-hsl));\r\n\t--c-accent-light: hsl(var(--accent-h), calc(var(--accent-s) / 1.3), var(--accent-l));\r\n\t--c-on-accent: hsl(var(--accent-h), var(--accent-s), 10%);\r\n\r\n\t/* ? ========== Text colors ========== */\r\n\t--c-txt: hsl(var(--txt-hsl));\r\n\t--c-subtext-1: var(--c-accent-light);\r\n\t--c-subtext-2: hsl(var(--accent-h) calc(var(--accent-s) / 2) var(--accent-l)) !important;\r\n\r\n\t/* ? ========== Surface colors ========== */\r\n\t// --c-surface-1: black; // darkest\r\n\t--c-surface-1: black; // darkest\r\n\t// --c-surface-2: #191c1e; // darker\r\n\t// --c-surface-3: #262229; // dark\r\n\t--c-surface-2: hsl(var(--accent-h), calc(var(--surface-s) + 15%), calc(var(--surface-l) + 12%)); // darker\r\n\t// --c-surface-2: rgb(49, 220, 74); // darker\r\n\t--c-surface-3: hsl(var(--accent-h), calc(var(--surface-s) + 15%), calc(var(--surface-l) + 8%)); // dark\r\n\r\n\t/* ? ========== Layout colors ========== */\r\n\t// --c-bg-sidebar: var(--c-surface-1);\r\n\t// --c-bg-chats-container: var(--c-surface-2);\r\n\t--c-bg-sidebar: black;\r\n\t--c-bg-chats-container: black;\r\n\t--c-bg-chats-sticky: black;\r\n\r\n\t/* ? ========== Chat bubbles colors ========== */\r\n\t// --c-bg-msg-user: hsla(var(--accent-hsl) / 0.04);\r\n\t// --c-bg-msg-gpt: hsla(var(--accent-hsl) / 0.08);\r\n\t--c-bg-msg-user: hsl(var(--accent-h), calc(var(--surface-s) + 15%), calc(var(--surface-l) + 4%));\r\n\t--c-bg-msg-gpt: hsl(var(--accent-h), calc(var(--surface-s) + 20%), calc(var(--surface-l) + 6%));\r\n\t--c-msg-name-user: var(--c-accent);\r\n\t// --c-msg-name-gpt: var(--c-green);\r\n\r\n\t/* ? ========== Type message textarea colors ========== */\r\n\t--c-bg-textarea: var(--c-surface-3);\r\n\t--c-placeholder-textarea: hsl(var(--accent-hsl) / 0.8);\r\n\r\n\t/* ? ========== modal, dialog, contextmenu bg ========== */\r\n\t--c-bg-modal: hsla(var(--accent-hsl) / 0.09);\r\n\t--c-bg-dialog: var(--c-surface-1);\r\n\t--c-bg-contextmenu: var(--c-surface-3);\r\n\r\n\t/* ? ========== Tooltip bg ========== */\r\n\t--c-bg-tooltip: var(--c-accent-light);\r\n\r\n\t/* ? ========== border colors ========== */\r\n\t--c-border: var(--c-surface-3);\r\n\t--c-border-accent: hsla(var(--accent-hsl) / 0.05);\r\n\r\n\t/* ? ========== btn colors ========== */\r\n\t--c-btn: var(--c-on-accent);\r\n\t--c-bg-btn: var(--c-accent);\r\n\r\n\t/* ? ========== <pre>/markdown things colors ========== */\r\n\t--c-bg-pre: hsl(0, 0%, 0%);\r\n\t--c-bg-pre-header: transparent;\r\n\t--c-bg-pre-header-btn: var(--c-accent);\r\n\t--c-markdown-a: var(--c-accent);\r\n\r\n\t/* ? ========== Scrollbar colors ========== */\r\n\t--c-scrollbar-thumb: var(--c-surface-3);\r\n\t--c-scrollbar-track: transparent;\r\n\r\n\t/* ? ========== OpenAI surface colors ========== */\r\n\t/* btn u biranju teme kad nema nikake pozadine */\r\n\t--surface-primary: var(--c-surface-1) !important;\r\n\r\n\t/* border oko context-menu */\r\n\t--surface-secondary: transparent !important;\r\n\r\n\t/* Selected button/link/list in settings: \"General\", \"Data controls\" */\r\n\t--surface-tertiary: var(--c-bg-msg-gpt) !important;\r\n\r\n\t/* ? ========== OpenAI text colors ========== */\r\n\t/*``` --text-primary \r\n        - body txt\r\n        - ??\r\n    */\r\n\t--text-primary: var(--c-txt) !important;\r\n\r\n\t/*``` --text-secondary \r\n        - txt ispod \"Upgrade\"\r\n        - txt ispod \"Chat history & training\" u Settingsu\r\n        - txt \"3.5\" u sticky pored \"ChatGPT 3.5\"\r\n        - kad je recimo focused sa tabom Dark u \"Themes\"\r\n        - text kad se ode na \"Upgrade\" pa ono \"Have an existing plan? See billing help\"\r\n    */\r\n\t--text-secondary: var(--c-subtext-1) !important;\r\n\r\n\t/*``` --text-tertiary \r\n        - strelica na dole pored 3.5 u sticky pored ChatGPT 3.5\r\n        - kad je nesto focused sa tabom - accessibility - npr Clear u clear all chats\r\n        - text u contextmenu kad se klikne na ChatGPT 3.5\r\n        - text kad odemo u  UPgrade pa ono USD $0/month i USD $20/month \r\n    */\r\n\t--text-tertiary: var(--c-subtext-2) !important;\r\n\r\n\t/* ? ========== PROVERITI - gray ========== */\r\n\t--gray-300: var(--text-secondary) !important;\r\n\r\n\t/* 3 tacke u listi u sidebar */\r\n\t--gray-500: var(--c-txt) !important;\r\n\r\n\t/* ? ========== BOX-SHADOW ==========*/\r\n\t--box-shadow: var(--box-shadow-values) hsla(var(--accent-hsl) / 0.1);\r\n\t// --box-shadow-contextmenu: 0px 0px 30px 0px hsla(var(--accent-hsl) / 0.1);\r\n\t// --box-shadow-contextmenu: 0px 0px 30px 0px red;\r\n\t--box-shadow-contextmenu: inset 0px 0px 15px 1px hsla(var(--accent-hsl) / 0.08);\r\n\t--box-shadow-textarea: inset 0px 0px 15px 1px hsla(var(--accent-hsl) / 0.05) !important;\r\n\t// --box-shadow-contextmenu: 0px 0px 30px 0px red;\r\n}\r\n","/* @keyframes animScrollText {\r\n\t0% {\r\n\t\ttransform: translateX(0);\r\n\t}\r\n\t70% {\r\n\t\ttransform: translateX(-26%);\r\n\t}\r\n\t100% {\r\n\t\ttransform: translateX(0);\r\n\t}\r\n} */\r\n\r\n@keyframes animFadeInClipPathCircle {\r\n\t0% {\r\n\t\topacity: 0;\r\n\t\tclip-path: circle(0%);\r\n\t\t// clip-path: polygon(50% 0%, 50% 0%, 50% 100%, 50% 100%);\r\n\t}\r\n\r\n\t100% {\r\n\t\topacity: 1;\r\n\t\tclip-path: circle(100% at 50% 50%);\r\n\t\t// clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);\r\n\t}\r\n}\r\n\r\n@keyframes animFadeInClipPath {\r\n\t0% {\r\n\t\topacity: 0;\r\n\t\tclip-path: polygon(0% 0%, 100% 0%, 100% 0%, 0% 0%);\r\n\t}\r\n\t100% {\r\n\t\topacity: 1;\r\n\t\tclip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);\r\n\t}\r\n}\r\n\r\n@keyframes animFadeIn {\r\n\tfrom {\r\n\t\topacity: 0;\r\n\t}\r\n\tto {\r\n\t\topacity: 1;\r\n\t}\r\n}\r\n","%animFadeInClipPathCircle {\r\n\twill-change: opacity, clip-path;\r\n\tanimation: animFadeInClipPathCircle 0.2s linear forwards;\r\n}\r\n%animFadeInClipPath {\r\n\twill-change: opacity, clip-path;\r\n\tanimation: animFadeInClipPath 0.2s linear forwards;\r\n}\r\n%animFadeIn {\r\n\twill-change: opacity;\r\n\tanimation: animFadeIn var(--anim-duration, 0.2s) linear forwards;\r\n}\r\n%animFadeOut {\r\n\twill-change: opacity;\r\n\tanimation: animFade var(--anim-duration, 0.4s) linear reverse;\r\n}\r\n\r\n%link_default {\r\n\tposition: relative;\r\n\ttext-decoration: none;\r\n\tcolor: var(--c-accent) !important;\r\n\t// display: inline-block;\r\n\ttransition: opacity 0.3s ease;\r\n\r\n\t/* Style for the ::after pseudo-element (initially hidden) */\r\n\t&::after {\r\n\t\tcontent: '';\r\n\t\tposition: absolute;\r\n\t\twidth: 100%;\r\n\t\theight: 2px;\r\n\t\tbottom: -5px;\r\n\t\tleft: 0;\r\n\t\t// right: 0; /* Set right to cover the entire link */\r\n\t\tbackground-color: currentColor;\r\n\t\tborder-radius: 20px;\r\n\t\ttransition: transform 0.3s $easeOutCubic;\r\n\t}\r\n}\r\n%link_hover_underlined {\r\n\t@extend %link_default;\r\n\r\n\t/* Style for the ::after pseudo-element (initially hidden) */\r\n\t&::after {\r\n\t\ttransform: scaleX(1);\r\n\t\ttransform-origin: bottom left;\r\n\t}\r\n\r\n\t&:hover::after {\r\n\t\ttransform: scaleX(0);\r\n\t\ttransform-origin: bottom right;\r\n\t}\r\n}\r\n%link_hover_underless {\r\n\t@extend %link_default;\r\n\r\n\t&::after {\r\n\t\ttransform: scaleX(0);\r\n\t\ttransform-origin: bottom right;\r\n\t}\r\n\r\n\t&:hover::after {\r\n\t\ttransform: scaleX(1);\r\n\t\ttransform-origin: bottom left;\r\n\t}\r\n}\r\n\r\n%sidebar_link_item_btns_bg {\r\n\t/* \r\n        hsla(0, 0%, calc(var(--surface-l) / 1.089), 0.7) \r\n        - this nice resolve but it doesn't work bcs it is BLACK-ISH, WTF ???? \r\n    */\r\n\t// background-image: linear-gradient(to right, hsla(0, 0%, calc(var(--surface-l) / 1.089), 0.7) 0%, var(--c-surface-2) 30%, var(--c-surface-2) 100%) !important;\r\n\tbackground-color: var(--c-surface-2) !important;\r\n\tborder-top-right-radius: inherit;\r\n\tborder-bottom-right-radius: inherit;\r\n\tpadding-left: 0.5rem;\r\n}\r\n","/* Ovo nece zbog CORS-a */\r\n// @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');\r\n// @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:ital,wght@0,300;0,400;0,700;1,400&display=swap');\r\n\r\nhtml,\r\nbody {\r\n\t--text-primary: var(--c-txt) !important;\r\n\r\n\tfont-family: var(--f-fm) !important;\r\n\tcolor: var(--c-txt) !important;\r\n\tbackground-color: var(--c-bg-chats-container) !important;\r\n}\r\n\r\na {\r\n\tfont-family: var(--f-fm) !important;\r\n}\r\n\r\n/* scrollbar-color for For Firefox */\r\n@-moz-document url-prefix() {\r\n\thtml {\r\n\t\tscrollbar-color: var(--c-scrollbar-thumb) var(--c-scrollbar-track); // second parameter (transparent) is for bg-thumb\r\n\t}\r\n}\r\n// /* scrollbar-thumb-color for Chromium-based browsers */\r\n::-webkit-scrollbar-thumb {\r\n\tbackground-color: var(--c-scrollbar-thumb) !important;\r\n}\r\n\r\n::selection {\r\n\tbackground-color: hsla(var(--accent-hsl) / 0.5) !important;\r\n\tcolor: var(--c-txt) !important;\r\n\t// color: var(--c-on-accent) !important;\r\n}\r\n\r\nbutton {\r\n\t--text-primary: var(--c-txt) !important;\r\n}\r\n\r\ninput::placeholder,\r\ntextarea::placeholder {\r\n\tcolor: var(--c-placeholder) !important;\r\n\topacity: 0.6 !important;\r\n}\r\n\r\n.h-px {\r\n\tdisplay: none !important;\r\n}\r\n\r\n/* .markdown {\r\n    [type=\"checkbox\"]:checked {\r\n        background-color: var(--c-accent);\r\n        --svg: escape('<svg viewBox=\"0 0 16 16\" fill=\"@{base}\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0z\"/></svg>'\r\n        );\r\n        // background-image: \"~url('data:image/svg+xml;charset=utf-8,@{svg}')\";\r\n        background-image: \"~url('data:image/svg+xml;charset=utf-8,#{var(--svg)}}')\";\r\n    }\r\n} */\r\n\r\ncode.hljs {\r\n\t// font-size: .85rem !important;\r\n\t// font-family: 'JetBrains Mono', monospace !important;\r\n\tletter-spacing: -0.2px;\r\n}\r\n\r\n/* === BORDER RADIUS */\r\n.rounded-md {\r\n\tborder-radius: var(--br-btn);\r\n}\r\n\r\n/* Shadow in \"Upgrade your plan\" */\r\n.shadow-md {\r\n\tbox-shadow: none;\r\n}\r\n\r\n/* \"404 |\" in \"404 | This page could not be found\" */\r\n.next-error-h1 {\r\n\tcolor: var(--c-accent);\r\n\tborder-color: currentColor !important;\r\n\tfont-size: var(--fsz-error-404) !important;\r\n\tfont-weight: 600 !important;\r\n}\r\n","/* ==== TYPOGRAPHY COLORS */\r\n\r\n/*\r\n\t- Obrati paznju na TOOLTIP clr i accent btns sa svg!!!\r\n \t- Have to add .toast-root .text-white[role='alert'] into :not() but it somehow affects tooltip txt color, wtf. And I cant investigate tooltip bcs it goes hidden when it is shown only on javascript mouseover.\r\n\r\n\t- [class*='text-gray-'] utice i na div[data-radix-popper-content-wrapper] tj \"Theme\" dropdown iteme te ne mogu da se overwrituju tamo u _menu.scss. Zato sam sklonila !important\r\n*/\r\n[class*='text-gray-']:not(.text-gray-100, .text-gray-400, .text-gray-500, .text-gray-600),\r\n[class*='text-white']:not(.btn-primary .text-white, .bg-green-600, svg, .toast-root .text-white[role='alert']) {\r\n\tcolor: var(--c-txt);\r\n}\r\n\r\n/* \r\n - Is this conversation helpful so far? 👍👎\r\n - tg-500 je recimo btn svg u \"Archived/Shared Links\" popup\r\n - tg-400 (dark) tg-600 (light) in \"You have no shared links.\"\r\n*/\r\n.text-gray-400,\r\n.text-gray-600,\r\n.text-gray-500 {\r\n\tcolor: var(--c-subtext-2) !important;\r\n\t// color: red !important;\r\n}\r\n\r\n/* .text-gizmo-gray-500 is the footer txt in dialog \"YOU'RE INVITED TO PLUS\" */\r\n.text-gizmo-gray-500,\r\n.text-gray-100 {\r\n\tcolor: var(--c-subtext-1) !important;\r\n}\r\n\r\n.text-token-text-secondary {\r\n\tcolor: var(--c-subtext-1) !important;\r\n\t// color: red !important;\r\n}\r\n\r\n/* \"Log out\", \"Delete all conversations\", \"Delete chat\" */\r\n.text-red-500 {\r\n\tcolor: var(--c-danger) !important;\r\n}\r\n\r\n/* Intro page (before login) */\r\n[class*='text-[#FE7600]'] {\r\n\tcolor: var(--c-accent);\r\n}\r\n","/* === BG COLORS */\r\n\r\n/* \r\n- Textarea msg bg. \r\n- \"Share link to chat\" dialog chat min duplicate (.bg-white)\r\n- Chat history & Training\" checkbox bullet\r\n */\r\n.bg-gray-900,\r\n.bg-white {\r\n\tbackground-color: var(--c-surface-1) !important;\r\n\t// background-color: red !important;\r\n}\r\n\r\n/* \r\n// ``` .bg-gray-50\r\n\t\t- \"❓\" btn \r\n\r\n// ``` .bg-gray-100\r\n\t\t- Line | in \"Is this conversation helpful so far?\r\n👍 👎 | ✖️\" */\r\n.bg-gray-50,\r\n.bg-gray-100 {\r\n\tbackground-color: var(--c-surface-2) !important;\r\n}\r\n// .bg-gray-50 {\r\n// \t// background-color: var(--c-surface-2) !important;\r\n// \tbackground-color: red !important;\r\n// }\r\n\r\n/* \r\n - \"Was this response better or worse?\" el when clicked on regenerate answer btn \r\n - \"Delete all shared links\" in \"Shared liks\" dialog\r\n - line | between \"s this conversation helpful so far? 👍👎\" and \"x\"\r\n*/\r\n// .bg-gray-100,\r\n// [class*=\":bg-gray-700\"] {\r\n//     background-color: red !important;\r\n// }\r\n\r\n/* hover:bg-gray-100 dark:hover:bg-gray-600 \r\n\t- GPTs Store PAGE - \"Featured\" section items :hover states\r\n\t- GPTs Store PAGE - \"Top picks\", \"DALLE\", \"Writing\" etc tags :hover states \r\n\t- GPTs Store PAGE - \"Search public GPTs\" search list item bg :hover states */\r\n[class*='dark:hover:bg-gray-600'] {\r\n\t&:hover {\r\n\t\tbackground-color: var(--c-surface-1) !important;\r\n\t\t// background-color: red !important;\r\n\t}\r\n}\r\n\r\n/* GPTs store PAGE - \"Trending\" section items hover state\" */\r\n[class*='dark:hover:bg-gray-700'] {\r\n\t&:hover {\r\n\t\tbackground-color: var(--c-surface-2) !important;\r\n\t}\r\n}\r\n\r\n/* [role='menuitem'] :hover state */\r\n[class*='dark:hover:bg-gray-800'],\r\n[class*='dark:hover:bg-white/5'] {\r\n\t&:hover {\r\n\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t// background-color: red !important;\r\n\t}\r\n}\r\n\r\n/* \r\n\t- GPTS store PAGE - \"Search public GPTs\" search list item bg \r\n\t- GPTs Store PAGE - \"Top picks\", \"DALLE\", \"Writing\" etc tags \r\n\t- GPTs Store PAGE - \"Featured\" section items bg\r\n\t- GPTs Store PAGE - Bg for Buttons left and right arrow for \"Top picks\", \"DALLE\", \"Writing\" etc tags on smaller screens\r\n\t- Inputs in \"Delete Account- Are you sure\" dialog  */\r\n[class*='dark:bg-gray-700'] {\r\n\tbackground-color: var(--c-surface-2) !important;\r\n\t// background-color: red !important;\r\n}\r\n\r\n/* \r\n- \"Shared links\" PAGE - overall BG !!!!\r\n- GPTS store PAGE - \"Search public GPTs\" search input bg. Nema klase za light temu te selektujem klasom za darks \r\n- Bg of mini chat-bubble in \"Share link to chat\" dialog.\r\n- Textarea in [role=\"dialog\"] */\r\n[class*='dark:bg-gray-800'] {\r\n\tbackground-color: var(--c-bg-chats-container) !important; // var(--c-surface-3)\r\n\t// background-color: var(--c-surface-1) !important;\r\n}\r\n\r\n/* Shared chats PAGE - green button \"Upgrade to Plus to create your own GPT\" */\r\n[class*='bg-green-600'] {\r\n\tbackground-color: var(--c-accent) !important;\r\n\tcolor: var(--c-on-accent) !important;\r\n}\r\n\r\n[class*='bg-red-500/10'] {\r\n\tbackground-color: hsla(var(--danger-hsl) / 0.11) !important;\r\n\tcolor: var(--c-danger) !important;\r\n\t// background-color: var(--c-danger) !important;\r\n}\r\n\r\n/* Like icon in \"Provide aditional feedback\" dialog when clicked liked answer */\r\n// .bg-green-100 {}\r\n\r\n.bg-gradient-to-l,\r\n.bg-gradient-to-r {\r\n\t--gradient-color-from: var(--c-surface-1);\r\n\t--gradient-color-to: transparent;\r\n\r\n\t--tw-gradient-from: var(--gradient-color-from) var(--tw-gradient-from-position) !important;\r\n\t--tw-gradient-to: var(--gradient-color-to) var(--tw-gradient-to-position);\r\n}\r\n\r\n/* Active link bg in sidebar listitem */\r\n.bg-token-surface-secondary {\r\n\t--surface-secondary: var(--c-surface-2) !important;\r\n}\r\n\r\n/* \r\n- Dialogs\r\n- Tabs in \"Settings\"\r\n- Table <thead> els\r\n- Share Link > Mini chat conversation\r\n- Context menu items in Share Link > Mini chat conversation\r\n- Context menu items in Settings > Theme ddl and Theme\r\n- Sticky header \r\n- Prompt textarea\r\n- Sidebar Circled gpt logo - NEWCHAT/CLEAR CHAT\r\n- Circled gpt logo \"How can I help you today\r\n- Scrolldown btn\r\n- ❓ btn on bottom right\r\n- Checkbox circle\r\n- GPTs Store PAGE - Search query section\r\n- GPTs Store PAGE - Search query section link-on-hover - CHANGE IT !!\r\n */\r\n[class*='bg-white'],\r\n.bg-token-sidebar-surface-secondary {\r\n\tbackground-color: var(--c-surface-2) !important;\r\n\t// @include borderBoxShadow(red);\r\n\t// background-color: red;\r\n}\r\n\r\n/* \r\n- Sidebar\r\n- Sidebar sticky behind NEWCHAT btn\r\n- Sidebar \"Today\", \"Yesterday\"... time headings \r\n- Sidebar user profile picture\r\n- Tooltip\r\n- ChatGPT 3.5 btn in sticky header\r\n- Context menu items in 3dots\r\n- Context menu items in ChatGPT 3.5\r\n- Markdown <pre>\r\n- Prompt textarea send button\r\n- GPTs - active pill (\"Top Picks\")\r\n */\r\n[class*='bg-black'],\r\n.bg-token-sidebar-surface-primary {\r\n\tbackground-color: var(--c-surface-1);\r\n\t// @include borderBoxShadow(lightgreen);\r\n\t// background-color: lightgreen;\r\n}\r\n","/* === BORDER COLORS */\r\n\r\n/* Border in textarea in \"Custom Instructions\" dialog */\r\n.border-gray-100 {\r\n\t// border-color: var(--c-surface-1) !important;\r\n\tborder-color: transparent !important;\r\n}\r\n\r\n.border-gray-200 {\r\n\tborder-color: var(--c-surface-2) !important;\r\n}\r\n\r\n/* Border in inputs in \"Upgrade your Plan\" dialog */\r\n.border-gray-300 {\r\n\t// border-color: red !important;\r\n\t// border-color: transparent !important;\r\n\tborder: none;\r\n}\r\n\r\n/* \"Upgrade your plan\" dialog, \"Share link to chat\" dialog chat min duplicate */\r\n[class*='dark:border-gray-700'] {\r\n\tborder-color: transparent !important;\r\n\t// border-color: red !important;\r\n}\r\n\r\n/* Border in dialogs after main heading - DARK */\r\nhtml.dark [class*=':border-white/10'] {\r\n\tborder-color: var(--c-border-accent) !important;\r\n}\r\n\r\n/* Border in dialogs after main heading - LIGHT */\r\nhtml.light [class*=':border-white/10'] {\r\n\tborder-color: var(--c-border) !important;\r\n}\r\n\r\n/* \"This content may violate content policy...\" warning */\r\n[class*='border-red-500'] {\r\n\tborder-color: var(--c-danger) !important;\r\n}\r\n","// [class*='rounded-xl'] {\r\n// \tborder-radius: var(--br-btn-big) !important;\r\n// \tborder: 1px solid red !important;\r\n// }\r\n// [class*='rounded-lg'] {\r\n// \tborder-radius: var(--br-btn) !important;\r\n// \tborder: 1px solid green !important;\r\n// }\r\n// [class*='rounded-md'] {\r\n// \tborder-radius: var(--br-btn) !important;\r\n// \tborder: 1px solid yellow !important;\r\n// }\r\n/* \r\n- Scroll down btn.\r\n- GPTs - product card circle pictures\r\n- General profile pic: \"NEWCHAT\", \"Upgrade Plan\", user profile in sidebar.\r\n- Check switch btn\r\n- Close sidebar btn */\r\n.rounded-full {\r\n\t// @include borderBoxShadow(rgb(2, 0, 139));\r\n}\r\n\r\n/* \r\n- GPTs - pill tags in sticky header */\r\n.rounded-3xl {\r\n\t// border-radius: var(--br-btn-big) !important;\r\n\t// @include borderBoxShadow(purple);\r\n}\r\n/* \r\n- Dialogs\r\n- ChatGPT 3.5 btn in sticky header\r\n- GPTs - Search input\r\n- GPTs - product cards\r\n- NEW CHAT big buttons\r\n- NEW CHAT big btns on hover svg wrapper etc\r\n- Custom Instructions > \"bubble\" on right side when textarea focused */\r\n.rounded-xl {\r\n\tborder-radius: var(--br-btn-big) !important;\r\n\t// @include borderBoxShadow(red);\r\n}\r\n\r\n/* \r\n- All sidebar <a> buttons/links\r\n- Theme btn,\r\n- SVGs: Share Link, Send btn in pompt-textarea,  \r\n- GPTs - sticky btns \"Global view\" and \"My GPTs\"\r\n- GPTs - search query section product cards/items \r\n- Toast root notify\r\n-  */\r\n.rounded-lg {\r\n\tborder-radius: var(--br-btn) !important;\r\n\t// @include borderBoxShadow(orange);\r\n}\r\n\r\n/*\r\n- Small btns in chat footer.\r\n- <pre>\r\n- Tab btns in dialog.\r\n- contextmenu-items in \"Theme\" ddl\r\n- \"Was this response better or worse? 👍👎\" el when clicked on regenerate answer btn and its inner buttons */\r\n.rounded-md {\r\n\tborder-radius: var(--br-btn) !important;\r\n\t// @include borderBoxShadow(yellow);\r\n}\r\n\r\n/*\r\n- Textarea in dialog.\r\n- menuitems in ChatGPT 3.5 contextmenu and contextmenu in 3dots in sidebar  (\"Share\", \"Rename\", \"Delete\") */\r\n.rounded {\r\n\tborder-radius: var(--br-btn) !important;\r\n\t// @include borderBoxShadow(lightgreen);\r\n}\r\n\r\n.rounded-t-md {\r\n\t// overflow: clip !important;\r\n\tborder-top-left-radius: var(--br-btn) !important;\r\n\tborder-top-right-radius: var(--br-btn) !important;\r\n}\r\n.rounded-b-md {\r\n\t// overflow: clip !important;\r\n\tborder-bottom-left-radius: var(--br-btn) !important;\r\n\tborder-bottom-right-radius: var(--br-btn) !important;\r\n}\r\n","/*!\r\n  Theme: Rosé Pine Moon\r\n  Author: Emilia Dunfelt <sayhi@dunfelt.se>\r\n  License: ~ MIT (or more permissive) [via base16-schemes-source]\r\n  Maintainer: @highlightjs/core-team\r\n  Version: 2021.09.0\r\n*/\r\n\r\n/*\r\n  WARNING: DO NOT EDIT THIS FILE DIRECTLY.\r\n\r\n  This theme file was auto-generated from the Base16 scheme ros-pine-moon\r\n  by the Highlight.js Base16 template builder.\r\n\r\n  - https://github.com/highlightjs/base16-highlightjs\r\n*/\r\n\r\n/*\r\nbase00  #232136  Default Background\r\nbase01  #2a273f  Lighter Background (Used for status bars, line number and folding marks)\r\nbase02  #393552  Selection Background\r\nbase03  #59546d  Comments, Invisibles, Line Highlighting\r\nbase04  #817c9c  Dark Foreground (Used for status bars)\r\nbase05  #e0def4  Default Foreground, Caret, Delimiters, Operators\r\nbase06  #f5f5f7  Light Foreground (Not often used)\r\nbase07  #d9d7e1  Light Background (Not often used)\r\nbase08  #ecebf0  Variables, XML Tags, Markup Link Text, Markup Lists, Diff Deleted\r\nbase09  #eb6f92  Integers, Boolean, Constants, XML Attributes, Markup Link Url\r\nbase0A  #f6c177  Classes, Markup Bold, Search Text Background\r\nbase0B  #ea9a97  Strings, Inherited Class, Markup Code, Diff Inserted\r\nbase0C  #3e8fb0  Support, Regular Expressions, Escape Characters, Markup Quotes\r\nbase0D  #9ccfd8  Functions, Methods, Attribute IDs, Headings\r\nbase0E  #c4a7e7  Keywords, Storage, Selector, Markup Italic, Diff Changed\r\nbase0F  #b9b9bc  Deprecated, Opening/Closing Embedded Language Tags, e.g. <?php ?>\r\n*/\r\npre {\r\n\t--c-bg-pre: #232136;\r\n}\r\npre code.hljs {\r\n\tdisplay: block;\r\n\toverflow-x: auto;\r\n\tpadding: 1em;\r\n}\r\n\r\ncode.hljs {\r\n\tpadding: 3px 5px;\r\n}\r\n\r\n.hljs,\r\n/* markdown pre */\r\npre .bg-token-main-surface-secondary,\r\n/* markdown header - lang name and copy btn */\r\npre .bg-token-main-surface-secondary>div:has(> span) {\r\n\tcolor: #e0def4 !important;\r\n\tbackground: var(--c-bg-pre) !important;\r\n}\r\n\r\n.hljs::selection,\r\n.hljs ::selection {\r\n\tbackground-color: #393552 !important;\r\n\tcolor: #e0def4 !important;\r\n}\r\n\r\n/* purposely do not highlight these things */\r\n.hljs-formula,\r\n.hljs-params,\r\n.hljs-property {\r\n}\r\n\r\n/* base03 - #59546d -  Comments, Invisibles, Line Highlighting */\r\n.hljs-comment {\r\n\tcolor: #59546d !important;\r\n}\r\n\r\n/* base04 - #817c9c -  Dark Foreground (Used for status bars) */\r\n.hljs-tag {\r\n\tcolor: #817c9c !important;\r\n}\r\n\r\n/* base05 - #e0def4 -  Default Foreground, Caret, Delimiters, Operators */\r\n.hljs-subst,\r\n.hljs-punctuation,\r\n.hljs-operator {\r\n\tcolor: #e0def4 !important;\r\n}\r\n\r\n.hljs-operator {\r\n\topacity: 0.7;\r\n}\r\n\r\n/* base08 - Variables, XML Tags, Markup Link Text, Markup Lists, Diff Deleted */\r\n.hljs-bullet,\r\n.hljs-variable,\r\n.hljs-template-variable,\r\n.hljs-selector-tag,\r\n.hljs-name,\r\n.hljs-deletion {\r\n\tcolor: #ecebf0 !important;\r\n}\r\n\r\n/* base09 - Integers, Boolean, Constants, XML Attributes, Markup Link Url */\r\n.hljs-symbol,\r\n.hljs-number,\r\n.hljs-link,\r\n.hljs-attr,\r\n.hljs-variable.constant_,\r\n.hljs-literal {\r\n\tcolor: #eb6f92 !important;\r\n}\r\n\r\n/* base0A - Classes, Markup Bold, Search Text Background */\r\n.hljs-title,\r\n.hljs-class .hljs-title,\r\n.hljs-title.class_ {\r\n\tcolor: #f6c177 !important;\r\n}\r\n\r\n.hljs-strong {\r\n\tfont-weight: bold;\r\n\tcolor: #f6c177 !important;\r\n}\r\n\r\n/* base0B - Strings, Inherited Class, Markup Code, Diff Inserted */\r\n.hljs-code,\r\n.hljs-addition,\r\n.hljs-title.class_.inherited__,\r\n.hljs-string {\r\n\tcolor: #ea9a97 !important;\r\n}\r\n\r\n/* base0C - Support, Regular Expressions, Escape Characters, Markup Quotes */\r\n.hljs-built_in,\r\n.hljs-doctag,\r\n/* guessing */\r\n.hljs-quote,\r\n.hljs-keyword.hljs-atrule,\r\n.hljs-regexp {\r\n\tcolor: #3e8fb0 !important;\r\n}\r\n\r\n/* base0D - Functions, Methods, Attribute IDs, Headings */\r\n.hljs-function .hljs-title,\r\n.hljs-attribute,\r\n.ruby .hljs-property,\r\n.hljs-title.function_,\r\n.hljs-section {\r\n\tcolor: #9ccfd8 !important;\r\n}\r\n\r\n/* base0E - Keywords, Storage, Selector, Markup Italic, Diff Changed */\r\n.hljs-type,\r\n/* .hljs-selector-id, */\r\n/* .hljs-selector-class, */\r\n/* .hljs-selector-attr, */\r\n/* .hljs-selector-pseudo, */\r\n.hljs-template-tag,\r\n.diff .hljs-meta,\r\n.hljs-keyword {\r\n\tcolor: #c4a7e7 !important;\r\n}\r\n\r\n.hljs-emphasis {\r\n\tcolor: #c4a7e7 !important;\r\n\tfont-style: italic;\r\n}\r\n\r\n/* base0F - Deprecated, Opening/Closing Embedded Language Tags, e.g. <?php ?> */\r\n.hljs-meta,\r\n/*\r\n    prevent top level .keyword and .string scopes\r\n    from leaking into meta by accident\r\n  */\r\n.hljs-meta .hljs-keyword,\r\n.hljs-meta .hljs-string {\r\n\tcolor: #b9b9bc !important;\r\n}\r\n\r\n.hljs-meta .hljs-keyword,\r\n/* for v10 compatible themes */\r\n.hljs-meta-keyword {\r\n\tfont-weight: bold;\r\n}\r\n","/*\r\n  IR_Black style (c) Vasily Mikhailitchenko <vaskas@programica.ru>\r\n*/\r\nhtml.dark[data-gptheme='oled'] {\r\n\t.hljs {\r\n\t\tbackground: var(--c-bg-pre) !important;\r\n\t\tcolor: #f8f8f8 !important;\r\n\t}\r\n\r\n\t.hljs-comment,\r\n\t.hljs-quote,\r\n\t.hljs-meta {\r\n\t\tcolor: #7c7c7c !important;\r\n\t}\r\n\r\n\t.hljs-keyword,\r\n\t.hljs-selector-tag,\r\n\t.hljs-tag,\r\n\t.hljs-name {\r\n\t\tcolor: #96cbfe !important;\r\n\t}\r\n\r\n\t.hljs-attribute,\r\n\t.hljs-selector-id {\r\n\t\tcolor: #ffffb6 !important;\r\n\t}\r\n\r\n\t.hljs-string,\r\n\t.hljs-selector-attr,\r\n\t.hljs-selector-pseudo,\r\n\t.hljs-addition {\r\n\t\tcolor: #a8ff60 !important;\r\n\t}\r\n\r\n\t.hljs-subst {\r\n\t\tcolor: #daefa3 !important;\r\n\t}\r\n\r\n\t.hljs-regexp,\r\n\t.hljs-link {\r\n\t\tcolor: #e9c062 !important;\r\n\t}\r\n\r\n\t.hljs-title,\r\n\t.hljs-section,\r\n\t.hljs-type,\r\n\t.hljs-doctag {\r\n\t\tcolor: #ffffb6 !important;\r\n\t}\r\n\r\n\t.hljs-symbol,\r\n\t.hljs-bullet,\r\n\t.hljs-variable,\r\n\t.hljs-template-variable,\r\n\t.hljs-literal {\r\n\t\tcolor: #c6c5fe !important;\r\n\t}\r\n\r\n\t.hljs-number,\r\n\t.hljs-deletion {\r\n\t\tcolor: #ff73fd !important;\r\n\t}\r\n\r\n\t.hljs-emphasis {\r\n\t\tfont-style: italic;\r\n\t}\r\n\r\n\t.hljs-strong {\r\n\t\tfont-weight: bold;\r\n\t}\r\n}\r\n","*,\r\n:after,\r\n:before {\r\n\t--tw-ring-color: hsl(\r\n\t\tvar(--accent-h),\r\n\t\tcalc(var(--accent-s) / 1.5),\r\n\t\tvar(--accent-l)\r\n\t) !important; // out border (box-shadow) on dialog btns color\r\n\t--tw-ring-offset-color: var(--c-bg-dialog) !important; // inner border on dialog btns color\r\n}\r\n\r\n/*\r\n    buttons, switch btns, svg buttons, input, menuitem (no btns in dialog tho, it is special style w/ --tw-ring-color and --tw-ring-offset-color vars) border/outline on keyboard focus or :focus-visible\r\n*/\r\n// :is(button, a, [role=\"menuitem\"]:not([class*=\"text-red-\"]), [role=\"dialog\"] textarea):not(.btn-primary, .btn-neutral, textarea#prompt-textarea) {\r\n//     &:focus-visible {\r\n//         outline: 2.5px solid hsl(var(--accent-h), calc(var(--accent-s) / 1.5), var(--accent-l));\r\n//     }\r\n// }\r\n\r\n/* \r\nTheme dropdown deo ima zeleni border za :focus-visible.\r\n  - [aria-label=\"Delete shared link\"] is recycle svg icon in \"Shared link\" table\r\n  - .btn-neutral:not([role=\"combobox\"] is in theme dropdown \"Dark/Light/System\" button\") \r\n*/\r\n:focus-visible:not(\r\n\t\t.btn-primary,\r\n\t\t.btn-danger,\r\n\t\t.btn-neutral:not([role='combobox'], .bg-token-surface-tertiary input),\r\n\t\ttextarea,\r\n\t\tinput,\r\n\t\t[aria-label='Delete shared link'],\r\n\t\t[class*='text-red-']\r\n\t) {\r\n\toutline: 2.5px solid hsl(var(--accent-h), calc(var(--accent-s) / 1.5), var(--accent-l));\r\n}\r\n\r\n:focus-visible:is(.btn-neutral[role='combobox']) {\r\n\tborder: none !important;\r\n}\r\n\r\n/* 🗑️ Recycle icon in \"Shared link\" table */\r\n:focus-visible:is([aria-label='Delete shared link'], [class*='text-red-']) {\r\n\t--tw-ring-color: var(--c-danger) !important;\r\n\t// --tw-ring-color: var(--c-danger) !important;\r\n\toutline: 2.5px solid var(--c-danger) !important;\r\n}\r\n\r\n.btn-danger {\r\n\t--tw-ring-color: var(--c-danger) !important;\r\n\t// outline: 2.5px solid var(--c-danger) !important;\r\n\r\n\t// &:focus {\r\n\t//     outline-color: var(--c-bg-dialog) !important;\r\n\t// }\r\n}\r\n\r\ninput {\r\n}\r\n","[role=\"separator\"] {\r\n    border-color: var(--c-border) !important;\r\n}","input[type='checkbox'] {\r\n\tpadding: 7px !important;\r\n\tborder: 2px solid var(--c-accent) !important;\r\n\tbackground-color: transparent !important;\r\n\tborder-radius: 4px;\r\n\r\n\t&:checked {\r\n\t\taccent-color: var(--c-accent) !important;\r\n\t\tbackground-color: var(--c-accent) !important;\r\n\t}\r\n}\r\n","[role='menu'] {\r\n\tbackground-color: var(--c-bg-contextmenu) !important;\r\n\tborder-radius: var(--br-contextmenu) !important;\r\n\t// border: none !important;\r\n\tpadding: var(--p-contextmenu) !important;\r\n\t// border: 1px solid hsla(var(--accent-hsl) / 0.2) !important;\r\n\tbox-shadow: var(--box-shadow-contextmenu) !important;\r\n\t// transition: all 0.3s ease-in-out;\r\n\r\n\t&:not(nav[aria-label='Chat history'] .group[data-headlessui-state] [role='menu']) {\r\n\t\t@extend %animFadeInClipPath;\r\n\t}\r\n\r\n\t[role='menuitem'] {\r\n\t\tbackground-color: inherit !important;\r\n\t\tpadding: var(--p-contextmenu-item) !important;\r\n\t\tborder-radius: var(--br-btn) !important;\r\n\t\ttransition: background-color 0.3s ease-in-out, color 0.3s ease-in-out;\r\n\r\n\t\t/* TODO dark:hover:bg-white/5   ima vec u globalu. Videti da li obrisati ovah hover i ostaviti onaj tamo samo. Rizicno je malo, sta ako se promeni ta klasa */\r\n\t\t&:hover {\r\n\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Remove padding for menu in sidebar bottom */\r\n\tnav {\r\n\t\tpadding: 0 !important;\r\n\t}\r\n\r\n\t&:has(a[href=\"https://openai.com/policies\"])\r\n\t{\r\n\t\ta:first-child span {\r\n\t\t\tcolor: var(--c-accent) !important;\r\n\t\t\tfont-weight: bold;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n// TODO check if this broke something else because it is the element hard for targeting\r\n/* \"New Chat\" xs in contextmenu in ChatGPT 3.5 */\r\n[data-radix-popper-content-wrapper] .absolute.right-11 {\r\n\t--svg-w: 24px;\r\n\t--gap-from-svg: 20px;\r\n\tright: calc(\r\n\t\tvar(--p-contextmenu) + var(--svg-w) + var(--gap-from-svg)\r\n\t) !important; // p-contextmenu = 10px, svg-w = 24px, gap-from-svg = 20px = (10px + 24px + 20px) = 54px. This is calculated spacing of \"New Chat\" in contextmenu in ChatGPT 3.5 and right edge in contextmenuitem\r\n}\r\n\r\n/* __ MODAL - Choose theme context menu & tooltips?  */\r\ndiv[data-radix-popper-content-wrapper] {\r\n\tz-index: calc(var(--z-modal) + 50) !important;\r\n\t// z-index: 200 !important;\r\n\r\n\t/* Mora not role=menu da ne bih selektovala i onaj contextmenu u sidebar kad se klikne na prompt listitem 3 dots za opcije i div[data-radix-popper-content-wrapper]:has([role='tooltip']) da ne bih selektovala tooltip */\r\n\t&:not(\r\n\t\t\tdiv[data-radix-popper-content-wrapper]:has(div[role='menu']),\r\n\t\t\tdiv[data-radix-popper-content-wrapper]:has([role='tooltip'])\r\n\t\t) {\r\n\t\t@extend %animFadeInClipPath;\r\n\t}\r\n\r\n\t/* Context menu bg */\r\n\t// .bg-white {\r\n\t// .bg-token-popover-surface-primary\r\n\t[role='listbox'] {\r\n\t\t// background-color: var(--c-bg-contextmenu) !important;\r\n\t\tpadding: var(--p-contextmenu) !important;\r\n\t\tborder-radius: var(--br-contextmenu) !important;\r\n\t\tbox-shadow: var(--box-shadow-contextmenu) !important;\r\n\t\toverflow: visible !important; // for what is this? hhh\r\n\t\tborder: none;\r\n\t}\r\n\r\n\t[data-radix-collection-item] {\r\n\t\tborder-radius: var(--br-btn);\r\n\t\tpadding: var(--p-contextmenu-item) !important;\r\n\t\theight: auto !important;\r\n\t\tmargin-bottom: 4px;\r\n\t\toverflow: visible !important;\r\n\t\toutline: none !important;\r\n\t}\r\n\r\n\t/* MODAL - Choose theme context menuitem hover */\r\n\t[data-radix-collection-item][data-state='unchecked'] {\r\n\t\t&:hover {\r\n\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t\toutline: none !important; // TODO this is temp fix. This ecause there were somewhite uglu outline on hover. But this also breaks :focus-visible accessibility style...\r\n\t\t}\r\n\t}\r\n\r\n\t/* MODAL - Choose theme context menuitem hover active */\r\n\t[data-state='checked'] {\r\n\t\tbackground-color: var(--c-bg-btn) !important;\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t}\r\n}\r\n\r\n// .data-radix-popper-content-wrapper {\r\n// \t// z-index: calc(var(--z-modal) + 200) !important;\r\n// \tz-index: 200 !important;\r\n// }\r\n","/* Sidebar bg-color */\r\n.bg-token-sidebar-surface-primary:has(nav[aria-label='Chat history']) {\r\n\t/* --surface-primary fix dark/black color for a:hover states */\r\n\t// --surface-primary: var(--c-surface-2) !important;\r\n\t// --surface-primary: red !important;\r\n\tcolor: var(--c-txt) !important;\r\n\t// background-color: var(--c-bg-sidebar) !important;\r\n\r\n\t/* Fix white txt on \"NEW CHAT\" in sidebar for light especially */\r\n\tnav a > * {\r\n\t\tcolor: var(--c-txt) !important;\r\n\t}\r\n}\r\n\r\nnav[aria-label='Chat history'] {\r\n\tpadding: var(--p-sidebar-nav) !important;\r\n\r\n\t// ! Strange black rectangle (.bg-black class) over \"New Chat\" btn when on links: https://chat.openai.com/gpts/discovery and https://chat.openai.com/g/g-UBYTKWkPj\r\n\t/* .sticky.bg-black:has(a[href='/']) {\r\n\t\tbackground-color: var(--c-bg-sidebar);\r\n\t\tpadding-bottom: 1rem !important;\r\n\t} */\r\n\r\n\t/* Parent of \"NEW CHAT\" btn */\r\n\t.sticky {\r\n\t\tbackground-color: var(--c-bg-sidebar) !important;\r\n\t\tbackdrop-filter: blur(0px) !important;\r\n\t\tmargin-bottom: 0.5rem !important;\r\n\t\tpadding-bottom: 0.5rem;\r\n\t}\r\n\r\n\t/* CLEAR CHATS div - Visible when unchecked \"Chat learning & Training\" in Settings */\r\n\t.absolute.left-0.top-0.overflow-hidden {\r\n\t\tbackground-color: var(--c-bg-sidebar) !important;\r\n\t\toverflow-y: scroll;\r\n\r\n\t\tmin-height: 50vh !important;\r\n\r\n\t\t.bg-gradient-to-t {\r\n\t\t\topacity: 0;\r\n\t\t}\r\n\t}\r\n\r\n\t/* NEW CHAT + LIST of chats in nav. Adding padding-left prevent :focus-visible style in those elements to be cropped from the left because of the overflow-hidden */\r\n\t.overflow-y-auto {\r\n\t\tpadding-left: 0.3rem !important;\r\n\r\n\t\t/* Your Firefox-specific styles here */\r\n\t\t@-moz-document url-prefix() {\r\n\t\t\tpadding-right: 0.8rem !important; // this add only for Firefox\r\n\t\t}\r\n\t}\r\n\r\n\t/*\r\n\tParent of time heading (of Today, Yesterday) in sidebar.\r\n\t! div:has(> h3)  is selector for the same but in GPTs page !!! */\r\n\t[data-projection-id]:has(h3),\r\n\tdiv:has(> h3) {\r\n\t\tmargin-top: 1.5rem !important;\r\n\t\tmargin-bottom: 0.3rem !important;\r\n\r\n\t\t/* Today, Yesterday - Time heading in sidebar */\r\n\t\th3 {\r\n\t\t\tdisplay: inline-block !important;\r\n\t\t\tcolor: var(--c-accent) !important;\r\n\t\t\tbackground-color: hsl(var(--accent-hsl) / 0.2) !important;\r\n\t\t\tborder-radius: 100vw;\r\n\t\t\ttext-transform: uppercase;\r\n\t\t\tfont-weight: bold;\r\n\t\t\tpadding: 0.5rem 1rem !important;\r\n\t\t\theight: auto !important;\r\n\t\t\tline-height: 1 !important;\r\n\t\t}\r\n\t}\r\n\r\n\ta {\r\n\t\tcolor: var(--c-txt) !important;\r\n\t\tpadding: var(--p-sidebar-nav-a) !important;\r\n\t\tfont-family: var(--f-fm) !important;\r\n\t\tborder-radius: var(--br-nav-a) !important;\r\n\t\t// border-radius: inherit !important;\r\n\r\n\t\ttransition: background-color 0.3s ease-in-out;\r\n\r\n\t\t/* \"New Chat\" link (first in nav in sidebar) */\r\n\t\t&[href='/'] {\r\n\t\t\tborder: 2px solid var(--c-surface-2);\r\n\t\t\tpadding: var(--p-sidebar-nav-a-new-chat) !important;\r\n\t\t\ttext-transform: uppercase;\r\n\t\t}\r\n\r\n\t\t/* \"Upgrade\" link in nav bg */\r\n\t\tspan.rounded-full.border-token-border-light {\r\n\t\t\tborder-color: transparent !important;\r\n\t\t\tbackground-color: var(--c-accent) !important;\r\n\r\n\t\t\t/* SVG icon in \"Upgrade\" link in nav */\r\n\t\t\t& > svg {\r\n\t\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tli {\r\n\t\tmargin-bottom: var(--mb-sidebar-nav-li) !important;\r\n\r\n\t\t.group {\r\n\t\t\t--duration-trans: 0.3s;\r\n\t\t\t--duration-anim: 0.2s;\r\n\t\t\toverflow: hidden;\r\n\r\n\t\t\t&.bg-token-sidebar-surface-secondary,\r\n\t\t\t&.bg-token-sidebar-surface-primary {\r\n\t\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t\t}\r\n\r\n\t\t\t/* TODO mozda dodati opet u buducnosti. Sad nema poente, jer text parent ima overflow hidden i isece citav text, a ova animacija ga svakako opet samo prikaze onoliki koliki je. Ako stavim overlow: visible na hover, animacija je razlicito primenjena na svaki element, posto je width za svaki eelement razlicit u zavisnosti od duzine texta, i animacija ne moze sa istim durationom da bude ista, a sadrzaj treba mnogo vise da se skroluje. A ne zelim jos da koristim javascript za fetchvanje width-a svakog elementa posebno i onda posebni duration za svaki element u zavisnosti od duzine texta. A i preopteretila bi se extenzija da lupujem kroz svaki element, citam podatke i dodajem animaciju, samo zarad tog efekta. Nije vredno */\r\n\t\t\t// &:hover {\r\n\t\t\t// \t/* Anim long (all actually) txt to scroll left to be shown whole */\r\n\t\t\t// \ta[href^='/c/'] > div.relative.grow.overflow-hidden.whitespace-nowrap {\r\n\t\t\t// \t\tanimation: animScrollText 3s $easeInOutSine backwards;\r\n\t\t\t// \t}\r\n\t\t\t// }\r\n\r\n\t\t\t/* 3dots btn */\r\n\t\t\tbutton {\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t}\r\n\r\n\t\t\t/* Archive btn */\r\n\t\t\tspan {\r\n\t\t\t\tbutton {\r\n\t\t\t\t\tcolor: var(--c-subtext-1) !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t/* Active-link 3-dots and archive btns wrapper */\r\n\t\t\t& > div.absolute {\r\n\t\t\t\t@extend %sidebar_link_item_btns_bg;\r\n\t\t\t}\r\n\r\n\t\t\ta[href^='/c/'] {\r\n\t\t\t\t/* & > div.relative.grow.overflow-hidden.whitespace-nowrap {\r\n\t\t\t\t\twill-change: transform;\r\n\t\t\t\t} */\r\n\t\t\t\t/* ! NOW `.bg-token-surface-primary` IS DELETED BY OPENAI ffs*/\r\n\t\t\t\t/* Selected/active/hover link item */\r\n\t\t\t\t// &.bg-token-surface-primary {\r\n\t\t\t\t//     background-color: var(--c-surface-2) !important;\r\n\r\n\t\t\t\t//     /* 3 dots btn bg-gradient */\r\n\t\t\t\t//     .bg-gradient-to-l {\r\n\t\t\t\t//         opacity: 1 !important;\r\n\t\t\t\t//     }\r\n\t\t\t\t// }\r\n\r\n\t\t\t\t/* 3 dots btn bg-gradient - <div> u <a> i <div> u <button> */\r\n\t\t\t\t.bg-gradient-to-l {\r\n\t\t\t\t\tdisplay: none !important;\r\n\t\t\t\t\t// border: 2px solid red !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t/* 3 dots > \"Rename\" clicked - style of input parent and input  - this is <div> next to <a> */\r\n\t\t\t.bg-token-surface-tertiary {\r\n\t\t\t\tpadding: var(--p-sidebar-nav-a) !important;\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t\tbackground-color: var(\r\n\t\t\t\t\t--c-surface-3\r\n\t\t\t\t) !important; // NOTE: bg can't be transparent-ish; it cause txt behind to be visible\r\n\t\t\t\tborder: 1px solid var(--c-border) !important;\r\n\t\t\t\tborder-radius: var(--br-nav-a) !important;\r\n\r\n\t\t\t\t/* This make it full width of <li>, from left to right */\r\n\t\t\t\tleft: 0 !important;\r\n\t\t\t\tright: 0 !important;\r\n\r\n\t\t\t\t/* Rename input.\r\n                    ! DO NOT TOUCH PADDING! TXT BEHIND GOIN TO BE VISIBLE. WTF??? \r\n                */\r\n\t\t\t\tinput {\r\n\t\t\t\t\t// input rename border color on focused\r\n\t\t\t\t\t--tw-ring-color: transparent !important;\r\n\t\t\t\t\tcaret-color: var(--c-accent);\r\n\t\t\t\t\tborder: none !important;\r\n\t\t\t\t\toutline: none !important;\r\n\t\t\t\t\tbox-shadow: none !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// TODO add better styling to this btn\r\n\t/* User profile btn in sidebar bottom */\r\n\t.group[data-headlessui-state] {\r\n\t\t/* User profile btn in sidebar bottom */\r\n\t\tbutton[aria-haspopup='true'] {\r\n\t\t\tborder-radius: var(--br-nav-a);\r\n\t\t\tmargin-top: 1rem;\r\n\r\n\t\t\t/* Username div */\r\n\t\t\t.font-semibold {\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/* Sidebar bottom - Log Out  */\r\n\t\t[role='menu'] {\r\n\t\t\tanimation: none !important;\r\n\t\t\t// transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;\r\n\t\t\ttransition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;\r\n\r\n\t\t\t[role='menuitem']:last-child {\r\n\t\t\t\tcolor: var(--c-danger) !important;\r\n\r\n\t\t\t\tsvg {\r\n\t\t\t\t\tcolor: var(--c-danger) !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/*  Border-radius for all elements that have .rounded-lg class in <nav> of sidebar. ALi on zezne border-radiusu i contextmenu u bottom sidebar jer i on ima ovu klasu. Zato sad dodajem <li> */\r\n\t// TODO mozda mogu obrisati, ako global ostane ista ova\r\n\t.rounded-lg {\r\n\t\tborder-radius: var(--br-nav-a) !important;\r\n\t}\r\n}\r\n",".prose {\r\n\t// --tw-prose-code: currentColor !important; // Code text in markdown\r\n\t// --tw-prose-bold: currentColor !important; // Bold text in markdown\r\n\tcolor: var(--c-txt) !important;\r\n\tfont-size: 1rem !important;\r\n\r\n\t--tw-prose-body: var(--c-txt) !important;\r\n\t--tw-prose-headings: var(--c-accent) !important;\r\n\t// --tw-prose-lead: red !important;\r\n\t--tw-prose-links: var(--c-accent) !important;\r\n\t--tw-prose-bold: currentColor !important;\r\n\t--tw-prose-counters: var(--c-accent) !important;\r\n\t--tw-prose-bullets: var(--c-accent) !important;\r\n\t--tw-prose-hr: var(--c-border) !important;\r\n\t--tw-prose-quotes: var(--c-subtext-2) !important;\r\n\t--tw-prose-quote-borders: var(--c-subtext-2) !important;\r\n\t// --tw-prose-captions: red !important;\r\n\t--tw-prose-code: currentCode !important;\r\n\t// --tw-prose-pre-code: var(--c-accent) !important;\r\n\t--tw-prose-th-borders: var(--c-border) !important;\r\n\t--tw-prose-td-borders: var(--c-border) !important;\r\n\r\n\t/* ___For Dark theme??? */\r\n\t--tw-prose-invert-body: var(--c-txt) !important;\r\n\t--tw-prose-invert-headings: var(--c-accent) !important;\r\n\t// --tw-prose-invert-lead: #9ca3af !important;\r\n\t--tw-prose-invert-links: var(--c-accent) !important;\r\n\t--tw-prose-invert-bold: currentColor !important;\r\n\t--tw-prose-invert-counters: var(--c-accent) !important;\r\n\t--tw-prose-invert-bullets: var(--c-accent) !important;\r\n\t--tw-prose-invert-hr: var(--c-border) !important;\r\n\t--tw-prose-invert-quotes: var(--c-subtext-2) !important;\r\n\t--tw-prose-invert-quote-borders: var(--c-subtext-2) !important;\r\n\t// --tw-prose-invert-captions: #9ca3af !important;\r\n\t--tw-prose-invert-code: currentColor !important;\r\n\t// --tw-prose-invert-pre-code: var(--c-accent) !important;\r\n\t// --tw-prose-invert-pre-bg: red !important;\r\n\t--tw-prose-invert-th-borders: var(--c-border) !important;\r\n\t--tw-prose-invert-td-borders: var(--c-border) !important;\r\n\r\n\t/* Markdown Links rendered in GPT answers */\r\n\ta {\r\n\t\t@extend %link_hover_underlined;\r\n\t}\r\n\r\n\t/* Style Markdown Checkboxes */\r\n\tinput[type='checkbox'] {\r\n\t\tpadding: 7px !important;\r\n\t\tborder: 2px solid var(--c-accent) !important;\r\n\t\tbackground-color: transparent !important;\r\n\t\tborder-radius: 4px;\r\n\r\n\t\t&:checked {\r\n\t\t\taccent-color: var(--c-accent) !important;\r\n\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t}\r\n\t}\r\n\r\n\ttable {\r\n\t\t/* TODO - this overflow cause cutting the border edges of latest <tr> child, wtf. So I have to add border to <table> also (down where <th>, <td> are) */\r\n\t\toverflow: hidden;\r\n\t\tborder-radius: var(--br-btn) !important;\r\n\r\n\t\tthead {\r\n\t\t\t--tw-prose-headings: var(--c-txt) !important;\r\n\r\n\t\t\tborder-collapse: collapse !important;\r\n\t\t\tborder-spacing: 0 !important;\r\n\t\t\tbackground-color: hsla(var(--txt-hsl) / 0.15) !important;\r\n\t\t\t// background-color: hsla(var(--accent-hsl) / .15) !important;\r\n\t\t\ttext-transform: uppercase;\r\n\t\t\tfont-size: 0.8rem !important;\r\n\t\t}\r\n\r\n\t\t&,\r\n\t\tth,\r\n\t\ttd {\r\n\t\t\tborder: 1px solid var(--c-border) !important;\r\n\t\t}\r\n\r\n\t\tth,\r\n\t\ttd {\r\n\t\t\tpadding: 0.5rem !important;\r\n\t\t}\r\n\r\n\t\t/* Make odd rows darker */\r\n\t\ttbody tr:nth-child(2n) {\r\n\t\t\tbackground-color: hsla(var(--txt-hsl) / 0.03) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* Thead color for Dark theme */\r\nhtml.dark .prose {\r\n\ttable thead {\r\n\t\t--tw-prose-headings: var(--c-on-accent) !important;\r\n\t\tbackground-color: hsla(var(--accent-hsl) / 0.7) !important;\r\n\t\t// background-color: var(--c-accent-light) !important;\r\n\t}\r\n}\r\n\r\n/* Code-snippets markdown and markdown header */\r\nhtml.dark[data-gptheme='oled'] {\r\n\t.prose {\r\n\t\t.bg-black {\r\n\t\t\tbackground-color: #000 !important;\r\n\r\n\t\t\t/* Markdown code-snippets (prose) header */\r\n\t\t\t.bg-token-surface-primary {\r\n\t\t\t\tbackground-color: #000 !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n","/* === RIGHT - <pre> - MARKDOWN CODE IN CHATS ===*/\r\n\r\npre {\r\n\tborder-radius: var(--br-pre) !important;\r\n\tmargin: var(--my-pre) auto !important;\r\n\r\n\t--c-bg-pre: #232136;\r\n\t--main-surface-secondary: var(--c-bg-pre) !important;\r\n\r\n\t.bg-gray-950 {\r\n\t\tbackground-color: var(--c-bg-pre) !important;\r\n\t}\r\n\r\n\t// overflow: clip !important;\r\n\r\n\t/*  === RIGHT - <pre> - header === */\r\n\t/*``` Header selector: .bg-black>div:has(> span) */\r\n\r\n\t/* // TODO\r\n\t\tThere seems to be an unusual behavior with the top-border-radius for the Markdown header, causing it to lose its radius and appear almost sharp (aka the original design). This occurs when the inspect element is open or when the screen size is reduced. It happens like a flash when hovering over the chat-bubble and then moving out of it completely or when in the inspect mode, also hovering COPY btn, idk. I cannot fully comprehend the issue, but it seems that the original design is being restored, despite my attempts to override it using various methods:\r\n\r\n\t\tI have rewritten the .rounded-md class and also the .rounded-t-md class for the header. I applied overflow: clip/hidden to <pre> and the Markdown header. However, none of these measures seem to resolve the issue.\r\n\r\n\t\t// ! UPDATE\r\n\t\tIt seems it works fine now.\r\n\t*/\r\n\t/* Markdown */\r\n\t/* Code name in markdown header (html, php, css, etc) */\r\n\tdiv:has(button) span {\r\n\t\tcolor: var(--c-accent-light) !important;\r\n\t}\r\n\r\n\t/* 'Copy code' btn in markdown header */\r\n\tbutton:has(svg) {\r\n\t\ttext-transform: uppercase !important;\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t\tbackground-color: var(--c-bg-pre-header-btn);\r\n\t\tpadding: var(--p-btn);\r\n\t\tborder-radius: var(--br-btn) !important;\r\n\r\n\t\t/* SVG icons before 'Copy code' btn in md */\r\n\t\tsvg {\r\n\t\t\tcolor: currentColor !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\nhtml.dark[data-gptheme='oled'] {\r\n\tpre {\r\n\t\t--c-bg-pre: #000;\r\n\t}\r\n}\r\n",".btn {\r\n\tbackground-color: var(--c-bg-btn) !important;\r\n\tcolor: var(--c-btn) !important;\r\n\tborder-radius: var(--br-btn) !important;\r\n\tborder: none !important;\r\n\r\n\t&:not(.btn-small) {\r\n\t\t// padding: 1.5rem !important;\r\n\t\tpadding: var(--p-btn) !important;\r\n\t}\r\n}\r\n\r\n/* .btn-primary {\r\n    background-color: var(--c-bg-btn) !important;\r\n} */\r\n\r\n.btn-danger {\r\n\tbackground-color: var(--c-danger) !important;\r\n\tcolor: var(--c-bg-chats-container) !important;\r\n}\r\n\r\n/* === RIGHT - Scroll Down arrow bg LIGHT  === */\r\n// html.light main [role=\"presentation\"] button.absolute.rounded-full {\r\n//     background-color: var(--c-txt) !important;\r\n// }\r\n\r\n/* === RIGHT - Scroll Down arrow bg DARK  === */\r\n// html.dark main [role=\"presentation\"] button.absolute.rounded-full {\r\n//     background-color: var(--c-accent) !important;\r\n// }\r\nmain [role='presentation'] button.absolute.rounded-full {\r\n\tbackground-color: var(--c-accent) !important;\r\n\tbox-shadow: var(--box-shadow-contextmenu);\r\n\r\n\t/* RIGHT - Scroll Down arrow SVG Color === */\r\n\tsvg {\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t}\r\n}\r\n\r\n/* === All the .btn inside dialogs not having svg icon inside */\r\n[role='dialog'] {\r\n\t.btn:not(.btn:has(svg)) {\r\n\t\tmin-width: var(--min-w-btn);\r\n\t}\r\n\r\n\t&:not(.PopoverContent) .btn-neutral {\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\tcolor: var(--c-txt) !important;\r\n\t}\r\n\r\n\t/* \".PopoverContent\" je recimo menu od btn u \"Shared Link to Chat\" 3dots menu (Shared your Name & Delete Link) */\r\n\t&.PopoverContent {\r\n\t\t.btn-neutral {\r\n\t\t\tbackground-color: transparent !important;\r\n\t\t\tcolor: var(--c-txt) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* === Settings > Tabs === */\r\n[role='tablist'] button {\r\n\tpadding: var(--p-btn) !important;\r\n\tbackground-color: transparent !important;\r\n\r\n\t&[data-state='active'],\r\n\t&:hover {\r\n\t\t// TODO Ovo je ok za desktop, ali za manje je bolje surface-1. Takodje dodati horiz gap izmedju\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\t}\r\n}\r\n\r\n/* === Checkbox button - switcher. In \"Chat history & training: and \"Custom instructions\" */\r\nbutton[role='switch'] {\r\n\t/* Checkbox ON */\r\n\t&:has([data-state='checked']) {\r\n\t\tbackground-color: var(--c-accent) !important;\r\n\r\n\t\t/* Chb bullet/circle checked */\r\n\t\tspan {\r\n\t\t\tbackground-color: var(--c-on-accent) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Checkbox OFF */\r\n\t&:has([data-state='unchecked']) {\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\r\n\t\t/* Chb bullet/circle unchecked */\r\n\t\tspan {\r\n\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.5) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* === Settings > Theme selector drop down */\r\nbutton[role='combobox'] {\r\n\t@extend .btn;\r\n\t@extend .btn-neutral;\r\n\tmin-width: var(--min-w-btn);\r\n\r\n\t/* Theme btn - fix height smaller then other btns */\r\n\theight: auto;\r\n\tline-height: inherit;\r\n}\r\n\r\n/* === ❓ circle btn on bottom right */\r\nbutton[id*='headlessui-menu-button'][class*='bg-gray-50'] {\r\n\tcolor: var(--c-txt) !important;\r\n\tborder: none !important;\r\n}\r\n\r\n/* Intro page (before Login or Register) */\r\nbutton[class*='bg-[#3C46FF] text-[#fff]'] {\r\n\t@extend .btn;\r\n}\r\n","/* \"Copied your User ID to clipboard\" parent - toast message when clicking on ? icon bottom right on username */\r\n.toast-root {\r\n\tmargin-top: -0.4rem !important;\r\n\r\n\t/* \r\n\t- \"Copied your User ID to clipboard\" - clicked on 'youremail@example.com' in context menu on ? fixed button in bottom right.\r\n\t- Alert shown on \"ℹ️ Unable to load conversations j10898d8ds8a-dsa689d6as9-s68d7a-j10898d8ds8a\" */\r\n\t[role='alert'] {\r\n\t\tbackground-color: var(--c-accent) !important;\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t\tpadding: var(--p-btn) !important;\r\n\t\tborder-radius: var(--br-btn) !important; // TODO obrisati ovo ako ostavim u globalu .rounded-lg onaj\r\n\t\tborder: none !important;\r\n\t}\r\n}\r\n","/* === TOOLTIPS arrow div bg color === */\r\ndiv[data-radix-popper-content-wrapper]:has([role='tooltip']) {\r\n\t@extend %animFadeIn;\r\n\r\n\t/* Tooltip and triangle bg */\r\n\t// .bg-black not existing anymore, it is .bg-gray-950 now, but I select it via <div> tag\r\n\r\n\tdiv {\r\n\t\tbackground-color: var(--c-bg-tooltip) !important;\r\n\t\tpadding: var(--p-tooltips) !important;\r\n\t\tbox-shadow: var(--box-shadow-contextmenu) !important;\r\n\t}\r\n}\r\n\r\n/* === TOOLTIPS text color === */\r\nhtml.light div[data-radix-popper-content-wrapper]:has([role='tooltip']) {\r\n\t[class*='text-white'] {\r\n\t\tcolor: var(--c-txt) !important;\r\n\t}\r\n}\r\nhtml.dark div[data-radix-popper-content-wrapper]:has([role='tooltip']) {\r\n\t[class*='text-white'] {\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t}\r\n}\r\n",".gizmo-shadow-stroke.h-full:has(svg) {\r\n    color: var(--c-on-accent) !important;\r\n    background-color: var(--c-accent) !important;\r\n}","/* ___  MODAL Background */\r\n.absolute.inset-0 .fixed.inset-0 {\r\n\tbackground-color: var(--c-bg-modal) !important;\r\n\tbackdrop-filter: blur(var(--blur-modal)) !important;\r\n\tz-index: var(--z-modal);\r\n}\r\n","/* ___ DIALOG - Dialog Settings  */\r\n[role='dialog'] {\r\n\tpadding: var(--p-dialog) !important;\r\n\tbackground-color: var(--c-bg-dialog) !important;\r\n\tborder-radius: var(--br-dialog) !important;\r\n\tbox-shadow: var(--box-shadow);\r\n\t--anim-duration: 0.28s;\r\n\t@extend %animFadeIn;\r\n\r\n\t.border-token-border-light,\r\n\t.border-white,\r\n\t.border-black {\r\n\t\tborder-color: transparent !important;\r\n\t}\r\n\r\n\t/* Tab view transitions - In tab dialog part which is changing on tabpanel click (on right side) */\r\n\t[id*='-content-'] {\r\n\t\t--anim-duration: 0.18s;\r\n\t\t@extend %animFadeIn;\r\n\t}\r\n\r\n\t[role='tablist'] {\r\n\t\t/* ___ DIALOG - \"Settings\" on smaller devices then deskop */\r\n\t\t&[data-orientation='horizontal'].bg-gray-100 {\r\n\t\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\t\t// border-radius: var(--br-btn) !important;\r\n\r\n\t\t\t// button[role=\"tab\"][data-state=\"active\"] {\r\n\t\t\tbutton[data-state='active'] {\r\n\t\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/* Add padding y to tabpanel in \"Settings\" (Where \"Theme\",\"Archived chats\", \"Delete All chats\", etc are. Added because Theme dropdown was cutted on hover on smaller devices, because of OpenAI's `overflow-y: auto` */\r\n\t[role='tabpanel'][data-orientation='horizontal'] {\r\n\t\tpadding: 1rem !important;\r\n\t}\r\n\r\n\t/* Heading \"Settings\" in Settings Modal */\r\n\th2[as='h3'] {\r\n\t\ttext-transform: uppercase;\r\n\t}\r\n\r\n\t/* \"Your invite is valid until December X, 2023\" in \"YOU'RE INVITED TO PLUS\" footer */\r\n\t.text-gizmo-gray-500 {\r\n\t\ttext-align: center;\r\n\t\tmargin-top: 1rem;\r\n\t}\r\n\r\n\t.bg-token-surface-primary {\r\n\t\t--surface-primary: transparent !important;\r\n\t}\r\n\r\n\t/* DIALOG - \"Upgrade your plan\" only */\r\n\t&:has(a[href=\"https://openai.com/enterprise\"])\r\n\t{\r\n\t\t// background-color: transparent !important;\r\n\t\t// Change `width: max-content;` to `max-width: max-content;` in `[role=\"dialog\"]:has(a[href=\"https://openai.com/enterprise\"])` because it disables shrinking the content in `Upgrade your plan` popup. But then I have to fix the content\r\n\t\tmax-width: max-content;\r\n\t\tpadding: 0 !important;\r\n\t\tborder: none !important;\r\n\r\n\t\t/* Strange white bg behind ✔️ items */\r\n\t\t.bg-white,\r\n\t\t.bg-gray-900 {\r\n\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t}\r\n\r\n\t\t/* Border radius for \"Upgrade your plan\" dialog */\r\n\t\t.rounded-md {\r\n\t\t\tborder-radius: var(--br-chat-bubble) !important;\r\n\t\t}\r\n\r\n\t\t/*  Stroke color for ✔️ in \"Upgrade your plan\" dialog list */\r\n\t\tsvg[stroke='currentColor']:has(polyline) {\r\n\t\t\tstroke: var(--c-accent) !important;\r\n\t\t}\r\n\r\n\t\t/* See \"ChatGPT Enterprise\" */\r\n\t\ta[href=\"https://openai.com/enterprise\"]\r\n\t\t{\r\n\t\t\tcolor: var(--c-accent) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t&:has([data-testid^='conversation-turn-']) {\r\n\t\t[class*='dark:bg-gray-800'] {\r\n\t\t\tbackground-color: var(--c-surface-1) !important;\r\n\t\t\t// background-color: lightsalmon !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* DIALOG - textarea (\"Custom instructions\") */\r\n\ttextarea {\r\n\t\tborder-radius: var(--br-contextmenu) !important;\r\n\t\tborder-color: transparent !important;\r\n\t\tbackground-color: var(--c-surface-3) !important; // [class*='dark:bg-gray-800']\r\n\t\topacity: 0.7;\r\n\r\n\t\t/* Textarea feedback when click on like btn in gpt answers */\r\n\t\t&#feedback-other {\r\n\t\t\tpadding: 1.5rem;\r\n\t\t}\r\n\r\n\t\t&:focus {\r\n\t\t\tborder-color: var(--c-surface-3) !important;\r\n\t\t\topacity: 1;\r\n\t\t}\r\n\r\n\t\t&::placeholder {\r\n\t\t\tcolor: var(--c-subtext-1) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t& [class*='dark:bg-gray-700']:has(input[id]) {\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\r\n\t\tinput {\r\n\t\t\tbackground-color: inherit !important;\r\n\t\t}\r\n\t\t// background-color: red !important;\r\n\t}\r\n\r\n\t/* ___ Dialog - \"Share Chat\" White preview <div>  */\r\n\t&:has(main div[data-radix-aspect-ratio-wrapper]) .w-full.rounded-lg {\r\n\t\tborder-radius: var(--br-chat-bubble) !important;\r\n\t\tbox-shadow: var(--box-shadow);\r\n\t\tborder: none !important;\r\n\r\n\t\t/* Mini chat conversation */\r\n\t\t--main-surface-primary: var(--c-surface-1) !important; // mini chat preview background in \"Share Link to Chat\"\r\n\t\t--main-surface-secondary: var(--c-surface-1) !important; // footer of mini chat preview in \"Share Link to Chat\"\r\n\t\t--main-surface-tertiary: transparent !important; // border color of footer of mini chat preview in \"Share Link to Chat\"\r\n\t}\r\n\r\n\t/* ___ DIALOG - \"SHARED LINKS\" or \"ARCHIVED CHATS\" - Table  */\r\n\ttable {\r\n\t\t// --main-surface-primary: var(--c-surface-2) !important;\r\n\t\tpadding: var(--p-contextmenu) !important;\r\n\t\t// border-radius: var(--br-contextmenu);\r\n\r\n\t\t/* BG of thead>th */\r\n\t\t.bg-white,\r\n\t\t.bg-gray-900 {\r\n\t\t\tbackground-color: transparent !important;\r\n\t\t}\r\n\r\n\t\tth,\r\n\t\ttd {\r\n\t\t\tpadding-top: var(--py-btn) !important;\r\n\t\t\tpadding-bottom: var(--py-btn) !important;\r\n\t\t}\r\n\r\n\t\tthead {\r\n\t\t\ttr {\r\n\t\t\t\t// border-radius: var(--br-btn) !important;\r\n\t\t\t\t// padding: var(--py-btn) var(--px-btn) !important;\r\n\t\t\t}\r\n\r\n\t\t\tth {\r\n\t\t\t\ttext-transform: uppercase !important;\r\n\t\t\t\t// color: var(--c-accent) !important;\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\ttbody {\r\n\t\t\t/* Link in table Shared Links/Archived Chats\r\n            \r\n                NAME - first column Links\r\n                \"Shared links\" & \"Archived Chats\" links in table, but a[href^=\"/c/\"] is also Conversation SVG in \"Shared Links\", ahh\r\n            */\r\n\t\t\ttd:first-child a {\r\n\t\t\t\t@extend %link_hover_underless;\r\n\t\t\t}\r\n\r\n\t\t\t/* Center the vertically svg icons next to each other in table */\r\n\t\t\ttd:has(button[aria-label^='Delete']) span[data-state] {\r\n\t\t\t\tdisplay: flex;\r\n\t\t\t\talign-items: center;\r\n\t\t\t\tjustify-items: center;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/* \"Delete shared link\" in Shared Links and \"Delete conversation\" in Archived Chats svg color */\r\n\t\tbutton[aria-label^='Delete'] {\r\n\t\t\tcolor: var(--c-danger) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* ___ DIALOG \"Delete account - are you sure?\" inputs parents */\r\n\tdiv[class*='focus-within:ring-1']:has(input) {\r\n\t\tpadding: 0.8rem !important;\r\n\t\tbackground-color: var(--c-surface-3);\r\n\r\n\t\tinput {\r\n\t\t\tbackground-color: var(--c-surface-3);\r\n\r\n\t\t\t&::placeholder {\r\n\t\t\t\tcolor: var(--c-subtext-1) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n","/* === RIGHT - CONVERSATION CONTAINER === */\r\nmain [role='presentation'] {\r\n\t&,\r\n\t/* Shared Link Page */\r\n\t.bg-token-main-surface-primary.h-full {\r\n\t\tbackground-color: var(--c-bg-chats-container) !important;\r\n\t}\r\n}\r\n\r\n/* === RIGHT - Chats - Gap from heading and svg icons ===*/\r\nmain [data-message-author-role='user'],\r\nmain [data-message-author-role='assistant'] {\r\n\tmargin-top: var(--mt-chat-txt) !important;\r\n\tmargin-bottom: var(--mb-chat-txt) !important;\r\n}\r\n\r\n/* @ === RIGHT - CHATS BUBBLES ===*/\r\nmain [data-testid^='conversation-turn-'] {\r\n\tmargin-bottom: var(--mb-chat-bubble) !important;\r\n\r\n\t/* RIGHT - CHATS BUBBLES DIV */\r\n\t.group {\r\n\t\t// padding: var(--p-chat-bubble) !important;\r\n\t\tpadding: calc(var(--p-chat-bubble) * 1.3) var(--p-chat-bubble) var(--p-chat-bubble) var(--p-chat-bubble) !important;\r\n\t\tborder-radius: var(--br-chat-bubble) !important;\r\n\t\tletter-spacing: 0.3px;\r\n\t\tline-height: 1.8 !important;\r\n\r\n\t\t.agent-turn {\r\n\t\t\twidth: 80% !important;\r\n\t\t\t// border: 1px solid red !important;\r\n\t\t\t// overflow-x: scroll !important;\r\n\t\t}\r\n\r\n\t\t/*  TODO \r\n            gap: 0.75rem + width: 1.5rem = 2.25rem toliko treba da bude padding-right/margin-right i dodati flex-grow: 1;\r\n                ovome: relative flex w-full flex-col lg:w-[calc(100%-115px)] agent-turn \r\n                i ovome: lg:w-[calc(100%-115px)]    to je isti deo samo za user chat bubble\r\n            to je kao chat onaj deo gde je chat, cudno ima veliki space sa desne strane, \r\n        */\r\n\t\t// Fix original strange space on the right (left is svg of user/gpt) in the chat bubbles where text is\r\n\t\tdiv[class*='lg:w-[calc(100%-115px)]'] {\r\n\t\t\t// .agent-turn {\r\n\t\t\t--gap-3: 0.75rem;\r\n\t\t\t--svg-w: 1.5rem;\r\n\t\t\tflex-grow: 1 !important;\r\n\t\t\tmargin-right: calc(var(--gap-3) + var(--svg-w)) !important;\r\n\t\t\t// padding-right: calc(var(--gap-3) + var(--svg-w)) !important;\r\n\t\t\t// border: 2px solid red !important;\r\n\t\t}\r\n\r\n\t\t/* \"Was this response better or worse? 👍👎\" el when clicked on regenerate answer btn  */\r\n\t\t.bg-gray-100,\r\n\t\t[class*=':bg-gray-700'] {\r\n\t\t\tbackground-color: transparent !important;\r\n\t\t\tcolor: var(--c-subtext-2) !important;\r\n\t\t\tborder: 1px solid var(--c-border);\r\n\t\t\tborder-radius: var(--br-contextmenu);\r\n\r\n\t\t\t/* \"Same\" svg, fix white border for visualy consistency */\r\n\t\t\tsvg.rounded-full {\r\n\t\t\t\tborder-color: var(--avatar-color);\r\n\t\t\t}\r\n\t\t\t/* 👍👎 */\r\n\t\t\tbutton[title] {\r\n\t\t\t\tborder-radius: var(--br-btn) !important;\r\n\t\t\t\tborder: 1px solid transparent;\r\n\t\t\t\ttransition: transform 0.2s $easeInOutSine;\r\n\r\n\t\t\t\t/* \"Better\", \"Worse\", \"Same\" */\r\n\t\t\t\tspan {\r\n\t\t\t\t\ttransition: color 0.2s $easeInOutSine;\r\n\t\t\t\t\tcolor: var(--c-subtext-2) !important;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:hover {\r\n\t\t\t\t\tbackground-color: transparent !important;\r\n\t\t\t\t\tborder-color: var(--c-border) !important;\r\n\t\t\t\t\ttransform: translateY(-4%);\r\n\r\n\t\t\t\t\tspan {\r\n\t\t\t\t\t\tcolor: var(--avatar-color) !important;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/* RIGHT - CHATS USER/GPT NAMES */\r\n\t.font-semibold.select-none {\r\n\t\ttext-transform: uppercase;\r\n\t}\r\n\r\n\t.gizmo-shadow-stroke div {\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t}\r\n\r\n\t/* @ RIGHT - CHATS BUBBLES - USER  */\r\n\t// There is no [data-message-author-role=\"user\"] when we clicked on \"Edit Prompt\", so we need select and like this for that case scenario\r\n\t// &:not(&:has([data-message-author-role='assistant'])),\r\n\t&:has([data-message-author-role='user']) {\r\n\t\t/*  RIGHT - CHATS BUBBLE BG */\r\n\t\t.group {\r\n\t\t\tbackground-color: var(--c-bg-msg-user);\r\n\t\t\toutline: 2px solid transparent !important;\r\n\r\n\t\t\t/* === User/ChatGPT name === */\r\n\t\t\t.font-semibold.select-none {\r\n\t\t\t\tcolor: var(--c-msg-name-user);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/*  Chat bubble footer SVG icons */\r\n\t\tbutton svg {\r\n\t\t\tcolor: var(--c-msg-name-user);\r\n\t\t}\r\n\t}\r\n\t/* User chat bubble - Edit state. There is no [data-message-author-role=\"user\"] when we clicked on \"Edit Prompt\", so we need select and like this for that case scenario */\r\n\t&:has(textarea) {\r\n\t\t/* \t\t.flex.flex-grow.flex-col.max-w-full > div {\r\n\t\t\t@extend %animFadeIn;\r\n\t\t} */\r\n\t\t.group {\r\n\t\t\tbackground-color: var(--c-bg-chats-container) !important;\r\n\t\t\tbox-shadow: var(--box-shadow-textarea);\r\n\t\t\toutline: 2px solid hsla(var(--accent-hsl) / 0.1) !important;\r\n\t\t\ttransition: outline 0.2s ease-in-out, box-shadow 0.2s ease-in-out;\r\n\r\n\t\t\t/* === User/ChatGPT name === */\r\n\t\t\t.font-semibold.select-none {\r\n\t\t\t\tcolor: var(--c-msg-name-user);\r\n\t\t\t}\r\n\r\n\t\t\ttextarea {\r\n\t\t\t\t@extend %animFadeIn;\r\n\t\t\t\tcolor: var(--c-subtext-2) !important;\r\n\t\t\t\tpadding: 0.5rem 0;\r\n\t\t\t}\r\n\r\n\t\t\t/* Parent of buttons: \"Save & Submit\" and \"Cancel\" */\r\n\t\t\t.text-center.mt-2.flex.justify-center {\r\n\t\t\t\t@extend %animFadeIn;\r\n\t\t\t}\r\n\r\n\t\t\t.btn-neutral {\r\n\t\t\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/* @ RIGHT - CHATS BUBBLES - GPT */\r\n\t&:has([data-message-author-role='assistant']) {\r\n\t\t/*   RIGHT - CHATS BUBBLE BG  */\r\n\t\t.group {\r\n\t\t\tbackground-color: var(--c-bg-msg-gpt);\r\n\r\n\t\t\tsvg[role='img'] {\r\n\t\t\t\tcolor: var(--c-surface-1) !important;\r\n\t\t\t}\r\n\r\n\t\t\t/*  User/ChatGPT name  */\r\n\t\t\t.font-semibold.select-none {\r\n\t\t\t\t// color: var(--c-msg-name-gpt);\r\n\t\t\t\tcolor: var(--avatar-color);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/*  Chat bubble footer SVG icons */\r\n\t\tbutton svg {\r\n\t\t\tcolor: var(--avatar-color);\r\n\t\t}\r\n\t}\r\n}\r\n","/* === RIGHT - NEW CHAT - 4 BIG BTNS === */\r\n\r\nmain form .grow {\r\n\t/* recimo gap izmedju new chat example buttons*/\r\n\t.gap-2 {\r\n\t\tgap: 0.8rem !important;\r\n\t}\r\n\r\n\t.btn {\r\n\t\tpadding: 1.5rem !important;\r\n\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\tcolor: var(--c-txt) !important;\r\n\t\tborder-radius: var(--br-btn-big) !important;\r\n\t\toverflow: hidden; // Mora jer kad se hoveruje .btn, onda se  .bg-gradient-to-l radius ne uklapa s ovim, manji je i onda .btn cudno izgleda sa desne strane, ovaj ga overflowuje\r\n\r\n\t\t/* Gradient bg visible on hover */\r\n\t\t.bg-gradient-to-l {\r\n\t\t\t--gradient-color-from: var(--c-surface-3) !important;\r\n\t\t\t// --tw-gradient-from: var(--c-surface-3) var(--tw-gradient-from-position) !important;\r\n\r\n\t\t\t/* Button SVG parent ❌ \r\n\t\t\tNo more .bg-token-surface-primary class, now is .bg-token-main-surface-primary */\r\n\t\t\t// .bg-token-surface-primary {\r\n\t\t\t.bg-token-main-surface-primary {\r\n\t\t\t\t// --surface-secondary: var(--c-surface-2) !important;\r\n\t\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\t\tborder-radius: 100vw !important;\r\n\t\t\t\tpadding: 0.5rem !important;\r\n\r\n\t\t\t\t/* SVG icon*/\r\n\t\t\t\tsvg {\r\n\t\t\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n","/* === STICKY ChatGPT version ===*/\r\n/* Removing \"main\" before sticky caused this style is applied on many elements I don't want: Sidebar \"NEW CHT\" wrapper, and down the [aria-haspopup='menu']:hover caused also issues on in pop-up table on more options (3dots) svg icon.\r\nBut adding this \"main\" blocked this style to smaller screens so I have to add it down, out of this block */\r\nmain .sticky {\r\n\tbackground-color: var(--c-bg-chats-sticky) !important;\r\n\tbackdrop-filter: blur(var(--blur-sticky));\r\n\r\n\t/*  \"My GPTs\" page sticky headers w/ +CREATE btn (.top-0 and .top-14) */\r\n\t&:has([href='/gpts/editor']),\r\n\t&.top-14 {\r\n\t\t--c-bg-chats-sticky: var(--c-bg-chats-container) !important;\r\n\t\t--blur-sticky: 0 !important;\r\n\t}\r\n\t&.top-14 {\r\n\t\tpadding-bottom: 0.6rem !important;\r\n\t}\r\n\r\n\t[aria-haspopup='menu']:hover,\r\n\t[aria-haspopup='menu'][data-state='open'] {\r\n\t\tbackground-color: var(--c-surface-1) !important;\r\n\t}\r\n\r\n\t/* === STICKY ChatGPT version svg icon ===*/\r\n\t.btn {\r\n\t\tborder-radius: 50vw !important;\r\n\r\n\t\tsvg {\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* Sticky header for smaller screens. Remove border-bottom */\r\n.sticky.border-token-border-medium {\r\n\tborder: none !important;\r\n}\r\n","/* ===  RIGHT - TEXTAREA PARENT, message type and send button */\r\n// main form .overflow-hidden:has(textarea#prompt-textarea) {\r\nmain form [class*='[&:has(textarea:focus)]']:has(textarea#prompt-textarea) {\r\n\tpadding: var(--p-prompt-textarea) !important;\r\n\t// background-color: transparent !important;\r\n\t// background-color: var(--c-bg-chats-container) !important;\r\n\tbackground-color: var(--c-bg-textarea) !important;\r\n\tborder-radius: var(--br-prompt-textarea) !important;\r\n\t// border: 3px solid var(--c-border-textarea);\r\n\tborder: none !important;\r\n\tbox-shadow: var(--box-shadow-textarea);\r\n\ttransition: background-color 0.3s ease-in-out, box-shadow 0.3s ease-in-out;\r\n\t// box-shadow: var(--box-shadow-contextmenu) !important;\r\n\r\n\t&:has(textarea#prompt-textarea:focus) {\r\n\t\t// box-shadow: var(--box-shadow-contextmenu) !important;\r\n\t\t// border-color: transparent !important;\r\n\t\tbox-shadow: none !important;\r\n\t}\r\n\r\n\ttextarea::placeholder {\r\n\t\tcolor: var(--c-placeholder-textarea) !important;\r\n\t}\r\n\r\n\t/* Send button */\r\n\tbutton[data-testid='send-button'] {\r\n\t\tbackground-color: var(--c-accent) !important;\r\n\t\tcolor: var(--c-txt) !important;\r\n\t\tborder-color: var(--c-accent) !important;\r\n\t\tborder-radius: 100vw !important;\r\n\t\tpadding: 2px;\r\n\t\tright: 1.3rem !important;\r\n\t\tbottom: 1.2rem !important;\r\n\r\n\t\t&[disabled] {\r\n\t\t\topacity: 0.5 !important;\r\n\t\t}\r\n\r\n\t\tsvg {\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* === RIGHT - TEXTAREA part wrapper, margin-top ===*/\r\nmain div[role='presentation'] div.w-full:has(form) {\r\n\tmargin-top: 0.5rem !important;\r\n}\r\n\r\n/* === RIGHT - TEXTAREA PARENT ===*/\r\nmain div.flex.w-full.items-center > div {\r\n\tbox-shadow: none;\r\n\tborder: none;\r\n}\r\n","/* Footer tj wrapper for green btn \"Upgrade to Plus to create your own GPT\"  */\r\nmain [role=\"presentation\"] [class*=\"empty:hidden\"]:has(> a[href=\"/gpts/discovery\"]) {\r\n    padding: 1.5rem;\r\n\r\n    .bg-green-600 {\r\n        @extend .btn;\r\n    }\r\n}","main:has(.sticky [href='/gpts/editor']) {\r\n\t// /* Main Cards (big) */\r\n\t// .rounded-xl {\r\n\t// \tborder-radius: var(--br-btn-big) !important;\r\n\t// }\r\n\t// /* Search query list cards. Input search */\r\n\t// .rounded-lg {\r\n\t// \tborder-radius: var(--br-btn) !important;\r\n\t// }\r\n\t/* Sticky header tags aka \"Top Picks\", \"DALLE\", \"Writing\", etc */\r\n\t.sticky {\r\n\t\t[class*='md:rounded-none'],\r\n\t\t[class*='md:rounded-lg'] {\r\n\t\t\tborder-radius: 100vw !important;\r\n\t\t\tpadding-inline: 1rem !important;\r\n\t\t}\r\n\t\t/* Active tag aka \"Top Picks\" */\r\n\t\t[class*='md:rounded-none'] {\r\n\t\t\tborder: none !important;\r\n\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\r\n\t\t\t/* Fix active pill tag bg be overwritten by global [class*='bg-black'] */\r\n\t\t\t&[class*='bg-black'] {\r\n\t\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t\t/* No-active tags aka \"DALLE\", \"Writing\", etc */\r\n\t\t[class*='md:rounded-lg'] {\r\n\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.2) !important;\r\n\t\t\tcolor: var(--c-accent) !important;\r\n\t\t}\r\n\r\n\t\t/* Left/right arrows in tags track */\r\n\t\t[class*='bg-gradient-to-'] {\r\n\t\t\tbutton {\r\n\t\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/* Input search */\r\n\tinput[placeholder='Search public GPTs'] {\r\n\t\toutline: none;\r\n\t\tbackground-color: var(--c-surface-2) !important;\r\n\r\n\t\t&::placeholder {\r\n\t\t\tcolor: var(--c-subtext-1) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* All the cards hover bg (on search query list and on main big ones) */\r\n\t[class*='dark:hover:bg-white/10'] {\r\n\t\t&:hover {\r\n\t\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\t}\r\n\t}\r\n\t/* Section visible on search query */\r\n\t[id*='headlessui-popover-panel-'] {\r\n\t\t// --main-surface-primary: var(--c-surface-2) !important;\r\n\t\t--br-search-query-section: calc(var(--br-btn) * 1.2) !important;\r\n\r\n\t\t/* Added to visually remove unstickness search query section from input search */\r\n\t\ttransform: translateY(-5px);\r\n\r\n\t\tborder-radius: 0 0 var(--br-search-query-section) var(--br-search-query-section) !important;\r\n\r\n\t\t/* Search query section items/cards */\r\n\t\t.gizmo-link {\r\n\t\t\tborder-radius: var(--br-btn) !important;\r\n\t\t\tmargin-bottom: 0.5rem;\r\n\r\n\t\t\tsvg.text-gray-400 {\r\n\t\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\t\t// color: red !important;\r\n\t\t\t}\r\n\r\n\t\t\t// &:hover {\r\n\t\t\t// \tbackground-color: var(--c-surface-3) !important;\r\n\t\t\t// }\r\n\t\t}\r\n\t}\r\n\r\n\t/* All the card items in GPTs Store main page */\r\n\t.h-fit {\r\n\t\t/* \"See more\" full-width buttons */\r\n\t\t.btn.w-full {\r\n\t\t\t// padding: calc(var(--p-btn) * 1.5) !important;\r\n\t\t\tpadding: 1.8rem !important;\r\n\t\t\tborder-radius: calc(var(--br-btn) * 1.2) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* \r\n? Active tag classes (\"Top Picks\") vs no-active tag classes (\"DALLE\", \"Writing\", etc)\r\n```border-token-text-primary bg-black text-white dark:bg-gray-100 dark:text-gray-800 md:rounded-none md:border-b-2 md:text-black dark:md:text-white\r\ncursor-pointer scroll-mx-5 whitespace-nowrap rounded-3xl px-3 py-2 first:ml-4 last:mr-4 md:px-2 md:first:ml-0 md:last:mr-0 border-token-text-primary bg-black text-white dark:bg-gray-100 dark:text-gray-800 md:rounded-none md:border-b-2 md:bg-transparent md:text-black dark:md:bg-transparent dark:md:text-white\r\n\r\n```bg-gray-50, dark:bg-gray-700 md:rounded-lg md:text-token-text-tertiary md:hover:bg-gray-50 dark:md:hover:bg-gray-700\r\ncursor-pointer scroll-mx-5 whitespace-nowrap rounded-3xl px-3 py-2 first:ml-4 last:mr-4 md:px-2 md:first:ml-0 md:last:mr-0 bg-gray-50 hover:bg-gray-100 dark:bg-gray-700 dark:hover:bg-gray-600 md:rounded-lg md:bg-transparent md:text-token-text-tertiary md:hover:bg-gray-50 dark:md:bg-transparent dark:md:hover:bg-gray-700\r\n*/\r\n","/* ___ General */\r\nbutton,\r\nli,\r\na,\r\nsvg,\r\n[class*=':hover'],\r\n[role='switch'] span[data-state] {\r\n\ttransition: all 0.3s ease-in-out;\r\n\r\n\t// transition:\r\n\t//     all .35s var(--ease-default),\r\n\t//     opacity .3 ease-in-out,\r\n\t//     background-color .3 ease-in-out,\r\n\t//     color .3 ease-in-out;\r\n\r\n\t/*     transition:\r\n        transform .25s var(--ease-default),\r\n        opacity .3s ease-in-out,\r\n        background-color .3s ease-in-out,\r\n        color .3s ease-in-out,\r\n        border-color .3s ease-in-out,\r\n        box-shadow .3s ease-in-out,\r\n        scale .3s ease-in-out,\r\n        rotate .3s ease-in-out,\r\n        translate .3s ease-in-out,\r\n        filter .3s ease-in-out,\r\n        border-radius .3s ease-in-out, inset .3s ease-in-out; */\r\n}\r\n\r\n/* ___ BUTTON SVG icon which ARE NOT in:\r\n    - in .btn <button>\r\n    - Theme choosing <button>\r\n    - in active tab <button>\r\n    - in send message btn <button>\r\n    - btns in message bubble footer <button> ([class*=\"[.final-completion]\"]) \r\n------------------------------\r\n    - .btn  |  Button\r\n    - [role=\"tab\"]  |  Active tab\r\n    - [role=\"combobox\"]  |  Theme choosing\r\n    - [data-testid=\"send-button\"]  |  Send Message Button\r\n    - [class*=\"[.final-completion]\"]  |  Btns in Message bubble footer\r\n    - [aria-label^=\"Delete\"])  | \"Delete\" icon in \"Shared links\" and \"Archived Chats\" \r\n    - [aria-label=\"Unarchive conversation\"])  | \"Unarchive\" icon in \"Archived Chats\"\r\n   */\r\nbutton:not(\r\n\t\t.btn,\r\n\t\t[role='tab'],\r\n\t\t[role='combobox'],\r\n\t\t[data-testid='send-button'],\r\n\t\t[class*='[.final-completion]'],\r\n\t\t[aria-label^='Delete'],\r\n\t\t[aria-label='Unarchive conversation']\r\n\t) {\r\n\tsvg {\r\n\t\ttransform-origin: center center;\r\n\t\t// border: 1px solid red !important;\r\n\t}\r\n\r\n\tsvg:hover {\r\n\t\ttransform: scale(1.12);\r\n\t}\r\n}\r\n\r\n.btn {\r\n\twill-change: transform, opacity;\r\n\r\n\t// transition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out, background-color 0.3s ease-in-out, color 0.3s ease-in-out !important;\r\n\ttransition: transform 0.2s $easeInOutQuad, opacity 0.3s ease-in-out, background-color 0.3s ease-in-out,\r\n\t\tcolor 0.3s ease-in-out !important;\r\n\r\n\t&:is(:hover, :active) {\r\n\t\ttransform: translateY(-2px);\r\n\t\topacity: 0.8;\r\n\t}\r\n}\r\n\r\n/* dialog buttons */\r\n[role='dialog'] {\r\n\t/* \".PopoverContent\" je recimo menu od btn u \"Shared Link to Chat\" 3dots menu (Shared your Name & Delete Link) */\r\n\t&.PopoverContent {\r\n\t\t.btn-neutral:is(:hover, :focus) {\r\n\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\ttransform: none !important;\r\n\t\t\topacity: 1 !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* ___ Switch button circle hover. Ovde ne moze :focus, ostane style kao da je checked ili obrnuto i kad se unhoveruje */\r\nbutton[role='switch'] {\r\n\tspan[data-state] {\r\n\t\ttransition: transform 0.4s $easeInOutBack, background-color 0.3s ease-in-out;\r\n\t}\r\n\r\n\t&:hover {\r\n\t\tspan[data-state] {\r\n\t\t\t/* Ovo se kosi sa openai klasama, jer on dodaje translate-x -19px, pa se circle pomera levo, sto i nije lose, lol. Ako to ne zelimo, mozemo koristiti scale umesto transform: scale */\r\n\t\t\ttransform: scale(0.8);\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* ___ New Chat big buttons */\r\nmain form .grow .btn {\r\n\t// transition: .4s $easeOutBack, background-color .3s ease-in-out opacity .3s ease-in-out;\r\n\r\n\t/* Gradient bg visible on hover */\r\n\t.bg-gradient-to-l {\r\n\t\ttransition: all 0.3s ease-in-out;\r\n\r\n\t\t/* Button SVG parent wrapper */\r\n\t\tspan[data-state] {\r\n\t\t\toverflow: hidden;\r\n\t\t\tpadding: 4px; // because svg btn looks cut off in firefox, so add a little space around\r\n\r\n\t\t\t/* Button w/ SVG */\r\n\t\t\t// .bg-token-surface-primary { this class doesnt exist anymore...\r\n\t\t\t.bg-token-main-surface-primary {\r\n\t\t\t\ttransform: translateY(120%) scale(0.5);\r\n\t\t\t\ttransition: transform 0.5s $easeOutBack;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t&:hover {\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\ttransform: translateY(-4px);\r\n\r\n\t\t.bg-gradient-to-l {\r\n\t\t\tspan[data-state] {\r\n\t\t\t\t/* Button w/ SVG */\r\n\t\t\t\t// .bg-token-surface-primary {\r\n\t\t\t\t.bg-token-main-surface-primary {\r\n\t\t\t\t\ttransform: translateY(0%) scale(1);\r\n\t\t\t\t\topacity: 1 !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* ___ Textarea send message send-button */\r\n[data-testid='send-button']:not([disabled]) {\r\n\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out;\r\n\r\n\t&:hover {\r\n\t\ttransform: translateY(-10%);\r\n\t}\r\n}\r\n\r\n/* ___ Chat Bubbles */\r\nmain [data-testid^='conversation-turn-'] {\r\n\t.group {\r\n\t\t&:hover {\r\n\t\t\t/* Bubble message footer (icons wrapper) */\r\n\t\t\tdiv[class*='empty:hidden']:has(button[class*='[.final-completion]']) .visible {\r\n\t\t\t\ttransform: translateY(0);\r\n\t\t\t\topacity: 1;\r\n\t\t\t}\r\n\r\n\t\t\t/* Bubble message footer (svg icons) */\r\n\t\t\t[class*='[.final-completion]'] svg {\r\n\t\t\t\ttransform: scale(1);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/* Bubble message footer */\r\n\t\tdiv[class*='empty:hidden']:has(button[class*='[.final-completion]']) {\r\n\t\t\toverflow-y: clip;\r\n\t\t\t// padding-inline: 10px; // to make counter answer (<2/4>) visible when this is overflow-hidden, we need to add padding-inline, or we can use overflow-y: clip; And overflow is \"important\" for translate transition\r\n\r\n\t\t\t/* Bubble message footer (icons wrapper) */\r\n\t\t\t.visible {\r\n\t\t\t\ttransform: translateY(100%);\r\n\t\t\t\topacity: 0;\r\n\t\t\t\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/* Bubble message footer (svg icons) */\r\n\t\t[class*='[.final-completion]'] svg {\r\n\t\t\ttransform: translateY(0px);\r\n\t\t\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out;\r\n\r\n\t\t\t&:hover {\r\n\t\t\t\topacity: 0.8;\r\n\t\t\t\ttransform: translateY(-3px);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* \"Copy code\" btn */\r\npre {\r\n\tbutton:has(svg) {\r\n\t\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out, background-color 0.2s ease-in-out,\r\n\t\t\tcolor 0.1s ease-in-out !important;\r\n\r\n\t\tsvg {\r\n\t\t\ttransition: color 0.1s ease-in-out !important;\r\n\t\t}\r\n\r\n\t\t&:hover {\r\n\t\t\tbackground-color: var(--c-accent-light) !important;\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\ttransform: translateY(2px);\r\n\t\t}\r\n\t}\r\n}\r\n\r\nhtml.light pre button:has(svg):hover {\r\n\tcolor: var(--c-txt) !important;\r\n}\r\n\r\n/* ___ Scroll down button */\r\nmain [role='presentation'] button.absolute.rounded-full {\r\n\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out;\r\n\r\n\t&:hover {\r\n\t\ttransform: translateY(10%);\r\n\t\topacity: 1 !important;\r\n\t}\r\n}\r\n\r\n/* ___ Table \"Archived Chats\" or \"Shared Links\" */\r\n[role='dialog'] table {\r\n\ttbody {\r\n\t\t/* Table column that contains \"Delete\" svg icon */\r\n\t\ttd:has(button[aria-label^='Delete']) {\r\n\t\t\tsvg {\r\n\t\t\t\ttransition: transform 0.4s $easeOutBack;\r\n\t\t\t}\r\n\r\n\t\t\t/* SVG parent wrapper */\r\n\t\t\tspan[data-state]:hover {\r\n\t\t\t\tsvg {\r\n\t\t\t\t\ttransform: translateY(2px) scale(1) !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* === ❓ circle btn on bottom right */\r\nbutton[id*='headlessui-menu-button'][class*='rounded-full'] {\r\n\ttransition: transform 0.3s $easeOutCirc;\r\n\r\n\t&:hover {\r\n\t\ttransform: scale(1.06);\r\n\t}\r\n}\r\n\r\n/* GPTs Store page - All the card items */\r\nmain:has(.sticky [href='/gpts/editor']) {\r\n\t.sticky {\r\n\t\t/* Sticky header with tags aka \"Top Picks\", \"DALLE\", \"Writing\", etc */\r\n\t\t[class*='md:rounded-none'],\r\n\t\t[class*='md:rounded-lg'] {\r\n\t\t\t// transition: background-color 0.3s ease, color 0.3s ease, transform 0.2s $easeInCirc;\r\n\t\t\ttransition: background-color 0.3s $easeInOutSine, color 0.3s $easeInOutSine, transform 0.3s $easeInOutSine;\r\n\t\t}\r\n\t\t/* Non-active pill-tag */\r\n\t\t[class*='md:rounded-lg']:hover {\r\n\t\t\ttransform: scale(0.955);\r\n\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t}\r\n\r\n\t\t/* Left/right arrows in tags track */\r\n\t\t[class*='bg-gradient-to-'] button {\r\n\t\t\ttransition: transform 0.3s $easeInQuart;\r\n\t\t}\r\n\t\t/* Right tags arrow */\r\n\t\t[class*='bg-gradient-to-l'] button {\r\n\t\t\t&:hover {\r\n\t\t\t\ttransform: translateX(3px);\r\n\t\t\t}\r\n\t\t}\r\n\t\t/* Left tags arrow */\r\n\t\t[class*='bg-gradient-to-r'] button {\r\n\t\t\t&:hover {\r\n\t\t\t\ttransform: translateX(-3px);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\t/* All the card items in GPTs Store main page */\r\n\t.h-fit {\r\n\t\ta[href*='/g/g-'] {\r\n\t\t\t// border: 1px solid red !important;\r\n\t\t\ttransition: transform 0.3s $easeInOutSine, background-color 0.3s ease-in-out;\r\n\r\n\t\t\t&:hover {\r\n\t\t\t\ttransform: translateY(-3px);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n",".gpth {\r\n\t&__svg {\r\n\t\t--svg-size: 2.25rem;\r\n\t\t--top: calc(var(--h-header) + 0.5rem);\r\n\t\t--right: 1.3rem;\r\n\t\tposition: fixed;\r\n\t\ttop: var(--top);\r\n\t\tright: var(--right);\r\n\t\tz-index: 10;\r\n\r\n\t\t// this add only for Firefox\r\n\t\t@-moz-document url-prefix() {\r\n\t\t\t--right: 0.95rem;\r\n\t\t}\r\n\r\n\t\t&-icon {\r\n\t\t\t--icon-shadow-blur: 0px;\r\n\t\t\t--icon-shadow-offset: 6px;\r\n\t\t\t--icon-shadow-color: hsla(var(--accent-hsl) / 0.1);\r\n\t\t\tposition: relative;\r\n\t\t\tdisplay: grid;\r\n\t\t\tplace-items: center;\r\n\t\t\twidth: var(--svg-size);\r\n\t\t\theight: var(--svg-size);\r\n\t\t\tborder-radius: 50vw;\r\n\t\t\tbox-shadow: var(--box-shadow);\r\n\t\t\ttransition: transform 0.15s $easeOutCubic, outline 0.25s $easeOutCubic;\r\n\t\t\tcursor: pointer;\r\n\r\n\t\t\timg {\r\n\t\t\t\tobject-fit: cover;\r\n\t\t\t\twidth: var(--svg-size);\r\n\t\t\t\theight: var(--svg-size);\r\n\t\t\t\tborder-radius: 50vw;\r\n\t\t\t\tbox-shadow: 0px 0px var(--icon-shadow-blur) var(--icon-shadow-offset) hsla(var(--accent-hsl) / 0.3);\r\n\t\t\t\ttransition: box-shadow 0.2s $easeOutCubic;\r\n\t\t\t}\r\n\r\n\t\t\t&::after {\r\n\t\t\t\tcontent: 'Change theme';\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\ttop: 50%;\r\n\t\t\t\tleft: 0;\r\n\t\t\t\tfont-size: 0.75rem;\r\n\t\t\t\tborder-radius: 1.2rem;\r\n\t\t\t\twidth: max-content;\r\n\t\t\t\theight: max-content;\r\n\t\t\t\tpadding: 0.5rem 0.8rem;\r\n\t\t\t\tpointer-events: none;\r\n\t\t\t\tbackground-color: var(--c-bg-tooltip);\r\n\t\t\t\topacity: 0;\r\n\t\t\t\ttransform: translate(-100%, -50%);\r\n\t\t\t\ttransition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out;\r\n\t\t\t}\r\n\r\n\t\t\t&:hover {\r\n\t\t\t\t--icon-shadow-blur: 30px;\r\n\t\t\t\t--icon-shadow-offset: 7px;\r\n\t\t\t\t--icon-shadow-color: hsla(var(--accent-hsl) / 0.2);\r\n\t\t\t\ttransform: translateY(2px);\r\n\r\n\t\t\t\toutline: 5px solid hsla(var(--accent-hsl) / 0.05);\r\n\t\t\t\toutline-offset: 8px;\r\n\r\n\t\t\t\t&::after {\r\n\t\t\t\t\topacity: 1;\r\n\t\t\t\t\ttransform: translate(-115%, -50%);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\t&__options {\r\n\t\tpointer-events: none;\r\n\t\topacity: 0;\r\n\t\tdisplay: grid;\r\n\t\tplace-items: center;\r\n\t\tgap: 3rem;\r\n\t\twidth: max-content;\r\n\t\theight: max-content;\r\n\t\tpadding: 0.8rem;\r\n\t\tposition: absolute;\r\n\t\tright: 50%;\r\n\t\ttop: 150%;\r\n\t\ttransform: translateX(50%);\r\n\t\tborder-radius: 20vw;\r\n\t\tbackground-color: var(--c-surface-3);\r\n\t\tbox-shadow: var(--box-shadow);\r\n\r\n\t\t// background-image: linear-gradient(-135deg, #716782, #42335d, #2e1f48);\r\n\t\tbackground-image: linear-gradient(135deg, #332250, #42335d 40%, #6c607f 100%);\r\n\r\n\t\tclip-path: polygon(0 0, 100% 0, 100% 0, 0% 0);\r\n\t\ttransition: all 0.3s ease-in-out;\r\n\t\tbackdrop-filter: blur(5px);\r\n\r\n\t\t&.gpth-options-shown {\r\n\t\t\topacity: 1;\r\n\t\t\tpointer-events: all !important;\r\n\t\t\tclip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%) !important;\r\n\r\n\t\t\tbutton {\r\n\t\t\t\ttransform: scale(1);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\th5 {\r\n\t\t\tmargin-bottom: 1rem;\r\n\t\t\tdisplay: inline-block;\r\n\t\t\tfont-size: 1.3rem;\r\n\t\t\tletter-spacing: 1px;\r\n\t\t\tfont-weight: 100;\r\n\t\t}\r\n\t}\r\n\t&__themes {\r\n\t\tdisplay: grid;\r\n\t\tplace-items: center;\r\n\r\n\t\t&-btns {\r\n\t\t\tgap: 1rem;\r\n\t\t\tdisplay: grid;\r\n\t\t\tborder-radius: var(--br-btn);\r\n\r\n\t\t\tbutton {\r\n\t\t\t\t--btn-size: 2rem;\r\n\t\t\t\t--btn-bg: var(--c-surface-2);\r\n\t\t\t\t--btn-shadow-color: var(--btn-bg);\r\n\t\t\t\tcursor: pointer;\r\n\t\t\t\tposition: relative;\r\n\t\t\t\twidth: var(--btn-size);\r\n\t\t\t\theight: var(--btn-size);\r\n\t\t\t\tdisplay: grid;\r\n\t\t\t\tplace-items: center;\r\n\t\t\t\tline-height: 1;\r\n\t\t\t\tborder-radius: 50vw;\r\n\t\t\t\tborder: none;\r\n\t\t\t\tbackground-color: var(--btn-bg);\r\n\t\t\t\t// box-shadow: inset 0px 0px 5px 1px var(--btn-shadow-color);\r\n\t\t\t\t// box-shadow: inset 0px 0px 8px 1px var(--btn-shadow-color);\r\n\t\t\t\t// box-shadow: 0px 0px 5px 2px hsla(var(--accent-hsl) / 0.2)\r\n\t\t\t\ttransform: scale(0);\r\n\t\t\t\ttransition: background-color 0.2s ease, background-image 0.2s ease, transform 0.3s ease-in-out;\r\n\r\n\t\t\t\t&::after {\r\n\t\t\t\t\tcontent: attr(data-gpth-theme);\r\n\t\t\t\t\tposition: absolute;\r\n\t\t\t\t\ttop: 50%;\r\n\t\t\t\t\tleft: 50%;\r\n\t\t\t\t\twidth: max-content;\r\n\t\t\t\t\tfont-size: 0.8rem;\r\n\t\t\t\t\tpadding: 4px 4px;\r\n\t\t\t\t\tborder-radius: 5px;\r\n\t\t\t\t\tbackground-color: var(--c-accent-light);\r\n\t\t\t\t\topacity: 0;\r\n\t\t\t\t\tborder-radius: 50vw;\r\n\t\t\t\t\ttransform: translate(-50%, -50%) scale(0);\r\n\t\t\t\t\ttransition: 0.25s ease-in-out;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:hover {\r\n\t\t\t\t\t--btn-bg: hsla(0, 0%, 0%, 0) !important;\r\n\r\n\t\t\t\t\t&#dark {\r\n\t\t\t\t\t\tbackground-image: none;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&::after {\r\n\t\t\t\t\t\topacity: 1;\r\n\t\t\t\t\t\ttransform: translate(-50%, -50%) scale(1);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&#light {\r\n\t\t\t\t\t--btn-bg: var(--c-accent-light);\r\n\t\t\t\t}\r\n\t\t\t\t&#dark {\r\n\t\t\t\t\t--btn-shadow-color: hsla(255, 12%, 7%, 0.2);\r\n\t\t\t\t\t--btn-bg: hsl(272, 19%, 20%);\r\n\t\t\t\t\tbackground-image: linear-gradient(135deg, #8d80a0, #50416b, #2f1f49);\r\n\t\t\t\t}\r\n\t\t\t\t&#oled {\r\n\t\t\t\t\t--btn-shadow-color: hsla(0, 0%, 100%, 0.2);\r\n\t\t\t\t\t--btn-bg: #000;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t&__upload {\r\n\t\tdisplay: grid;\r\n\t\tjustify-items: center;\r\n\r\n\t\t&--content {\r\n\t\t\tdisplay: grid;\r\n\t\t\talign-items: center;\r\n\t\t\tgap: 1rem;\r\n\t\t}\r\n\r\n\t\tinput {\r\n\t\t\tdisplay: none;\r\n\t\t}\r\n\r\n\t\tlabel,\r\n\t\tbutton {\r\n\t\t\ttext-align: center;\r\n\t\t\toutline: none;\r\n\t\t\tborder: none;\r\n\t\t\tcursor: pointer;\r\n\t\t\twidth: 100%;\r\n\t\t\tpadding: var(--p-btn);\r\n\t\t\tborder-radius: var(--br-btn);\r\n\t\t\tbackground-color: var(--c-accent);\r\n\t\t\tcolor: var(--c-on-accent);\r\n\t\t\tfont-size: 1rem;\r\n\t\t}\r\n\r\n\t\tbutton#uploadImage {\r\n\t\t\tdisplay: none;\r\n\t\t}\r\n\t\tbutton#removeImage {\r\n\t\t\tdisplay: none;\r\n\t\t}\r\n\r\n\t\t&--preview {\r\n\t\t\tdisplay: grid;\r\n\t\t\tjustify-items: center;\r\n\r\n\t\t\tp {\r\n\t\t\t\ttext-align: center;\r\n\t\t\t\tmargin-bottom: 1rem;\r\n\t\t\t\tcolor: var(--c-subtext-2);\r\n\t\t\t}\r\n\t\t}\r\n\t\t&--placeholderImg {\r\n\t\t\tdisplay: grid;\r\n\t\t\tjustify-items: center;\r\n\t\t\t// --img-w: 11rem;\r\n\t\t\t--img-w: 95%;\r\n\t\t\t--img-h: 7rem;\r\n\t\t\t// margin: 0 auto;\r\n\t\t\twidth: var(--img-w);\r\n\t\t\theight: var(--img-h);\r\n\t\t\tborder-radius: var(--br-btn);\r\n\r\n\t\t\timg {\r\n\t\t\t\twidth: var(--img-w);\r\n\t\t\t\theight: var(--img-h);\r\n\t\t\t\t// width: 100%;\r\n\t\t\t\t// height: 100%;\r\n\t\t\t\tobject-fit: cover;\r\n\t\t\t\tobject-position: center;\r\n\t\t\t\tborder-radius: inherit;\r\n\t\t\t\tdisplay: none;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t&--placeholder {\r\n\t\t\twidth: var(--img-w);\r\n\t\t\theight: var(--img-h);\r\n\t\t\tdisplay: grid;\r\n\t\t\tgrid-template-columns: 1fr 3fr;\r\n\t\t\toverflow: clip;\r\n\t\t\tbox-shadow: 0 0 0 2px hsla(var(--accent-hsl) / 0.2);\r\n\t\t\tborder-radius: inherit;\r\n\r\n\t\t\taside {\r\n\t\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.2);\r\n\t\t\t}\r\n\t\t\tsection {\r\n\t\t\t\t// background-color: hsla(var(--accent-hsl) / 0.01);\r\n\t\t\t\tdisplay: grid;\r\n\t\t\t\tgrid-template-rows: 3fr 4fr 2.5fr;\r\n\t\t\t\tgap: 6px;\r\n\t\t\t\tpadding: 5px 10px;\r\n\r\n\t\t\t\tarticle {\r\n\t\t\t\t\twidth: 70%;\r\n\t\t\t\t\tborder-radius: 10px;\r\n\r\n\t\t\t\t\t&:nth-child(1) {\r\n\t\t\t\t\t\t// height: 50%;\r\n\t\t\t\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.4);\r\n\t\t\t\t\t}\r\n\t\t\t\t\t&:nth-child(2) {\r\n\t\t\t\t\t\t// height: 2rem;\r\n\t\t\t\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.2);\r\n\t\t\t\t\t\tjustify-self: flex-end;\r\n\t\t\t\t\t}\r\n\t\t\t\t\t&:nth-child(3) {\r\n\t\t\t\t\t\t// height: 4rem;\r\n\t\t\t\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.4);\r\n\t\t\t\t\t\t// justify-self: flex-end;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\nhtml.light {\r\n\t& [data-gpth-theme]::after,\r\n\t.gpth__svg-icon::after {\r\n\t\tcolor: var(--c-txt);\r\n\t}\r\n}\r\nhtml.dark {\r\n\t& [data-gpth-theme]::after,\r\n\t.gpth__svg-icon::after {\r\n\t\tcolor: var(--c-on-accent);\r\n\t}\r\n}\r\n"],"names":[],"version":3,"file":"sass.faed8373.css.map"} */ +/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"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C;;;;;AAAA;;;;;AAaC;;;;;AAUL;;;;;AAAA;;;;;AAMA;;;;A;;;;A;;;;;A;;;;;A;;;;A;;;;A;;;;A;;;;;;A;;;;;;A;;;;;A;;;;;A;;;;A;;;;A;;;;A;;;;A;;;;;;A;;;;;;A;;;;A;;;;A;;;;A;;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;;;A;;;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;A;;;;;;;;;;;;A;E;;;;;A;;;;;;;;;;;;;;;A;;;;;;;;;A;;;;;;;;;;;;;;;;;A;;;;;;;;;A;;;;;A;;;;;;;;;;;;;;;;;;;;;;;;;A;;;;;;;A;;;;A;;;;;;;;A;;;;;A;;;;;;;;A;;;;;;;;;;;;;;;;;;;;;A;;;;;;;;;;;;;;;A;;;;A;;;;A;;;;;A;;;;A;;;;;;A;;;;;A;;;;;A;;;;;;;A;;;;A;;;;;;;;;;;;;;;A;;;;A;;;;;A;;;;;;A;;;;;;;;;;;;;A;;;;;;;;;A;;;;;;;;;;A;;;;A;;;;;;;;A;;;;;A;;;;A;;;;;A;;;;A;;;;A","sources":["src/sass/index.scss","src/sass/abstract/_easing.scss","src/sass/abstract/_vars.scss","src/sass/abstract/_anims.scss","src/sass/abstract/_extends.scss","src/sass/global/_base.scss","src/sass/global/_colors-txts.scss","src/sass/global/_colors-bgs.scss","src/sass/global/_colors-borders.scss","src/sass/global/_rounded.scss","src/sass/hljs/_ros-pine-moon.scss","src/sass/hljs/oled/_ir-black.scss","src/sass/elements/_accessibility.scss","src/sass/elements/_separators.scss","src/sass/elements/_forms.scss","src/sass/elements/_menu.scss","src/sass/elements/_sidebar.scss","src/sass/elements/_prose.scss","src/sass/elements/_pre.scss","src/sass/elements/_btn.scss","src/sass/elements/_toast.scss","src/sass/elements/_tooltips.scss","src/sass/elements/_logo.scss","src/sass/elements/_modal.scss","src/sass/elements/_dialogs.scss","src/sass/elements/_right--main.scss","src/sass/elements/_right--new-chat.scss","src/sass/elements/_right--sticky.scss","src/sass/elements/_right--textarea.scss","src/sass/pages/_shared-links.scss","src/sass/pages/_gpt-store.scss","src/sass/elements/_transitions.scss","src/sass/gpthemes-els/_gpth-v2.scss"],"sourcesContent":["// @import 'font-face/_roboto';\r\n// @import 'font-face/_jetbrains';\r\n@import 'abstract/_easing';\r\n@import 'abstract/_vars';\r\n@import 'abstract/_anims';\r\n@import 'abstract/_extends';\r\n\r\n// @import 'dev/_mixins';\r\n\r\n@import 'global/_base';\r\n@import 'global/_colors-txts';\r\n@import 'global/_colors-bgs';\r\n@import 'global/_colors-borders';\r\n@import 'global/_rounded';\r\n\r\n/* Highlight,js Theme Styles */\r\n@import 'hljs/_ros-pine-moon';\r\n\r\n/* OLED hljs Themes */\r\n@import 'hljs/oled/_ir-black'; // favorit. yellowish/pink/blue jace boje\r\n// @import 'hljs/oled/_black-metal'; // fino. nije toliko colorful. pink/peach/darkteal/grey\r\n// @import 'hljs/oled/_black-metal-bathory'; // kao i ovo gore, skoro, malo jace boje, nisu tako zagasite\r\n// @import 'hljs/oled/_dark-violet'; // pinkish\r\n// @import 'hljs/oled/_pico'; // orange/green darkest\r\n\r\n// @import 'elements/_forms';\r\n@import 'elements/_accessibility';\r\n@import 'elements/_separators';\r\n@import 'elements/_forms';\r\n@import 'elements/_menu';\r\n@import 'elements/_sidebar';\r\n@import 'elements/_prose';\r\n@import 'elements/_pre';\r\n@import 'elements/_btn';\r\n@import 'elements/_toast';\r\n@import 'elements/_tooltips';\r\n@import 'elements/_logo';\r\n@import 'elements/_modal';\r\n@import 'elements/_dialogs';\r\n@import 'elements/_right--main';\r\n@import 'elements/_right--new-chat';\r\n@import 'elements/_right--sticky';\r\n@import 'elements/_right--textarea';\r\n@import 'pages/_shared-links';\r\n@import 'pages/_gpt-store';\r\n@import 'elements/_transitions';\r\n\r\n// @import 'gpthemes-els/_gpth';\r\n@import 'gpthemes-els/_gpth-v2';\r\n","/* Sine */\r\n$easeInSine: cubic-bezier(0.12, 0, 0.39, 0);\r\n$easeOutSine: cubic-bezier(0.39, 0.575, 0.565, 1);\r\n$easeInOutSine: cubic-bezier(0.445, 0.05, 0.55, 0.95);\r\n\r\n/* Quad */\r\n$easeInQuad: cubic-bezier(0.55, 0.085, 0.68, 0.53);\r\n$easeOutQuad: cubic-bezier(0.25, 0.46, 0.45, 0.94);\r\n$easeInOutQuad: cubic-bezier(0.455, 0.03, 0.515, 0.955);\r\n\r\n/* Cubic */\r\n$easeInCubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);\r\n$easeOutCubic: cubic-bezier(0.215, 0.61, 0.355, 1);\r\n$easeInOutCubic: cubic-bezier(0.645, 0.045, 0.355, 1);\r\n\r\n/* Quart */\r\n$easeInQuart: cubic-bezier(0.165, 0.84, 0.44, 1);\r\n$easeOutQuart: cubic-bezier(0.165, 0.84, 0.44, 1);\r\n$easeInOutQuart: cubic-bezier(0.77, 0, 0.175, 1);\r\n\r\n/* Quint */\r\n$easeInQuint: cubic-bezier(0.755, 0.05, 0.855, 0.06);\r\n$easeOutQuint: cubic-bezier(0.23, 1, 0.32, 1);\r\n$easeInOutQuint: cubic-bezier(0.86, 0, 0.07, 1);\r\n\r\n/* Expo */\r\n$easeInExpo: cubic-bezier(0.95, 0.05, 0.795, 0.035);\r\n$easeOutExpo: cubic-bezier(0.19, 1, 0.22, 1);\r\n$easeInOutExpo: cubic-bezier(1, 0, 0, 1);\r\n\r\n/* Cicr */\r\n$easeInCirc: cubic-bezier(0.6, 0.04, 0.98, 0.335);\r\n$easeOutCirc: cubic-bezier(0.075, 0.82, 0.165, 1);\r\n$easeInOutCirc: cubic-bezier(0.785, 0.135, 0.15, 0.86);\r\n\r\n/* Back */\r\n$easeInBack: cubic-bezier(0.6, -0.28, 0.735, 0.045);\r\n$easeOutBack: cubic-bezier(0.175, 0.885, 0.32, 1.275);\r\n$easeInOutBack: cubic-bezier(0.68, -0.55, 0.265, 1.55);",":root {\r\n\t/* ? --- Fonts --- */\r\n\t--f-fm: 'Inter', sans-serif, Söhne, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell,\r\n\t\tNoto Sans, sans-serif, Helvetica Neue, Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol,\r\n\t\tNoto Color Emoji;\r\n\t--fsz-error-404: 3rem;\r\n\r\n\t--h-header: calc(3.5rem + 0.5rem + 0.375rem);\r\n\r\n\t/* ? --- Border-radius --- */\r\n\t--br: 1rem;\r\n\t--br-chat-bubble: calc(var(--br) * 2.55);\r\n\t--br-prompt-textarea: calc(var(--br) * 2.25);\r\n\t--br-btn: calc(var(--br) / 1.1);\r\n\t--br-btn-big: calc(var(--br) * 1.2);\r\n\t--br-nav-a: var(--br-btn);\r\n\t--br-dialog: calc(var(--br) * 2.5);\r\n\t--br-contextmenu: calc(var(--br-btn) * 1.4);\r\n\t--br-pre: calc(var(--br) * 1.5);\r\n\t--br-tooltips: var(--br-btn);\r\n\r\n\t/* ? --- Paddings --- */\r\n\t--p-chat-bubble: 1.8rem;\r\n\t--p-contextmenu: 0.8rem;\r\n\t--p-contextmenu-item: 0.9rem 1rem;\r\n\t--p-prompt-textarea: 0.7rem;\r\n\t--p-tooltips: 0.2rem;\r\n\t--p-btn: 0.77rem;\r\n\t--py-btn: 1rem;\r\n\t--px-btn: 1rem;\r\n\r\n\t--p-sidebar-nav: 0.5rem;\r\n\t--p-sidebar-nav-a-new-chat: 2rem;\r\n\t--p-sidebar-nav-a: 0.6rem;\r\n\t--p-dialog: 2rem;\r\n\r\n\t/* ? --- Margins --- */\r\n\t--mt-chat-txt: 0.5rem;\r\n\t--mb-chat-txt: 1rem;\r\n\t--mb-chat-bubble: 2rem;\r\n\t--mb-sidebar-nav-li: 0.2rem;\r\n\t--my-pre: 1.5rem;\r\n\r\n\t/* ? --- Blurs --- */\r\n\t--blur-sticky: 20px;\r\n\t--blur-modal: 8px;\r\n\r\n\t/* ? --- Width --- */\r\n\t--min-w-btn: 5.5rem;\r\n\r\n\t/* ? --- Shadow things --- */\r\n\t--box-shadow-values: 0px 0px 100px 0px;\r\n\r\n\t--z-modal: 100;\r\n\r\n\t--sidebar-surface-primary: var(\r\n\t\t--c-bg-sidebar\r\n\t) !important; // GPT's variable in .bg-token-sidebar-surface-primary class. sidebar bg, nav item bg on hover\r\n\t--sidebar-surface-secondary: var(\r\n\t\t--c-surface-2\r\n\t) !important; // GPT's variable in .bg-token-sidebar-surface-secondary nav item bg on hover\r\n\t--main-surface-primary: var(\r\n\t\t--c-surface-2\r\n\t) !important; // header of tables in \"Shared links\" and \"Archived chats\". Arrow btn in new chat big buttons\r\n\t--main-surface-secondary: var(\r\n\t\t--c-surface-2\r\n\t) !important; // markdown header bg, footer of mini chat preview in \"Share Link to Chat\"\r\n\r\n\t--main-surface-tertiary: var(\r\n\t\t--c-surface-3\r\n\t) !important; // border-clr of footer of mini chat preview in \"Share Link to Chat\"\r\n\t--text-quaternary: var(--c-surface-2) !important; // sidebar collapse btn\r\n\r\n\t--popover-surface-primary: var(\r\n\t\t--c-bg-contextmenu\r\n\t) !important; // .bg-token-popover-surface-primary  - contextmenu in theme dropdown chooser | \"Upgrade ur plan\" dialog bg\r\n\r\n\t--border-light: transparent !important; // border oko \"Uprade\" btn-a: .border-token-border-light, border oko inputa u GPTs page\r\n}\r\n\r\n/* @ ================== LIGHT ================== */\r\nhtml.light {\r\n\t/* ? ========== HSL ========== */\r\n\t/* --accent-hsl: 250 99% 65%; */\r\n\t--accent-h: 250;\r\n\t--accent-s: 99%;\r\n\t--accent-l: 65%;\r\n\t--accent-hsl: var(--accent-h) var(--accent-s) var(--accent-l);\r\n\r\n\t/* --txt-hsl: 255 86% 92%; */\r\n\t--txt-h: 0;\r\n\t--txt-s: 0%;\r\n\t--txt-l: 0%;\r\n\t--txt-hsl: var(--txt-h) var(--txt-s) var(--txt-l);\r\n\r\n\t--surface-h: 0;\r\n\t--surface-s: 0%;\r\n\t--surface-l: 85%;\r\n\t--surface-hsl: hsl(var(--surface-h) var(--surface-s) var(--surface-l));\r\n\r\n\t/* --danger-hsl: 346 51% 45% */\r\n\t--danger-h: 346;\r\n\t--danger-s: 51%;\r\n\t--danger-l: 45%;\r\n\t--danger-hsl: var(--danger-h) var(--danger-s) var(--danger-l);\r\n\t--c-danger: hsl(var(--danger-hsl));\r\n\r\n\t/* ? ========== COLORS ========== */\r\n\t--c-accent: hsl(var(--accent-hsl));\r\n\t--c-accent-light: hsl(var(--accent-h), calc(var(--accent-s) / 2), calc(var(--accent-l) * 1.3));\r\n\t--c-on-accent: hsl(var(--accent-h), var(--accent-s), calc(var(--accent-l) * 1.5));\r\n\r\n\t/* ? ========== Text colors ========== */\r\n\t--c-txt: hsl(var(--txt-hsl));\r\n\t--c-subtext-1: hsla(0, 0%, 20%);\r\n\t--c-subtext-2: hsl(0, 0%, 40%);\r\n\r\n\t/* ? ========== Surface colors ========== */\r\n\t--c-surface-1: hsl(0, 0%, var(--surface-l)); // dark\r\n\t--c-surface-2: hsl(0, 0%, calc(var(--surface-l) / 1.089)); // darker - 78.05\r\n\t--c-surface-3: hsl(0, 0%, calc(var(--surface-l) / 1.18)); // darkest - 72.03\r\n\r\n\t/* ? ========== Layout colors ========== */\r\n\t--c-bg-sidebar: var(--c-surface-1);\r\n\t--c-bg-chats-container: hsl(var(--accent-h) var(--surface-s) calc(var(--surface-l) * 1.025));\r\n\t--c-bg-chats-sticky: hsla(var(--accent-hsl) / 0.02);\r\n\r\n\t/* ? ========== Chat bubbles colors ========== */\r\n\t--c-bg-msg-user: hsla(var(--accent-hsl) / 0.08);\r\n\t--c-bg-msg-gpt: hsl(0 0% 84%);\r\n\t--c-msg-name-user: var(--c-accent);\r\n\r\n\t/* ? ========== Type message textarea colors ========== */\r\n\t--c-bg-textarea: hsla(0, 0%, calc(var(--surface-l) / 1.05));\r\n\t--c-border-textarea: var(--c-bg-textarea);\r\n\t--c-placeholder-textarea: hsla(var(--txt-hsl) / 0.6);\r\n\r\n\t/* ? ========== modal, dialog, contextmenu bg ========== */\r\n\t--c-bg-modal: hsla(var(--txt-hsl) / 0.3);\r\n\t--c-bg-dialog: var(--c-surface-2);\r\n\t--c-bg-contextmenu: var(--c-surface-3);\r\n\r\n\t/* ? ========== Tooltip bg ========== */\r\n\t--c-bg-tooltip: var(--c-accent-light);\r\n\r\n\t/* ? ========== border colors ========== */\r\n\t--c-border: hsla(var(--txt-hsl) / 0.05);\r\n\t--c-border-accent: hsla(var(--accent-hsl) / 0.1);\r\n\r\n\t/* ? ========== btn colors ========== */\r\n\t--c-btn: var(--c-on-accent);\r\n\t--c-bg-btn: var(--c-accent);\r\n\r\n\t/* ? ========== <pre>/markdown things colors ========== */\r\n\t--c-bg-pre: hsl(0, 0%, 0%);\r\n\t--c-bg-pre-header: transparent;\r\n\t--c-bg-pre-header-btn: var(--c-accent);\r\n\t--c-markdown-a: var(--c-accent);\r\n\r\n\t/* ? ========== Scrollbar colors ========== */\r\n\t--c-scrollbar-thumb: var(--c-surface-3);\r\n\t--c-scrollbar-track: transparent;\r\n\r\n\t/* ? ========== OpenAI surface colors ========== */\r\n\t/* btn u biranju teme kad nemaa nikake pozadine */\r\n\t--surface-primary: var(--c-surface-1) !important;\r\n\r\n\t/* border oko context-menu, .bg-token-surface-secondary (za active link u sidebaru)*/\r\n\t--surface-secondary: transparent !important;\r\n\r\n\t/* Selected button/link/list in settings: \"General\", \"Data controls\" */\r\n\t--surface-tertiary: var(--c-bg-msg-gpt) !important;\r\n\r\n\t/* ? ========== OpenAI text colors ========== */\r\n\t/*``` --text-primary \r\n        - body txt\r\n        - ??\r\n    */\r\n\t--text-primary: var(--c-txt) !important;\r\n\r\n\t/*``` --text-secondary \r\n        - txt ispod \"Upgrade\"\r\n        - txt ispod \"Chat history & training\" u Settingsu\r\n        - txt \"3.5\" u sticky pored \"ChatGPT 3.5\"\r\n        - kad je recimo focused sa tabom Dark u \"Themes\"\r\n        - text kad se ode na \"Upgrade\" pa ono \"Have an existing plan? See billing help\"\r\n    */\r\n\t--text-secondary: var(--c-subtext-1) !important;\r\n\r\n\t/*``` --text-tertiary \r\n        - strelica na dole pored 3.5 u sticky pored ChatGPT 3.5\r\n        - kad je nesto focused sa tabom - accessibility - npr Clear u clear all chats\r\n        - text u contextmenu kad se klikne na ChatGPT 3.5\r\n        - text kad odemo u  UPgrade pa ono USD $0/month i USD $20/month \r\n    */\r\n\t--text-tertiary: var(--c-subtext-2) !important;\r\n\r\n\t/* ? ========== PROVERITI - gray ========== */\r\n\t--gray-300: var(--text-secondary) !important;\r\n\r\n\t/* 3 tacke u listi u sidebar */\r\n\t--gray-500: var(--c-txt) !important;\r\n\r\n\t/* ? ========== BOX-SHADOW ==========*/\r\n\t--box-shadow: var(--box-shadow-values) hsla(var(--accent-hsl) / 0.1);\r\n\t// --box-shadow-contextmenu: 0px 0px 5px -2px hsla(0, 0%, 0%, 0.18);\r\n\t--box-shadow-contextmenu: inset 0px 0px 10px 2px hsla(0, 0%, 0%, 0.1);\r\n\t--box-shadow-textarea: inset 0px 0px 15px 1px hsla(0, 0%, 0%, 0.1) !important;\r\n}\r\n\r\n/* @ ================== DARK ================== */\r\nhtml.dark {\r\n\t/* ? ========== HSL ========== */\r\n\r\n\t/* --accent-hsl: 272 93% 78%; */\r\n\t--accent-h: 272;\r\n\t--accent-s: 93%;\r\n\t--accent-l: 78%;\r\n\t--accent-hsl: var(--accent-h) var(--accent-s) var(--accent-l);\r\n\r\n\t/* --txt-hsl: 255 86% 92%; */\r\n\t--txt-h: 255;\r\n\t--txt-s: 86%;\r\n\t--txt-l: 92%;\r\n\t--txt-hsl: var(--txt-h) var(--txt-s) var(--txt-l);\r\n\r\n\t--surface-h: 249;\r\n\t--surface-s: 19%;\r\n\t--surface-l: 13%;\r\n\t--surface-hsl: hsl(var(--accent-h) var(--surface-s) var(--surface-l));\r\n\r\n\t/* --danger-hsl: 356 77% 76% */\r\n\t--danger-h: 356;\r\n\t--danger-s: 77%;\r\n\t--danger-l: 76%;\r\n\t--danger-hsl: var(--danger-h) var(--danger-s) var(--danger-l);\r\n\t--c-danger: hsl(var(--danger-hsl));\r\n\r\n\t/* ? ========== COLORS ========== */\r\n\t--c-accent: hsl(var(--accent-hsl));\r\n\t--c-accent-light: hsl(var(--accent-h), calc(var(--accent-s) / 1.3), var(--accent-l));\r\n\t--c-on-accent: hsl(var(--accent-h), var(--accent-s), 10%);\r\n\r\n\t/* ? ========== Text colors ========== */\r\n\t--c-txt: hsl(var(--txt-hsl));\r\n\t--c-subtext-1: var(--c-accent-light);\r\n\t--c-subtext-2: hsl(var(--accent-h) calc(var(--accent-s) / 2) var(--accent-l)) !important;\r\n\r\n\t/* ? ========== Surface colors ========== */\r\n\t--c-surface-1: hsl(var(--accent-h), var(--surface-s), var(--surface-l)); // darkest\r\n\t--c-surface-2: hsl(var(--accent-h), var(--surface-s), calc(var(--surface-l) * 1.5)); // darker\r\n\t--c-surface-3: hsl(var(--accent-h), var(--surface-s), calc(var(--surface-l) * 2)); // dark\r\n\r\n\t/* ? ========== Layout colors ========== */\r\n\t--c-bg-sidebar: var(--c-surface-1);\r\n\t--c-bg-chats-container: hsl(var(--accent-h) var(--surface-s) calc(var(--surface-l) * 1.076));\r\n\t--c-bg-chats-sticky: hsla(var(--surface-hsl) / 0.02);\r\n\r\n\t/* ? ========== Chat bubbles colors ========== */\r\n\t--c-bg-msg-user: hsla(var(--accent-hsl) / 0.04);\r\n\t--c-bg-msg-gpt: hsla(var(--accent-hsl) / 0.08);\r\n\t--c-msg-name-user: var(--c-accent);\r\n\t// --c-msg-name-gpt: var(--c-green);\r\n\r\n\t/* ? ========== Type message textarea colors ========== */\r\n\t--c-bg-textarea: var(--c-surface-2);\r\n\t--c-border-textarea: var(--c-surface-2);\r\n\t--c-placeholder-textarea: hsl(var(--accent-hsl) / 0.8);\r\n\r\n\t/* ? ========== modal, dialog, contextmenu bg ========== */\r\n\t--c-bg-modal: hsla(var(--accent-hsl) / 0.22);\r\n\t--c-bg-dialog: var(--c-surface-2);\r\n\t--c-bg-contextmenu: var(--c-surface-3);\r\n\r\n\t/* ? ========== Tooltip bg ========== */\r\n\t--c-bg-tooltip: var(--c-accent-light);\r\n\r\n\t/* ? ========== border colors ========== */\r\n\t--c-border: var(--c-surface-3);\r\n\t--c-border-accent: hsla(var(--accent-hsl) / 0.05);\r\n\r\n\t/* ? ========== btn colors ========== */\r\n\t--c-btn: var(--c-on-accent);\r\n\t--c-bg-btn: var(--c-accent);\r\n\r\n\t/* ? ========== <pre>/markdown things colors ========== */\r\n\t--c-bg-pre: hsl(0, 0%, 0%);\r\n\t--c-bg-pre-header: transparent;\r\n\t--c-bg-pre-header-btn: var(--c-accent);\r\n\t--c-markdown-a: var(--c-accent);\r\n\r\n\t/* ? ========== Scrollbar colors ========== */\r\n\t--c-scrollbar-thumb: var(--c-surface-3);\r\n\t--c-scrollbar-track: transparent;\r\n\r\n\t/* ? ========== OpenAI surface colors ========== */\r\n\t/* btn u biranju teme kad nema nikake pozadine */\r\n\t--surface-primary: var(--c-surface-1) !important;\r\n\r\n\t/* border oko context-menu */\r\n\t--surface-secondary: transparent !important;\r\n\r\n\t/* Selected button/link/list in settings: \"General\", \"Data controls\" */\r\n\t--surface-tertiary: var(--c-bg-msg-gpt) !important;\r\n\r\n\t/* ? ========== OpenAI text colors ========== */\r\n\t/*``` --text-primary \r\n        - body txt\r\n        - ??\r\n    */\r\n\t--text-primary: var(--c-txt) !important;\r\n\r\n\t/*``` --text-secondary \r\n        - txt ispod \"Upgrade\"\r\n        - txt ispod \"Chat history & training\" u Settingsu\r\n        - txt \"3.5\" u sticky pored \"ChatGPT 3.5\"\r\n        - kad je recimo focused sa tabom Dark u \"Themes\"\r\n        - text kad se ode na \"Upgrade\" pa ono \"Have an existing plan? See billing help\"\r\n    */\r\n\t--text-secondary: var(--c-subtext-1) !important;\r\n\r\n\t/*``` --text-tertiary \r\n        - strelica na dole pored 3.5 u sticky pored ChatGPT 3.5\r\n        - kad je nesto focused sa tabom - accessibility - npr Clear u clear all chats\r\n        - text u contextmenu kad se klikne na ChatGPT 3.5\r\n        - text kad odemo u  UPgrade pa ono USD $0/month i USD $20/month \r\n    */\r\n\t--text-tertiary: var(--c-subtext-2) !important;\r\n\r\n\t/* ? ========== PROVERITI - gray ========== */\r\n\t--gray-300: var(--text-secondary) !important;\r\n\r\n\t/* 3 tacke u listi u sidebar */\r\n\t--gray-500: var(--c-txt) !important;\r\n\r\n\t/* ? ========== BOX-SHADOW ==========*/\r\n\t--box-shadow: var(--box-shadow-values) hsla(var(--accent-hsl) / 0.1);\r\n\t// --box-shadow-contextmenu: 0px 0px 30px -10px hsla(var(--accent-hsl) / 0.18);\r\n\t--box-shadow-contextmenu: inset 0px 0px 12px 1px hsla(var(--accent-hsl) / 0.13);\r\n\t--box-shadow-textarea: inset 0px 0px 15px 1px hsla(var(--accent-hsl) / 0.05) !important;\r\n}\r\n\r\n/* @ ================== OLED ================== */\r\nhtml.dark[data-gptheme='oled'] {\r\n\t/* ? ========== HSL ========== */\r\n\r\n\t/* --accent-hsl: 272 93% 78%; */\r\n\t--accent-h: 272;\r\n\t--accent-s: 93%;\r\n\t--accent-l: 78%;\r\n\t--accent-hsl: var(--accent-h) var(--accent-s) var(--accent-l);\r\n\r\n\t/* --txt-hsl: 255 86% 92%; */\r\n\t--txt-h: 255;\r\n\t--txt-s: 86%;\r\n\t--txt-l: 92%;\r\n\t--txt-hsl: var(--txt-h) var(--txt-s) var(--txt-l);\r\n\r\n\t--surface-h: 0;\r\n\t--surface-s: 0%;\r\n\t--surface-l: 0%;\r\n\t--surface-hsl: hsl(var(--accent-h) var(--surface-s) var(--surface-l));\r\n\r\n\t/* --danger-hsl: 356 77% 76% */\r\n\t--danger-h: 356;\r\n\t--danger-s: 77%;\r\n\t--danger-l: 76%;\r\n\t--danger-hsl: var(--danger-h) var(--danger-s) var(--danger-l);\r\n\t--c-danger: hsl(var(--danger-hsl));\r\n\r\n\t/* ? ========== COLORS ========== */\r\n\t--c-accent: hsl(var(--accent-hsl));\r\n\t--c-accent-light: hsl(var(--accent-h), calc(var(--accent-s) / 1.3), var(--accent-l));\r\n\t--c-on-accent: hsl(var(--accent-h), var(--accent-s), 10%);\r\n\r\n\t/* ? ========== Text colors ========== */\r\n\t--c-txt: hsl(var(--txt-hsl));\r\n\t--c-subtext-1: var(--c-accent-light);\r\n\t--c-subtext-2: hsl(var(--accent-h) calc(var(--accent-s) / 2) var(--accent-l)) !important;\r\n\r\n\t/* ? ========== Surface colors ========== */\r\n\t// --c-surface-1: black; // darkest\r\n\t--c-surface-1: black; // darkest\r\n\t// --c-surface-2: #191c1e; // darker\r\n\t// --c-surface-3: #262229; // dark\r\n\t--c-surface-2: hsl(var(--accent-h), calc(var(--surface-s) + 15%), calc(var(--surface-l) + 12%)); // darker\r\n\t// --c-surface-2: rgb(49, 220, 74); // darker\r\n\t--c-surface-3: hsl(var(--accent-h), calc(var(--surface-s) + 15%), calc(var(--surface-l) + 8%)); // dark\r\n\r\n\t/* ? ========== Layout colors ========== */\r\n\t// --c-bg-sidebar: var(--c-surface-1);\r\n\t// --c-bg-chats-container: var(--c-surface-2);\r\n\t--c-bg-sidebar: black;\r\n\t--c-bg-chats-container: black;\r\n\t--c-bg-chats-sticky: black;\r\n\r\n\t/* ? ========== Chat bubbles colors ========== */\r\n\t// --c-bg-msg-user: hsla(var(--accent-hsl) / 0.04);\r\n\t// --c-bg-msg-gpt: hsla(var(--accent-hsl) / 0.08);\r\n\t--c-bg-msg-user: hsl(var(--accent-h), calc(var(--surface-s) + 15%), calc(var(--surface-l) + 4%));\r\n\t--c-bg-msg-gpt: hsl(var(--accent-h), calc(var(--surface-s) + 20%), calc(var(--surface-l) + 6%));\r\n\t--c-msg-name-user: var(--c-accent);\r\n\t// --c-msg-name-gpt: var(--c-green);\r\n\r\n\t/* ? ========== Type message textarea colors ========== */\r\n\t--c-bg-textarea: var(--c-surface-3);\r\n\t--c-placeholder-textarea: hsl(var(--accent-hsl) / 0.8);\r\n\r\n\t/* ? ========== modal, dialog, contextmenu bg ========== */\r\n\t--c-bg-modal: hsla(var(--accent-hsl) / 0.09);\r\n\t--c-bg-dialog: var(--c-surface-1);\r\n\t--c-bg-contextmenu: var(--c-surface-3);\r\n\r\n\t/* ? ========== Tooltip bg ========== */\r\n\t--c-bg-tooltip: var(--c-accent-light);\r\n\r\n\t/* ? ========== border colors ========== */\r\n\t--c-border: var(--c-surface-3);\r\n\t--c-border-accent: hsla(var(--accent-hsl) / 0.05);\r\n\r\n\t/* ? ========== btn colors ========== */\r\n\t--c-btn: var(--c-on-accent);\r\n\t--c-bg-btn: var(--c-accent);\r\n\r\n\t/* ? ========== <pre>/markdown things colors ========== */\r\n\t--c-bg-pre: hsl(0, 0%, 0%);\r\n\t--c-bg-pre-header: transparent;\r\n\t--c-bg-pre-header-btn: var(--c-accent);\r\n\t--c-markdown-a: var(--c-accent);\r\n\r\n\t/* ? ========== Scrollbar colors ========== */\r\n\t--c-scrollbar-thumb: var(--c-surface-3);\r\n\t--c-scrollbar-track: transparent;\r\n\r\n\t/* ? ========== OpenAI surface colors ========== */\r\n\t/* btn u biranju teme kad nema nikake pozadine */\r\n\t--surface-primary: var(--c-surface-1) !important;\r\n\r\n\t/* border oko context-menu */\r\n\t--surface-secondary: transparent !important;\r\n\r\n\t/* Selected button/link/list in settings: \"General\", \"Data controls\" */\r\n\t--surface-tertiary: var(--c-bg-msg-gpt) !important;\r\n\r\n\t/* ? ========== OpenAI text colors ========== */\r\n\t/*``` --text-primary \r\n        - body txt\r\n        - ??\r\n    */\r\n\t--text-primary: var(--c-txt) !important;\r\n\r\n\t/*``` --text-secondary \r\n        - txt ispod \"Upgrade\"\r\n        - txt ispod \"Chat history & training\" u Settingsu\r\n        - txt \"3.5\" u sticky pored \"ChatGPT 3.5\"\r\n        - kad je recimo focused sa tabom Dark u \"Themes\"\r\n        - text kad se ode na \"Upgrade\" pa ono \"Have an existing plan? See billing help\"\r\n    */\r\n\t--text-secondary: var(--c-subtext-1) !important;\r\n\r\n\t/*``` --text-tertiary \r\n        - strelica na dole pored 3.5 u sticky pored ChatGPT 3.5\r\n        - kad je nesto focused sa tabom - accessibility - npr Clear u clear all chats\r\n        - text u contextmenu kad se klikne na ChatGPT 3.5\r\n        - text kad odemo u  UPgrade pa ono USD $0/month i USD $20/month \r\n    */\r\n\t--text-tertiary: var(--c-subtext-2) !important;\r\n\r\n\t/* ? ========== PROVERITI - gray ========== */\r\n\t--gray-300: var(--text-secondary) !important;\r\n\r\n\t/* 3 tacke u listi u sidebar */\r\n\t--gray-500: var(--c-txt) !important;\r\n\r\n\t/* ? ========== BOX-SHADOW ==========*/\r\n\t--box-shadow: var(--box-shadow-values) hsla(var(--accent-hsl) / 0.1);\r\n\t// --box-shadow-contextmenu: 0px 0px 30px 0px hsla(var(--accent-hsl) / 0.1);\r\n\t// --box-shadow-contextmenu: 0px 0px 30px 0px red;\r\n\t--box-shadow-contextmenu: inset 0px 0px 15px 1px hsla(var(--accent-hsl) / 0.08);\r\n\t--box-shadow-textarea: inset 0px 0px 15px 1px hsla(var(--accent-hsl) / 0.05) !important;\r\n\t// --box-shadow-contextmenu: 0px 0px 30px 0px red;\r\n}\r\n","/* @keyframes animScrollText {\r\n\t0% {\r\n\t\ttransform: translateX(0);\r\n\t}\r\n\t70% {\r\n\t\ttransform: translateX(-26%);\r\n\t}\r\n\t100% {\r\n\t\ttransform: translateX(0);\r\n\t}\r\n} */\r\n\r\n/* @keyframes animFadeInClipPathCircle {\r\n\t0% {\r\n\t\topacity: 0;\r\n\t\tclip-path: circle(0%);\r\n\t\t// clip-path: polygon(50% 0%, 50% 0%, 50% 100%, 50% 100%);\r\n\t}\r\n\r\n\t100% {\r\n\t\topacity: 1;\r\n\t\tclip-path: circle(100% at 50% 50%);\r\n\t\t// clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);\r\n\t}\r\n} */\r\n\r\n@keyframes animFadeInClipPath {\r\n\t0% {\r\n\t\topacity: 0;\r\n\t\tclip-path: polygon(0% 0%, 100% 0%, 100% 0%, 0% 0%);\r\n\t}\r\n\t100% {\r\n\t\topacity: 1;\r\n\t\tclip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);\r\n\t}\r\n}\r\n\r\n@keyframes animFadeIn {\r\n\tfrom {\r\n\t\topacity: 0;\r\n\t}\r\n\tto {\r\n\t\topacity: 1;\r\n\t}\r\n}\r\n","/* %animFadeInClipPathCircle {\r\n\twill-change: opacity, clip-path;\r\n\tanimation: animFadeInClipPathCircle 0.2s linear forwards;\r\n} */\r\n%animFadeInClipPath {\r\n\twill-change: opacity, clip-path;\r\n\tanimation: animFadeInClipPath 0.2s linear forwards;\r\n}\r\n%animFadeIn {\r\n\twill-change: opacity;\r\n\tanimation: animFadeIn var(--anim-duration, 0.2s) linear forwards;\r\n}\r\n/* %animFadeOut {\r\n\twill-change: opacity;\r\n\tanimation: animFade var(--anim-duration, 0.4s) linear reverse;\r\n} */\r\n\r\n%link_default {\r\n\tposition: relative;\r\n\ttext-decoration: none;\r\n\tcolor: var(--c-accent) !important;\r\n\t// display: inline-block;\r\n\ttransition: opacity 0.3s ease;\r\n\r\n\t/* Style for the ::after pseudo-element (initially hidden) */\r\n\t&::after {\r\n\t\tcontent: '';\r\n\t\tposition: absolute;\r\n\t\twidth: 100%;\r\n\t\theight: 2px;\r\n\t\tbottom: -5px;\r\n\t\tleft: 0;\r\n\t\t// right: 0; /* Set right to cover the entire link */\r\n\t\tbackground-color: currentColor;\r\n\t\tborder-radius: 20px;\r\n\t\ttransition: transform 0.3s $easeOutCubic;\r\n\t}\r\n}\r\n%link_hover_underlined {\r\n\t@extend %link_default;\r\n\r\n\t/* Style for the ::after pseudo-element (initially hidden) */\r\n\t&::after {\r\n\t\ttransform: scaleX(1);\r\n\t\ttransform-origin: bottom left;\r\n\t}\r\n\r\n\t&:hover::after {\r\n\t\ttransform: scaleX(0);\r\n\t\ttransform-origin: bottom right;\r\n\t}\r\n}\r\n%link_hover_underless {\r\n\t@extend %link_default;\r\n\r\n\t&::after {\r\n\t\ttransform: scaleX(0);\r\n\t\ttransform-origin: bottom right;\r\n\t}\r\n\r\n\t&:hover::after {\r\n\t\ttransform: scaleX(1);\r\n\t\ttransform-origin: bottom left;\r\n\t}\r\n}\r\n\r\n%sidebar_link_item_btns_bg {\r\n\t/* \r\n        hsla(0, 0%, calc(var(--surface-l) / 1.089), 0.7) \r\n        - this nice resolve but it doesn't work bcs it is BLACK-ISH, WTF ???? \r\n    */\r\n\t// background-image: linear-gradient(to right, hsla(0, 0%, calc(var(--surface-l) / 1.089), 0.7) 0%, var(--c-surface-2) 30%, var(--c-surface-2) 100%) !important;\r\n\tbackground-color: var(--c-surface-2) !important;\r\n\tborder-top-right-radius: inherit;\r\n\tborder-bottom-right-radius: inherit;\r\n\tpadding-left: 0.5rem;\r\n}\r\n","/* Ovo nece zbog CORS-a */\r\n// @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');\r\n// @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:ital,wght@0,300;0,400;0,700;1,400&display=swap');\r\n\r\nhtml,\r\nbody {\r\n\t--text-primary: var(--c-txt) !important;\r\n\r\n\tfont-family: var(--f-fm) !important;\r\n\tcolor: var(--c-txt) !important;\r\n\tbackground-color: var(--c-bg-chats-container) !important;\r\n}\r\n\r\na {\r\n\tfont-family: var(--f-fm) !important;\r\n}\r\n\r\n/* scrollbar-color for For Firefox */\r\n@-moz-document url-prefix() {\r\n\thtml {\r\n\t\tscrollbar-color: var(--c-scrollbar-thumb) var(--c-scrollbar-track); // second parameter (transparent) is for bg-thumb\r\n\t}\r\n}\r\n// /* scrollbar-thumb-color for Chromium-based browsers */\r\n::-webkit-scrollbar-thumb {\r\n\tbackground-color: var(--c-scrollbar-thumb) !important;\r\n}\r\n\r\n::selection {\r\n\tbackground-color: hsla(var(--accent-hsl) / 0.5) !important;\r\n\tcolor: var(--c-txt) !important;\r\n\t// color: var(--c-on-accent) !important;\r\n}\r\n\r\nbutton {\r\n\t--text-primary: var(--c-txt) !important;\r\n}\r\n\r\ninput::placeholder,\r\ntextarea::placeholder {\r\n\tcolor: var(--c-placeholder) !important;\r\n\topacity: 0.6 !important;\r\n}\r\n\r\n.h-px {\r\n\tdisplay: none !important;\r\n}\r\n\r\n/* .markdown {\r\n    [type=\"checkbox\"]:checked {\r\n        background-color: var(--c-accent);\r\n        --svg: escape('<svg viewBox=\"0 0 16 16\" fill=\"@{base}\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0z\"/></svg>'\r\n        );\r\n        // background-image: \"~url('data:image/svg+xml;charset=utf-8,@{svg}')\";\r\n        background-image: \"~url('data:image/svg+xml;charset=utf-8,#{var(--svg)}}')\";\r\n    }\r\n} */\r\n\r\ncode.hljs {\r\n\t// font-size: .85rem !important;\r\n\t// font-family: 'JetBrains Mono', monospace !important;\r\n\tletter-spacing: -0.2px;\r\n}\r\n\r\n/* === BORDER RADIUS */\r\n.rounded-md {\r\n\tborder-radius: var(--br-btn);\r\n}\r\n\r\n/* Shadow in \"Upgrade your plan\" */\r\n.shadow-md {\r\n\tbox-shadow: none;\r\n}\r\n\r\n/* \"404 |\" in \"404 | This page could not be found\" */\r\n.next-error-h1 {\r\n\tcolor: var(--c-accent);\r\n\tborder-color: currentColor !important;\r\n\tfont-size: var(--fsz-error-404) !important;\r\n\tfont-weight: 600 !important;\r\n}\r\n","/* ==== TYPOGRAPHY COLORS */\r\n\r\n/*\r\n\t- Obrati paznju na TOOLTIP clr i accent btns sa svg!!!\r\n \t- Have to add .toast-root .text-white[role='alert'] into :not() but it somehow affects tooltip txt color, wtf. And I cant investigate tooltip bcs it goes hidden when it is shown only on javascript mouseover.\r\n\r\n\t- [class*='text-gray-'] utice i na div[data-radix-popper-content-wrapper] tj \"Theme\" dropdown iteme te ne mogu da se overwrituju tamo u _menu.scss. Zato sam sklonila !important\r\n*/\r\n[class*='text-gray-']:not(.text-gray-100, .text-gray-400, .text-gray-500, .text-gray-600),\r\n[class*='text-white']:not(.btn-primary .text-white, .bg-green-600, svg, .toast-root .text-white[role='alert']) {\r\n\tcolor: var(--c-txt);\r\n}\r\n\r\n/* \r\n - Is this conversation helpful so far? 👍👎\r\n - tg-500 je recimo btn svg u \"Archived/Shared Links\" popup\r\n - tg-400 (dark) tg-600 (light) in \"You have no shared links.\"\r\n*/\r\n.text-gray-400,\r\n.text-gray-600,\r\n.text-gray-500 {\r\n\tcolor: var(--c-subtext-2) !important;\r\n\t// color: red !important;\r\n}\r\n\r\n/* .text-gizmo-gray-500 is the footer txt in dialog \"YOU'RE INVITED TO PLUS\" */\r\n.text-gizmo-gray-500,\r\n.text-gray-100 {\r\n\tcolor: var(--c-subtext-1) !important;\r\n}\r\n\r\n.text-token-text-secondary {\r\n\tcolor: var(--c-subtext-1) !important;\r\n\t// color: red !important;\r\n}\r\n\r\n/* \"Log out\", \"Delete all conversations\", \"Delete chat\" */\r\n.text-red-500 {\r\n\tcolor: var(--c-danger) !important;\r\n}\r\n\r\n/* Intro page (before login) */\r\n[class*='text-[#FE7600]'] {\r\n\tcolor: var(--c-accent);\r\n}\r\n","/* === BG COLORS */\r\n\r\n/* \r\n- Textarea msg bg. \r\n- \"Share link to chat\" dialog chat min duplicate (.bg-white)\r\n- Chat history & Training\" checkbox bullet\r\n */\r\n.bg-gray-900,\r\n.bg-white {\r\n\tbackground-color: var(--c-surface-1) !important;\r\n\t// background-color: red !important;\r\n}\r\n\r\n/* \r\n// ``` .bg-gray-50\r\n\t\t- \"❓\" btn \r\n\r\n// ``` .bg-gray-100\r\n\t\t- Line | in \"Is this conversation helpful so far?\r\n👍 👎 | ✖️\" */\r\n.bg-gray-50,\r\n.bg-gray-100 {\r\n\tbackground-color: var(--c-surface-2) !important;\r\n}\r\n// .bg-gray-50 {\r\n// \t// background-color: var(--c-surface-2) !important;\r\n// \tbackground-color: red !important;\r\n// }\r\n\r\n/* \r\n - \"Was this response better or worse?\" el when clicked on regenerate answer btn \r\n - \"Delete all shared links\" in \"Shared liks\" dialog\r\n - line | between \"s this conversation helpful so far? 👍👎\" and \"x\"\r\n*/\r\n// .bg-gray-100,\r\n// [class*=\":bg-gray-700\"] {\r\n//     background-color: red !important;\r\n// }\r\n\r\n/* hover:bg-gray-100 dark:hover:bg-gray-600 \r\n\t- GPTs Store PAGE - \"Featured\" section items :hover states\r\n\t- GPTs Store PAGE - \"Top picks\", \"DALLE\", \"Writing\" etc tags :hover states \r\n\t- GPTs Store PAGE - \"Search public GPTs\" search list item bg :hover states */\r\n[class*='dark:hover:bg-gray-600'] {\r\n\t&:hover {\r\n\t\tbackground-color: var(--c-surface-1) !important;\r\n\t\t// background-color: red !important;\r\n\t}\r\n}\r\n\r\n/* GPTs store PAGE - \"Trending\" section items hover state\" */\r\n[class*='dark:hover:bg-gray-700'] {\r\n\t&:hover {\r\n\t\tbackground-color: var(--c-surface-2) !important;\r\n\t}\r\n}\r\n\r\n/* [role='menuitem'] :hover state */\r\n[class*='dark:hover:bg-gray-800'],\r\n[class*='dark:hover:bg-white/5'] {\r\n\t&:hover {\r\n\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t// background-color: red !important;\r\n\t}\r\n}\r\n\r\n/* \r\n\t- GPTS store PAGE - \"Search public GPTs\" search list item bg \r\n\t- GPTs Store PAGE - \"Top picks\", \"DALLE\", \"Writing\" etc tags \r\n\t- GPTs Store PAGE - \"Featured\" section items bg\r\n\t- GPTs Store PAGE - Bg for Buttons left and right arrow for \"Top picks\", \"DALLE\", \"Writing\" etc tags on smaller screens\r\n\t- Inputs in \"Delete Account- Are you sure\" dialog  */\r\n[class*='dark:bg-gray-700'] {\r\n\tbackground-color: var(--c-surface-2) !important;\r\n\t// background-color: red !important;\r\n}\r\n\r\n/* \r\n- \"Shared links\" PAGE - overall BG !!!!\r\n- GPTS store PAGE - \"Search public GPTs\" search input bg. Nema klase za light temu te selektujem klasom za darks \r\n- Bg of mini chat-bubble in \"Share link to chat\" dialog.\r\n- Textarea in [role=\"dialog\"] */\r\n[class*='dark:bg-gray-800'] {\r\n\tbackground-color: var(--c-bg-chats-container) !important; // var(--c-surface-3)\r\n\t// background-color: var(--c-surface-1) !important;\r\n}\r\n\r\n/* Shared chats PAGE - green button \"Upgrade to Plus to create your own GPT\" */\r\n[class*='bg-green-600'] {\r\n\tbackground-color: var(--c-accent) !important;\r\n\tcolor: var(--c-on-accent) !important;\r\n}\r\n\r\n[class*='bg-red-500/10'] {\r\n\tbackground-color: hsla(var(--danger-hsl) / 0.11) !important;\r\n\tcolor: var(--c-danger) !important;\r\n\t// background-color: var(--c-danger) !important;\r\n}\r\n\r\n/* Like icon in \"Provide aditional feedback\" dialog when clicked liked answer */\r\n// .bg-green-100 {}\r\n\r\n.bg-gradient-to-l,\r\n.bg-gradient-to-r {\r\n\t--gradient-color-from: var(--c-surface-1);\r\n\t--gradient-color-to: transparent;\r\n\r\n\t--tw-gradient-from: var(--gradient-color-from) var(--tw-gradient-from-position) !important;\r\n\t--tw-gradient-to: var(--gradient-color-to) var(--tw-gradient-to-position);\r\n}\r\n\r\n/* Active link bg in sidebar listitem */\r\n.bg-token-surface-secondary {\r\n\t--surface-secondary: var(--c-surface-2) !important;\r\n}\r\n\r\n/* \r\n- Dialogs\r\n- Tabs in \"Settings\"\r\n- Table <thead> els\r\n- Share Link > Mini chat conversation\r\n- Context menu items in Share Link > Mini chat conversation\r\n- Context menu items in Settings > Theme ddl and Theme\r\n- Sticky header \r\n- Prompt textarea\r\n- Sidebar Circled gpt logo - NEWCHAT/CLEAR CHAT\r\n- Circled gpt logo \"How can I help you today\r\n- Scrolldown btn\r\n- ❓ btn on bottom right\r\n- Checkbox circle\r\n- GPTs Store PAGE - Search query section\r\n- GPTs Store PAGE - Search query section link-on-hover - CHANGE IT !!\r\n */\r\n[class*='bg-white'],\r\n.bg-token-sidebar-surface-secondary {\r\n\tbackground-color: var(--c-surface-2) !important;\r\n\t// @include borderBoxShadow(red);\r\n\t// background-color: red;\r\n}\r\n\r\n/* \r\n- Sidebar\r\n- Sidebar sticky behind NEWCHAT btn\r\n- Sidebar \"Today\", \"Yesterday\"... time headings \r\n- Sidebar user profile picture\r\n- Tooltip\r\n- ChatGPT 3.5 btn in sticky header\r\n- Context menu items in 3dots\r\n- Context menu items in ChatGPT 3.5\r\n- Markdown <pre>\r\n- Prompt textarea send button\r\n- GPTs - active pill (\"Top Picks\")\r\n */\r\n[class*='bg-black'],\r\n.bg-token-sidebar-surface-primary {\r\n\tbackground-color: var(--c-surface-1);\r\n\t// @include borderBoxShadow(lightgreen);\r\n\t// background-color: lightgreen;\r\n}\r\n","/* === BORDER COLORS */\r\n\r\n/* Border in textarea in \"Custom Instructions\" dialog */\r\n.border-gray-100 {\r\n\t// border-color: var(--c-surface-1) !important;\r\n\tborder-color: transparent !important;\r\n}\r\n\r\n.border-gray-200 {\r\n\tborder-color: var(--c-surface-2) !important;\r\n}\r\n\r\n/* Border in inputs in \"Upgrade your Plan\" dialog */\r\n.border-gray-300 {\r\n\t// border-color: red !important;\r\n\t// border-color: transparent !important;\r\n\tborder: none;\r\n}\r\n\r\n/* \"Upgrade your plan\" dialog, \"Share link to chat\" dialog chat min duplicate */\r\n[class*='dark:border-gray-700'] {\r\n\tborder-color: transparent !important;\r\n\t// border-color: red !important;\r\n}\r\n\r\n/* Border in dialogs after main heading - DARK */\r\nhtml.dark [class*=':border-white/10'] {\r\n\tborder-color: var(--c-border-accent) !important;\r\n}\r\n\r\n/* Border in dialogs after main heading - LIGHT */\r\nhtml.light [class*=':border-white/10'] {\r\n\tborder-color: var(--c-border) !important;\r\n}\r\n\r\n/* \"This content may violate content policy...\" warning */\r\n[class*='border-red-500'] {\r\n\tborder-color: var(--c-danger) !important;\r\n}\r\n","// [class*='rounded-xl'] {\r\n// \tborder-radius: var(--br-btn-big) !important;\r\n// \tborder: 1px solid red !important;\r\n// }\r\n// [class*='rounded-lg'] {\r\n// \tborder-radius: var(--br-btn) !important;\r\n// \tborder: 1px solid green !important;\r\n// }\r\n// [class*='rounded-md'] {\r\n// \tborder-radius: var(--br-btn) !important;\r\n// \tborder: 1px solid yellow !important;\r\n// }\r\n/* \r\n- Scroll down btn.\r\n- GPTs - product card circle pictures\r\n- General profile pic: \"NEWCHAT\", \"Upgrade Plan\", user profile in sidebar.\r\n- Check switch btn\r\n- Close sidebar btn */\r\n.rounded-full {\r\n\t// @include borderBoxShadow(rgb(2, 0, 139));\r\n}\r\n\r\n/* \r\n- GPTs - pill tags in sticky header */\r\n.rounded-3xl {\r\n\t// border-radius: var(--br-btn-big) !important;\r\n\t// @include borderBoxShadow(purple);\r\n}\r\n/* \r\n- Dialogs\r\n- ChatGPT 3.5 btn in sticky header\r\n- GPTs - Search input\r\n- GPTs - product cards\r\n- NEW CHAT big buttons\r\n- NEW CHAT big btns on hover svg wrapper etc\r\n- Custom Instructions > \"bubble\" on right side when textarea focused */\r\n.rounded-xl {\r\n\tborder-radius: var(--br-btn-big) !important;\r\n\t// @include borderBoxShadow(red);\r\n}\r\n\r\n/* \r\n- All sidebar <a> buttons/links\r\n- Theme btn,\r\n- SVGs: Share Link, Send btn in pompt-textarea,  \r\n- GPTs - sticky btns \"Global view\" and \"My GPTs\"\r\n- GPTs - search query section product cards/items \r\n- Toast root notify\r\n-  */\r\n.rounded-lg {\r\n\tborder-radius: var(--br-btn) !important;\r\n\t// @include borderBoxShadow(orange);\r\n}\r\n\r\n/*\r\n- Small btns in chat footer.\r\n- <pre>\r\n- Tab btns in dialog.\r\n- contextmenu-items in \"Theme\" ddl\r\n- \"Was this response better or worse? 👍👎\" el when clicked on regenerate answer btn and its inner buttons */\r\n.rounded-md {\r\n\tborder-radius: var(--br-btn) !important;\r\n\t// @include borderBoxShadow(yellow);\r\n}\r\n\r\n/*\r\n- Textarea in dialog.\r\n- menuitems in ChatGPT 3.5 contextmenu and contextmenu in 3dots in sidebar  (\"Share\", \"Rename\", \"Delete\") */\r\n.rounded {\r\n\tborder-radius: var(--br-btn) !important;\r\n\t// @include borderBoxShadow(lightgreen);\r\n}\r\n\r\n.rounded-t-md {\r\n\t// overflow: clip !important;\r\n\tborder-top-left-radius: var(--br-btn) !important;\r\n\tborder-top-right-radius: var(--br-btn) !important;\r\n}\r\n.rounded-b-md {\r\n\t// overflow: clip !important;\r\n\tborder-bottom-left-radius: var(--br-btn) !important;\r\n\tborder-bottom-right-radius: var(--br-btn) !important;\r\n}\r\n","/*!\r\n  Theme: Rosé Pine Moon\r\n  Author: Emilia Dunfelt <sayhi@dunfelt.se>\r\n  License: ~ MIT (or more permissive) [via base16-schemes-source]\r\n  Maintainer: @highlightjs/core-team\r\n  Version: 2021.09.0\r\n*/\r\n\r\n/*\r\n  WARNING: DO NOT EDIT THIS FILE DIRECTLY.\r\n\r\n  This theme file was auto-generated from the Base16 scheme ros-pine-moon\r\n  by the Highlight.js Base16 template builder.\r\n\r\n  - https://github.com/highlightjs/base16-highlightjs\r\n*/\r\n\r\n/*\r\nbase00  #232136  Default Background\r\nbase01  #2a273f  Lighter Background (Used for status bars, line number and folding marks)\r\nbase02  #393552  Selection Background\r\nbase03  #59546d  Comments, Invisibles, Line Highlighting\r\nbase04  #817c9c  Dark Foreground (Used for status bars)\r\nbase05  #e0def4  Default Foreground, Caret, Delimiters, Operators\r\nbase06  #f5f5f7  Light Foreground (Not often used)\r\nbase07  #d9d7e1  Light Background (Not often used)\r\nbase08  #ecebf0  Variables, XML Tags, Markup Link Text, Markup Lists, Diff Deleted\r\nbase09  #eb6f92  Integers, Boolean, Constants, XML Attributes, Markup Link Url\r\nbase0A  #f6c177  Classes, Markup Bold, Search Text Background\r\nbase0B  #ea9a97  Strings, Inherited Class, Markup Code, Diff Inserted\r\nbase0C  #3e8fb0  Support, Regular Expressions, Escape Characters, Markup Quotes\r\nbase0D  #9ccfd8  Functions, Methods, Attribute IDs, Headings\r\nbase0E  #c4a7e7  Keywords, Storage, Selector, Markup Italic, Diff Changed\r\nbase0F  #b9b9bc  Deprecated, Opening/Closing Embedded Language Tags, e.g. <?php ?>\r\n*/\r\npre {\r\n\t--c-bg-pre: #232136;\r\n}\r\npre code.hljs {\r\n\tdisplay: block;\r\n\toverflow-x: auto;\r\n\tpadding: 1em;\r\n}\r\n\r\ncode.hljs {\r\n\tpadding: 3px 5px;\r\n}\r\n\r\n.hljs,\r\n/* markdown pre */\r\npre .bg-token-main-surface-secondary,\r\n/* markdown header - lang name and copy btn */\r\npre .bg-token-main-surface-secondary>div:has(> span) {\r\n\tcolor: #e0def4 !important;\r\n\tbackground: var(--c-bg-pre) !important;\r\n}\r\n\r\n.hljs::selection,\r\n.hljs ::selection {\r\n\tbackground-color: #393552 !important;\r\n\tcolor: #e0def4 !important;\r\n}\r\n\r\n/* purposely do not highlight these things */\r\n.hljs-formula,\r\n.hljs-params,\r\n.hljs-property {\r\n}\r\n\r\n/* base03 - #59546d -  Comments, Invisibles, Line Highlighting */\r\n.hljs-comment {\r\n\tcolor: #59546d !important;\r\n}\r\n\r\n/* base04 - #817c9c -  Dark Foreground (Used for status bars) */\r\n.hljs-tag {\r\n\tcolor: #817c9c !important;\r\n}\r\n\r\n/* base05 - #e0def4 -  Default Foreground, Caret, Delimiters, Operators */\r\n.hljs-subst,\r\n.hljs-punctuation,\r\n.hljs-operator {\r\n\tcolor: #e0def4 !important;\r\n}\r\n\r\n.hljs-operator {\r\n\topacity: 0.7;\r\n}\r\n\r\n/* base08 - Variables, XML Tags, Markup Link Text, Markup Lists, Diff Deleted */\r\n.hljs-bullet,\r\n.hljs-variable,\r\n.hljs-template-variable,\r\n.hljs-selector-tag,\r\n.hljs-name,\r\n.hljs-deletion {\r\n\tcolor: #ecebf0 !important;\r\n}\r\n\r\n/* base09 - Integers, Boolean, Constants, XML Attributes, Markup Link Url */\r\n.hljs-symbol,\r\n.hljs-number,\r\n.hljs-link,\r\n.hljs-attr,\r\n.hljs-variable.constant_,\r\n.hljs-literal {\r\n\tcolor: #eb6f92 !important;\r\n}\r\n\r\n/* base0A - Classes, Markup Bold, Search Text Background */\r\n.hljs-title,\r\n.hljs-class .hljs-title,\r\n.hljs-title.class_ {\r\n\tcolor: #f6c177 !important;\r\n}\r\n\r\n.hljs-strong {\r\n\tfont-weight: bold;\r\n\tcolor: #f6c177 !important;\r\n}\r\n\r\n/* base0B - Strings, Inherited Class, Markup Code, Diff Inserted */\r\n.hljs-code,\r\n.hljs-addition,\r\n.hljs-title.class_.inherited__,\r\n.hljs-string {\r\n\tcolor: #ea9a97 !important;\r\n}\r\n\r\n/* base0C - Support, Regular Expressions, Escape Characters, Markup Quotes */\r\n.hljs-built_in,\r\n.hljs-doctag,\r\n/* guessing */\r\n.hljs-quote,\r\n.hljs-keyword.hljs-atrule,\r\n.hljs-regexp {\r\n\tcolor: #3e8fb0 !important;\r\n}\r\n\r\n/* base0D - Functions, Methods, Attribute IDs, Headings */\r\n.hljs-function .hljs-title,\r\n.hljs-attribute,\r\n.ruby .hljs-property,\r\n.hljs-title.function_,\r\n.hljs-section {\r\n\tcolor: #9ccfd8 !important;\r\n}\r\n\r\n/* base0E - Keywords, Storage, Selector, Markup Italic, Diff Changed */\r\n.hljs-type,\r\n/* .hljs-selector-id, */\r\n/* .hljs-selector-class, */\r\n/* .hljs-selector-attr, */\r\n/* .hljs-selector-pseudo, */\r\n.hljs-template-tag,\r\n.diff .hljs-meta,\r\n.hljs-keyword {\r\n\tcolor: #c4a7e7 !important;\r\n}\r\n\r\n.hljs-emphasis {\r\n\tcolor: #c4a7e7 !important;\r\n\tfont-style: italic;\r\n}\r\n\r\n/* base0F - Deprecated, Opening/Closing Embedded Language Tags, e.g. <?php ?> */\r\n.hljs-meta,\r\n/*\r\n    prevent top level .keyword and .string scopes\r\n    from leaking into meta by accident\r\n  */\r\n.hljs-meta .hljs-keyword,\r\n.hljs-meta .hljs-string {\r\n\tcolor: #b9b9bc !important;\r\n}\r\n\r\n.hljs-meta .hljs-keyword,\r\n/* for v10 compatible themes */\r\n.hljs-meta-keyword {\r\n\tfont-weight: bold;\r\n}\r\n","/*\r\n  IR_Black style (c) Vasily Mikhailitchenko <vaskas@programica.ru>\r\n*/\r\nhtml.dark[data-gptheme='oled'] {\r\n\t.hljs {\r\n\t\tbackground: var(--c-bg-pre) !important;\r\n\t\tcolor: #f8f8f8 !important;\r\n\t}\r\n\r\n\t.hljs-comment,\r\n\t.hljs-quote,\r\n\t.hljs-meta {\r\n\t\tcolor: #7c7c7c !important;\r\n\t}\r\n\r\n\t.hljs-keyword,\r\n\t.hljs-selector-tag,\r\n\t.hljs-tag,\r\n\t.hljs-name {\r\n\t\tcolor: #96cbfe !important;\r\n\t}\r\n\r\n\t.hljs-attribute,\r\n\t.hljs-selector-id {\r\n\t\tcolor: #ffffb6 !important;\r\n\t}\r\n\r\n\t.hljs-string,\r\n\t.hljs-selector-attr,\r\n\t.hljs-selector-pseudo,\r\n\t.hljs-addition {\r\n\t\tcolor: #a8ff60 !important;\r\n\t}\r\n\r\n\t.hljs-subst {\r\n\t\tcolor: #daefa3 !important;\r\n\t}\r\n\r\n\t.hljs-regexp,\r\n\t.hljs-link {\r\n\t\tcolor: #e9c062 !important;\r\n\t}\r\n\r\n\t.hljs-title,\r\n\t.hljs-section,\r\n\t.hljs-type,\r\n\t.hljs-doctag {\r\n\t\tcolor: #ffffb6 !important;\r\n\t}\r\n\r\n\t.hljs-symbol,\r\n\t.hljs-bullet,\r\n\t.hljs-variable,\r\n\t.hljs-template-variable,\r\n\t.hljs-literal {\r\n\t\tcolor: #c6c5fe !important;\r\n\t}\r\n\r\n\t.hljs-number,\r\n\t.hljs-deletion {\r\n\t\tcolor: #ff73fd !important;\r\n\t}\r\n\r\n\t.hljs-emphasis {\r\n\t\tfont-style: italic;\r\n\t}\r\n\r\n\t.hljs-strong {\r\n\t\tfont-weight: bold;\r\n\t}\r\n}\r\n","*,\r\n:after,\r\n:before {\r\n\t--tw-ring-color: hsl(\r\n\t\tvar(--accent-h),\r\n\t\tcalc(var(--accent-s) / 1.5),\r\n\t\tvar(--accent-l)\r\n\t) !important; // out border (box-shadow) on dialog btns color\r\n\t--tw-ring-offset-color: var(--c-bg-dialog) !important; // inner border on dialog btns color\r\n}\r\n\r\n/*\r\n    buttons, switch btns, svg buttons, input, menuitem (no btns in dialog tho, it is special style w/ --tw-ring-color and --tw-ring-offset-color vars) border/outline on keyboard focus or :focus-visible\r\n*/\r\n// :is(button, a, [role=\"menuitem\"]:not([class*=\"text-red-\"]), [role=\"dialog\"] textarea):not(.btn-primary, .btn-neutral, textarea#prompt-textarea) {\r\n//     &:focus-visible {\r\n//         outline: 2.5px solid hsl(var(--accent-h), calc(var(--accent-s) / 1.5), var(--accent-l));\r\n//     }\r\n// }\r\n\r\n/* \r\nTheme dropdown deo ima zeleni border za :focus-visible.\r\n  - [aria-label=\"Delete shared link\"] is recycle svg icon in \"Shared link\" table\r\n  - .btn-neutral:not([role=\"combobox\"] is in theme dropdown \"Dark/Light/System\" button\") \r\n*/\r\n:focus-visible:not(\r\n\t\t.btn-primary,\r\n\t\t.btn-danger,\r\n\t\t.btn-neutral:not([role='combobox'], .bg-token-surface-tertiary input),\r\n\t\ttextarea,\r\n\t\tinput,\r\n\t\t[aria-label='Delete shared link'],\r\n\t\t[class*='text-red-']\r\n\t) {\r\n\toutline: 2.5px solid hsl(var(--accent-h), calc(var(--accent-s) / 1.5), var(--accent-l));\r\n}\r\n\r\n:focus-visible:is(.btn-neutral[role='combobox']) {\r\n\tborder: none !important;\r\n}\r\n\r\n/* 🗑️ Recycle icon in \"Shared link\" table */\r\n:focus-visible:is([aria-label='Delete shared link'], [class*='text-red-']) {\r\n\t--tw-ring-color: var(--c-danger) !important;\r\n\t// --tw-ring-color: var(--c-danger) !important;\r\n\toutline: 2.5px solid var(--c-danger) !important;\r\n}\r\n\r\n.btn-danger {\r\n\t--tw-ring-color: var(--c-danger) !important;\r\n\t// outline: 2.5px solid var(--c-danger) !important;\r\n\r\n\t// &:focus {\r\n\t//     outline-color: var(--c-bg-dialog) !important;\r\n\t// }\r\n}\r\n\r\ninput {\r\n}\r\n","[role=\"separator\"] {\r\n    border-color: var(--c-border) !important;\r\n}","input[type='checkbox'] {\r\n\tpadding: 7px !important;\r\n\tborder: 2px solid var(--c-accent) !important;\r\n\tbackground-color: transparent !important;\r\n\tborder-radius: 4px;\r\n\r\n\t&:checked {\r\n\t\taccent-color: var(--c-accent) !important;\r\n\t\tbackground-color: var(--c-accent) !important;\r\n\t}\r\n}\r\n\r\n/* \"Select your Team Plan\" dialog radio buttons when clicking \"Upgrade plan\" > \"Team\" */\r\nbutton[role='radio'] {\r\n\tborder-color: var(--c-accent) !important;\r\n\r\n\t&[data-state='checked'] {\r\n\t\tbackground-color: var(--c-accent);\r\n\t}\r\n\r\n\tsvg {\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t}\r\n}\r\n","[role='menu'] {\r\n\tbackground-color: var(--c-bg-contextmenu) !important;\r\n\tborder-radius: var(--br-contextmenu) !important;\r\n\t// border: none !important;\r\n\tpadding: var(--p-contextmenu) !important;\r\n\t// border: 1px solid hsla(var(--accent-hsl) / 0.2) !important;\r\n\tbox-shadow: var(--box-shadow-contextmenu) !important;\r\n\t// transition: all 0.3s ease-in-out;\r\n\r\n\t&:not(nav[aria-label='Chat history'] .group[data-headlessui-state] [role='menu']) {\r\n\t\t@extend %animFadeInClipPath;\r\n\t}\r\n\r\n\t[role='menuitem'] {\r\n\t\tbackground-color: inherit !important;\r\n\t\tpadding: var(--p-contextmenu-item) !important;\r\n\t\tborder-radius: var(--br-btn) !important;\r\n\t\ttransition: background-color 0.3s ease-in-out, color 0.3s ease-in-out;\r\n\r\n\t\t/* TODO dark:hover:bg-white/5   ima vec u globalu. Videti da li obrisati ovah hover i ostaviti onaj tamo samo. Rizicno je malo, sta ako se promeni ta klasa */\r\n\t\t&:hover {\r\n\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Remove padding for menu in sidebar bottom */\r\n\tnav {\r\n\t\tpadding: 0 !important;\r\n\t}\r\n\r\n\t&:has(a[href=\"https://openai.com/policies\"])\r\n\t{\r\n\t\ta:first-child span {\r\n\t\t\tcolor: var(--c-accent) !important;\r\n\t\t\tfont-weight: bold;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n// TODO check if this broke something else because it is the element hard for targeting\r\n/* \"New Chat\" xs in contextmenu in ChatGPT 3.5 */\r\n[data-radix-popper-content-wrapper] .absolute.right-11 {\r\n\t--svg-w: 24px;\r\n\t--gap-from-svg: 20px;\r\n\tright: calc(\r\n\t\tvar(--p-contextmenu) + var(--svg-w) + var(--gap-from-svg)\r\n\t) !important; // p-contextmenu = 10px, svg-w = 24px, gap-from-svg = 20px = (10px + 24px + 20px) = 54px. This is calculated spacing of \"New Chat\" in contextmenu in ChatGPT 3.5 and right edge in contextmenuitem\r\n}\r\n\r\n/* __ MODAL - Choose theme context menu & tooltips?  */\r\ndiv[data-radix-popper-content-wrapper] {\r\n\tz-index: calc(var(--z-modal) + 50) !important;\r\n\t// z-index: 200 !important;\r\n\r\n\t/* \"Custom Instructions\" dialog */\r\n\t&:has([role='dialog']) {\r\n\t\t/* \"Custom Instructions\" dialog context menu visible on textarea focus */\r\n\t\t[role='dialog'] {\r\n\t\t\t--box-shadow: var(--box-shadow-contextmenu) !important;\r\n\t\t\t// box-shadow: var(--box-shadow-contextmenu) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Mora not role=menu da ne bih selektovala i onaj contextmenu u sidebar kad se klikne na prompt listitem 3 dots za opcije i div[data-radix-popper-content-wrapper]:has([role='tooltip']) da ne bih selektovala tooltip */\r\n\t&:not(\r\n\t\t\tdiv[data-radix-popper-content-wrapper]:has(div[role='menu']),\r\n\t\t\tdiv[data-radix-popper-content-wrapper]:has([role='tooltip'])\r\n\t\t) {\r\n\t\t@extend %animFadeInClipPath;\r\n\t}\r\n\r\n\t/* Context menu bg */\r\n\t// .bg-white {\r\n\t// .bg-token-popover-surface-primary\r\n\t[role='listbox'] {\r\n\t\t// background-color: var(--c-bg-contextmenu) !important;\r\n\t\tpadding: var(--p-contextmenu) !important;\r\n\t\tborder-radius: var(--br-contextmenu) !important;\r\n\t\tbox-shadow: var(--box-shadow-contextmenu) !important;\r\n\t\toverflow: visible !important; // for what is this? hhh\r\n\t\tborder: none;\r\n\t}\r\n\r\n\t[data-radix-collection-item] {\r\n\t\tborder-radius: var(--br-btn);\r\n\t\tpadding: var(--p-contextmenu-item) !important;\r\n\t\theight: auto !important;\r\n\t\tmargin-bottom: 4px;\r\n\t\toverflow: visible !important;\r\n\t\toutline: none !important;\r\n\t}\r\n\r\n\t/* MODAL - Choose theme context menuitem hover */\r\n\t[data-radix-collection-item][data-state='unchecked'] {\r\n\t\t&:hover {\r\n\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t\toutline: none !important; // TODO this is temp fix. This ecause there were somewhite uglu outline on hover. But this also breaks :focus-visible accessibility style...\r\n\t\t}\r\n\t}\r\n\r\n\t/* MODAL - Choose theme context menuitem hover active */\r\n\t[data-state='checked'] {\r\n\t\tbackground-color: var(--c-bg-btn) !important;\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t}\r\n}\r\n\r\n// .data-radix-popper-content-wrapper {\r\n// \t// z-index: calc(var(--z-modal) + 200) !important;\r\n// \tz-index: 200 !important;\r\n// }\r\n","/* Sidebar bg-color */\r\n.bg-token-sidebar-surface-primary:has(nav[aria-label='Chat history']) {\r\n\t/* --surface-primary fix dark/black color for a:hover states */\r\n\t// --surface-primary: var(--c-surface-2) !important;\r\n\t// --surface-primary: red !important;\r\n\tcolor: var(--c-txt) !important;\r\n\t// background-color: var(--c-bg-sidebar) !important;\r\n\r\n\t/* Fix white txt on \"NEW CHAT\" in sidebar for light especially */\r\n\tnav a > * {\r\n\t\tcolor: var(--c-txt) !important;\r\n\t}\r\n}\r\n\r\nnav[aria-label='Chat history'] {\r\n\tpadding: var(--p-sidebar-nav) !important;\r\n\r\n\t// ! Strange black rectangle (.bg-black class) over \"New Chat\" btn when on links: https://chat.openai.com/gpts/discovery and https://chat.openai.com/g/g-UBYTKWkPj\r\n\t/* .sticky.bg-black:has(a[href='/']) {\r\n\t\tbackground-color: var(--c-bg-sidebar);\r\n\t\tpadding-bottom: 1rem !important;\r\n\t} */\r\n\r\n\t/* Parent of \"NEW CHAT\" btn */\r\n\t.sticky {\r\n\t\tbackground-color: var(--c-bg-sidebar) !important;\r\n\t\tbackdrop-filter: blur(0px) !important;\r\n\t\tmargin-bottom: 0.5rem !important;\r\n\t\tpadding-bottom: 0.5rem;\r\n\t}\r\n\r\n\t/* CLEAR CHATS div - Visible when unchecked \"Chat learning & Training\" in Settings */\r\n\t.absolute.left-0.top-0.overflow-hidden {\r\n\t\tbackground-color: var(--c-bg-sidebar) !important;\r\n\t\toverflow-y: scroll;\r\n\r\n\t\tmin-height: 50vh !important;\r\n\r\n\t\t.bg-gradient-to-t {\r\n\t\t\topacity: 0;\r\n\t\t}\r\n\t}\r\n\r\n\t/* NEW CHAT + LIST of chats in nav. Adding padding-left prevent :focus-visible style in those elements to be cropped from the left because of the overflow-hidden */\r\n\t.overflow-y-auto {\r\n\t\tpadding-left: 0.3rem !important;\r\n\r\n\t\t/* Your Firefox-specific styles here */\r\n\t\t@-moz-document url-prefix() {\r\n\t\t\tpadding-right: 0.8rem !important; // this add only for Firefox\r\n\t\t}\r\n\t}\r\n\r\n\t/*\r\n\tParent of time heading (of Today, Yesterday) in sidebar.\r\n\t! div:has(> h3)  is selector for the same but in GPTs page !!! */\r\n\t[data-projection-id]:has(h3),\r\n\tdiv:has(> h3) {\r\n\t\tmargin-top: 1.5rem !important;\r\n\t\tmargin-bottom: 0.3rem !important;\r\n\r\n\t\t/* Today, Yesterday - Time heading in sidebar */\r\n\t\th3 {\r\n\t\t\tdisplay: inline-block !important;\r\n\t\t\tcolor: var(--c-accent) !important;\r\n\t\t\tbackground-color: hsl(var(--accent-hsl) / 0.2) !important;\r\n\t\t\tborder-radius: 100vw;\r\n\t\t\ttext-transform: uppercase;\r\n\t\t\tfont-weight: bold;\r\n\t\t\tpadding: 0.5rem 1rem !important;\r\n\t\t\theight: auto !important;\r\n\t\t\tline-height: 1 !important;\r\n\t\t}\r\n\t}\r\n\r\n\ta {\r\n\t\tcolor: var(--c-txt) !important;\r\n\t\tpadding: var(--p-sidebar-nav-a) !important;\r\n\t\tfont-family: var(--f-fm) !important;\r\n\t\tborder-radius: var(--br-nav-a) !important;\r\n\t\t// border-radius: inherit !important;\r\n\r\n\t\ttransition: background-color 0.3s ease-in-out;\r\n\r\n\t\t/* \"New Chat\" link (first in nav in sidebar) */\r\n\t\t&[href='/'] {\r\n\t\t\tborder: 2px solid var(--c-surface-2);\r\n\t\t\tpadding: var(--p-sidebar-nav-a-new-chat) !important;\r\n\t\t\ttext-transform: uppercase;\r\n\t\t}\r\n\r\n\t\t/* \"Upgrade\" link in nav bg */\r\n\t\tspan.rounded-full.border-token-border-light {\r\n\t\t\tborder-color: transparent !important;\r\n\t\t\tbackground-color: var(--c-accent) !important;\r\n\r\n\t\t\t/* SVG icon in \"Upgrade\" link in nav */\r\n\t\t\t& > svg {\r\n\t\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tli {\r\n\t\tmargin-bottom: var(--mb-sidebar-nav-li) !important;\r\n\r\n\t\t.group {\r\n\t\t\t--duration-trans: 0.3s;\r\n\t\t\t--duration-anim: 0.2s;\r\n\t\t\toverflow: hidden;\r\n\r\n\t\t\t&.bg-token-sidebar-surface-secondary,\r\n\t\t\t&.bg-token-sidebar-surface-primary {\r\n\t\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t\t}\r\n\r\n\t\t\t/* TODO mozda dodati opet u buducnosti. Sad nema poente, jer text parent ima overflow hidden i isece citav text, a ova animacija ga svakako opet samo prikaze onoliki koliki je. Ako stavim overlow: visible na hover, animacija je razlicito primenjena na svaki element, posto je width za svaki eelement razlicit u zavisnosti od duzine texta, i animacija ne moze sa istim durationom da bude ista, a sadrzaj treba mnogo vise da se skroluje. A ne zelim jos da koristim javascript za fetchvanje width-a svakog elementa posebno i onda posebni duration za svaki element u zavisnosti od duzine texta. A i preopteretila bi se extenzija da lupujem kroz svaki element, citam podatke i dodajem animaciju, samo zarad tog efekta. Nije vredno */\r\n\t\t\t// &:hover {\r\n\t\t\t// \t/* Anim long (all actually) txt to scroll left to be shown whole */\r\n\t\t\t// \ta[href^='/c/'] > div.relative.grow.overflow-hidden.whitespace-nowrap {\r\n\t\t\t// \t\tanimation: animScrollText 3s $easeInOutSine backwards;\r\n\t\t\t// \t}\r\n\t\t\t// }\r\n\r\n\t\t\t/* 3dots btn */\r\n\t\t\tbutton {\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t}\r\n\r\n\t\t\t/* Archive btn */\r\n\t\t\tspan {\r\n\t\t\t\tbutton {\r\n\t\t\t\t\tcolor: var(--c-subtext-1) !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t/* Active-link 3-dots and archive btns wrapper */\r\n\t\t\t& > div.absolute {\r\n\t\t\t\t@extend %sidebar_link_item_btns_bg;\r\n\t\t\t}\r\n\r\n\t\t\ta[href^='/c/'] {\r\n\t\t\t\t/* & > div.relative.grow.overflow-hidden.whitespace-nowrap {\r\n\t\t\t\t\twill-change: transform;\r\n\t\t\t\t} */\r\n\t\t\t\t/* ! NOW `.bg-token-surface-primary` IS DELETED BY OPENAI ffs*/\r\n\t\t\t\t/* Selected/active/hover link item */\r\n\t\t\t\t// &.bg-token-surface-primary {\r\n\t\t\t\t//     background-color: var(--c-surface-2) !important;\r\n\r\n\t\t\t\t//     /* 3 dots btn bg-gradient */\r\n\t\t\t\t//     .bg-gradient-to-l {\r\n\t\t\t\t//         opacity: 1 !important;\r\n\t\t\t\t//     }\r\n\t\t\t\t// }\r\n\r\n\t\t\t\t/* 3 dots btn bg-gradient - <div> u <a> i <div> u <button> */\r\n\t\t\t\t.bg-gradient-to-l {\r\n\t\t\t\t\tdisplay: none !important;\r\n\t\t\t\t\t// border: 2px solid red !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t/* 3 dots > \"Rename\" clicked - style of input parent and input  - this is <div> next to <a> */\r\n\t\t\t.bg-token-surface-tertiary {\r\n\t\t\t\tpadding: var(--p-sidebar-nav-a) !important;\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t\tbackground-color: var(\r\n\t\t\t\t\t--c-surface-3\r\n\t\t\t\t) !important; // NOTE: bg can't be transparent-ish; it cause txt behind to be visible\r\n\t\t\t\tborder: 1px solid var(--c-border) !important;\r\n\t\t\t\tborder-radius: var(--br-nav-a) !important;\r\n\r\n\t\t\t\t/* This make it full width of <li>, from left to right */\r\n\t\t\t\tleft: 0 !important;\r\n\t\t\t\tright: 0 !important;\r\n\r\n\t\t\t\t/* Rename input.\r\n                    ! DO NOT TOUCH PADDING! TXT BEHIND GOIN TO BE VISIBLE. WTF??? \r\n                */\r\n\t\t\t\tinput {\r\n\t\t\t\t\t// input rename border color on focused\r\n\t\t\t\t\t--tw-ring-color: transparent !important;\r\n\t\t\t\t\tcaret-color: var(--c-accent);\r\n\t\t\t\t\tborder: none !important;\r\n\t\t\t\t\toutline: none !important;\r\n\t\t\t\t\tbox-shadow: none !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// TODO add better styling to this btn\r\n\t/* User profile btn in sidebar bottom */\r\n\t.group[data-headlessui-state] {\r\n\t\t/* User profile btn in sidebar bottom */\r\n\t\tbutton[aria-haspopup='true'] {\r\n\t\t\tborder-radius: var(--br-nav-a);\r\n\t\t\tmargin-top: 1rem;\r\n\r\n\t\t\t/* Username div */\r\n\t\t\t.font-semibold {\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/* Sidebar bottom - Log Out  */\r\n\t\t[role='menu'] {\r\n\t\t\tanimation: none !important;\r\n\t\t\t// transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;\r\n\t\t\ttransition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;\r\n\r\n\t\t\t[role='menuitem']:last-child {\r\n\t\t\t\tcolor: var(--c-danger) !important;\r\n\r\n\t\t\t\tsvg {\r\n\t\t\t\t\tcolor: var(--c-danger) !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/*  Border-radius for all elements that have .rounded-lg class in <nav> of sidebar. ALi on zezne border-radiusu i contextmenu u bottom sidebar jer i on ima ovu klasu. Zato sad dodajem <li> */\r\n\t// TODO mozda mogu obrisati, ako global ostane ista ova\r\n\t.rounded-lg {\r\n\t\tborder-radius: var(--br-nav-a) !important;\r\n\t}\r\n}\r\n",".prose {\r\n\t// --tw-prose-code: currentColor !important; // Code text in markdown\r\n\t// --tw-prose-bold: currentColor !important; // Bold text in markdown\r\n\tcolor: var(--c-txt) !important;\r\n\tfont-size: 1rem !important;\r\n\r\n\t--tw-prose-body: var(--c-txt) !important;\r\n\t--tw-prose-headings: var(--c-accent) !important;\r\n\t// --tw-prose-lead: red !important;\r\n\t--tw-prose-links: var(--c-accent) !important;\r\n\t--tw-prose-bold: currentColor !important;\r\n\t--tw-prose-counters: var(--c-accent) !important;\r\n\t--tw-prose-bullets: var(--c-accent) !important;\r\n\t--tw-prose-hr: var(--c-border) !important;\r\n\t--tw-prose-quotes: var(--c-subtext-2) !important;\r\n\t--tw-prose-quote-borders: var(--c-subtext-2) !important;\r\n\t// --tw-prose-captions: red !important;\r\n\t--tw-prose-code: currentCode !important;\r\n\t// --tw-prose-pre-code: var(--c-accent) !important;\r\n\t--tw-prose-th-borders: var(--c-border) !important;\r\n\t--tw-prose-td-borders: var(--c-border) !important;\r\n\r\n\t/* ___For Dark theme??? */\r\n\t--tw-prose-invert-body: var(--c-txt) !important;\r\n\t--tw-prose-invert-headings: var(--c-accent) !important;\r\n\t// --tw-prose-invert-lead: #9ca3af !important;\r\n\t--tw-prose-invert-links: var(--c-accent) !important;\r\n\t--tw-prose-invert-bold: currentColor !important;\r\n\t--tw-prose-invert-counters: var(--c-accent) !important;\r\n\t--tw-prose-invert-bullets: var(--c-accent) !important;\r\n\t--tw-prose-invert-hr: var(--c-border) !important;\r\n\t--tw-prose-invert-quotes: var(--c-subtext-2) !important;\r\n\t--tw-prose-invert-quote-borders: var(--c-subtext-2) !important;\r\n\t// --tw-prose-invert-captions: #9ca3af !important;\r\n\t--tw-prose-invert-code: currentColor !important;\r\n\t// --tw-prose-invert-pre-code: var(--c-accent) !important;\r\n\t// --tw-prose-invert-pre-bg: red !important;\r\n\t--tw-prose-invert-th-borders: var(--c-border) !important;\r\n\t--tw-prose-invert-td-borders: var(--c-border) !important;\r\n\r\n\t/* Markdown Links rendered in GPT answers */\r\n\ta {\r\n\t\t@extend %link_hover_underlined;\r\n\t}\r\n\r\n\t/* Style Markdown Checkboxes */\r\n\tinput[type='checkbox'] {\r\n\t\tpadding: 7px !important;\r\n\t\tborder: 2px solid var(--c-accent) !important;\r\n\t\tbackground-color: transparent !important;\r\n\t\tborder-radius: 4px;\r\n\r\n\t\t&:checked {\r\n\t\t\taccent-color: var(--c-accent) !important;\r\n\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t}\r\n\t}\r\n\r\n\ttable {\r\n\t\t/* TODO - this overflow cause cutting the border edges of latest <tr> child, wtf. So I have to add border to <table> also (down where <th>, <td> are) */\r\n\t\toverflow: hidden;\r\n\t\tborder-radius: var(--br-btn) !important;\r\n\r\n\t\tthead {\r\n\t\t\t--tw-prose-headings: var(--c-txt) !important;\r\n\r\n\t\t\tborder-collapse: collapse !important;\r\n\t\t\tborder-spacing: 0 !important;\r\n\t\t\tbackground-color: hsla(var(--txt-hsl) / 0.15) !important;\r\n\t\t\t// background-color: hsla(var(--accent-hsl) / .15) !important;\r\n\t\t\ttext-transform: uppercase;\r\n\t\t\tfont-size: 0.8rem !important;\r\n\t\t}\r\n\r\n\t\t&,\r\n\t\tth,\r\n\t\ttd {\r\n\t\t\tborder: 1px solid var(--c-border) !important;\r\n\t\t}\r\n\r\n\t\tth,\r\n\t\ttd {\r\n\t\t\tpadding: 0.5rem !important;\r\n\t\t}\r\n\r\n\t\t/* Make odd rows darker */\r\n\t\ttbody tr:nth-child(2n) {\r\n\t\t\tbackground-color: hsla(var(--txt-hsl) / 0.03) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* Thead color for Dark theme */\r\nhtml.dark .prose {\r\n\ttable thead {\r\n\t\t--tw-prose-headings: var(--c-on-accent) !important;\r\n\t\tbackground-color: hsla(var(--accent-hsl) / 0.7) !important;\r\n\t\t// background-color: var(--c-accent-light) !important;\r\n\t}\r\n}\r\n\r\n/* Code-snippets markdown and markdown header */\r\nhtml.dark[data-gptheme='oled'] {\r\n\t.prose {\r\n\t\t.bg-black {\r\n\t\t\tbackground-color: #000 !important;\r\n\r\n\t\t\t/* Markdown code-snippets (prose) header */\r\n\t\t\t.bg-token-surface-primary {\r\n\t\t\t\tbackground-color: #000 !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n","/* === RIGHT - <pre> - MARKDOWN CODE IN CHATS ===*/\r\n\r\npre {\r\n\tborder-radius: var(--br-pre) !important;\r\n\tmargin: var(--my-pre) auto !important;\r\n\r\n\t--c-bg-pre: #232136;\r\n\t--main-surface-secondary: var(--c-bg-pre) !important;\r\n\r\n\t.bg-gray-950 {\r\n\t\tbackground-color: var(--c-bg-pre) !important;\r\n\t}\r\n\r\n\t// overflow: clip !important;\r\n\r\n\t/*  === RIGHT - <pre> - header === */\r\n\t/*``` Header selector: .bg-black>div:has(> span) */\r\n\r\n\t/* // TODO\r\n\t\tThere seems to be an unusual behavior with the top-border-radius for the Markdown header, causing it to lose its radius and appear almost sharp (aka the original design). This occurs when the inspect element is open or when the screen size is reduced. It happens like a flash when hovering over the chat-bubble and then moving out of it completely or when in the inspect mode, also hovering COPY btn, idk. I cannot fully comprehend the issue, but it seems that the original design is being restored, despite my attempts to override it using various methods:\r\n\r\n\t\tI have rewritten the .rounded-md class and also the .rounded-t-md class for the header. I applied overflow: clip/hidden to <pre> and the Markdown header. However, none of these measures seem to resolve the issue.\r\n\r\n\t\t// ! UPDATE\r\n\t\tIt seems it works fine now.\r\n\t*/\r\n\t/* Markdown */\r\n\t/* Code name in markdown header (html, php, css, etc) */\r\n\tdiv:has(button) span {\r\n\t\tcolor: var(--c-accent-light) !important;\r\n\t}\r\n\r\n\t/* 'Copy code' btn in markdown header */\r\n\tbutton:has(svg) {\r\n\t\ttext-transform: uppercase !important;\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t\tbackground-color: var(--c-bg-pre-header-btn);\r\n\t\tpadding: var(--p-btn);\r\n\t\tborder-radius: var(--br-btn) !important;\r\n\r\n\t\t/* SVG icons before 'Copy code' btn in md */\r\n\t\tsvg {\r\n\t\t\tcolor: currentColor !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\nhtml.dark[data-gptheme='oled'] {\r\n\tpre {\r\n\t\t--c-bg-pre: #000;\r\n\t}\r\n}\r\n",".btn {\r\n\tbackground-color: var(--c-bg-btn) !important;\r\n\tcolor: var(--c-btn) !important;\r\n\tborder-radius: var(--br-btn) !important;\r\n\tborder: none !important;\r\n\r\n\t&:not(.btn-small) {\r\n\t\t// padding: 1.5rem !important;\r\n\t\tpadding: var(--p-btn) !important;\r\n\t}\r\n}\r\n\r\n/* .btn-primary {\r\n    background-color: var(--c-bg-btn) !important;\r\n} */\r\n\r\n.btn-danger {\r\n\tbackground-color: var(--c-danger) !important;\r\n\tcolor: var(--c-bg-chats-container) !important;\r\n}\r\n\r\n/* === RIGHT - Scroll Down arrow bg LIGHT  === */\r\n// html.light main [role=\"presentation\"] button.absolute.rounded-full {\r\n//     background-color: var(--c-txt) !important;\r\n// }\r\n\r\n/* === RIGHT - Scroll Down arrow bg DARK  === */\r\n// html.dark main [role=\"presentation\"] button.absolute.rounded-full {\r\n//     background-color: var(--c-accent) !important;\r\n// }\r\nmain [role='presentation'] button.absolute.rounded-full {\r\n\tbackground-color: var(--c-accent) !important;\r\n\tbox-shadow: var(--box-shadow-contextmenu);\r\n\r\n\t/* RIGHT - Scroll Down arrow SVG Color === */\r\n\tsvg {\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t}\r\n}\r\n\r\n/* === All the .btn inside dialogs not having svg icon inside */\r\n[role='dialog'] {\r\n\t.btn:not(.btn:has(svg)) {\r\n\t\tmin-width: var(--min-w-btn);\r\n\t}\r\n\r\n\t&:not(.PopoverContent) .btn-neutral {\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\tcolor: var(--c-txt) !important;\r\n\t}\r\n\r\n\t/* \".PopoverContent\" je recimo menu od btn u \"Shared Link to Chat\" 3dots menu (Shared your Name & Delete Link) */\r\n\t&.PopoverContent {\r\n\t\t.btn-neutral {\r\n\t\t\tbackground-color: transparent !important;\r\n\t\t\tcolor: var(--c-txt) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* === Settings > Tabs === */\r\n[role='tablist'] button {\r\n\tpadding: var(--p-btn) !important;\r\n\tbackground-color: transparent !important;\r\n\r\n\t&[data-state='active'],\r\n\t&:hover {\r\n\t\t// TODO Ovo je ok za desktop, ali za manje je bolje surface-1. Takodje dodati horiz gap izmedju\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\t}\r\n}\r\n\r\n/* === Checkbox button - switcher. In \"Chat history & training: and \"Custom instructions\" */\r\nbutton[role='switch'] {\r\n\t/* Checkbox ON */\r\n\t&:has([data-state='checked']) {\r\n\t\tbackground-color: var(--c-accent) !important;\r\n\r\n\t\t/* Chb bullet/circle checked */\r\n\t\tspan {\r\n\t\t\tbackground-color: var(--c-on-accent) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Checkbox OFF */\r\n\t&:has([data-state='unchecked']) {\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\r\n\t\t/* Chb bullet/circle unchecked */\r\n\t\tspan {\r\n\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.5) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* === Settings > Theme selector drop down */\r\nbutton[role='combobox'] {\r\n\t@extend .btn;\r\n\t@extend .btn-neutral;\r\n\tmin-width: var(--min-w-btn);\r\n\r\n\t/* Theme btn - fix height smaller then other btns */\r\n\theight: auto;\r\n\tline-height: inherit;\r\n}\r\n\r\n/* === ❓ circle btn on bottom right */\r\nbutton[id*='headlessui-menu-button'][class*='bg-gray-50'] {\r\n\tcolor: var(--c-txt) !important;\r\n\tborder: none !important;\r\n}\r\n\r\n/* Intro page (before Login or Register) */\r\nbutton[class*='bg-[#3C46FF] text-[#fff]'] {\r\n\t@extend .btn;\r\n}\r\n","/* \"Copied your User ID to clipboard\" parent - toast message when clicking on ? icon bottom right on username */\r\n.toast-root {\r\n\tmargin-top: -0.4rem !important;\r\n\r\n\t/* \r\n\t- \"Copied your User ID to clipboard\" - clicked on 'youremail@example.com' in context menu on ? fixed button in bottom right.\r\n\t- Alert shown on \"ℹ️ Unable to load conversations j10898d8ds8a-dsa689d6as9-s68d7a-j10898d8ds8a\" */\r\n\t[role='alert'] {\r\n\t\tbackground-color: var(--c-accent) !important;\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t\tpadding: var(--p-btn) !important;\r\n\t\tborder-radius: var(--br-btn) !important; // TODO obrisati ovo ako ostavim u globalu .rounded-lg onaj\r\n\t\tborder: none !important;\r\n\t}\r\n}\r\n","/* === TOOLTIPS arrow div bg color === */\r\ndiv[data-radix-popper-content-wrapper]:has([role='tooltip']) {\r\n\t@extend %animFadeIn;\r\n\r\n\t/* Tooltip and triangle bg */\r\n\t// .bg-black not existing anymore, it is .bg-gray-950 now, but I select it via <div> tag\r\n\r\n\tdiv {\r\n\t\tbackground-color: var(--c-bg-tooltip) !important;\r\n\t\tpadding: var(--p-tooltips) !important;\r\n\t\tbox-shadow: var(--box-shadow-contextmenu) !important;\r\n\t}\r\n}\r\n\r\n/* === TOOLTIPS text color === */\r\nhtml.light div[data-radix-popper-content-wrapper]:has([role='tooltip']) {\r\n\t[class*='text-white'] {\r\n\t\tcolor: var(--c-txt) !important;\r\n\t}\r\n}\r\nhtml.dark div[data-radix-popper-content-wrapper]:has([role='tooltip']) {\r\n\t[class*='text-white'] {\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t}\r\n}\r\n",".gizmo-shadow-stroke.h-full:has(svg) {\r\n    color: var(--c-on-accent) !important;\r\n    background-color: var(--c-accent) !important;\r\n}","/* ___  MODAL Background */\r\n.absolute.inset-0 .fixed.inset-0 {\r\n\tbackground-color: var(--c-bg-modal) !important;\r\n\tbackdrop-filter: blur(var(--blur-modal)) !important;\r\n\tz-index: var(--z-modal);\r\n}\r\n","/* ___ DIALOG - Dialog Settings  */\r\n[role='dialog'] {\r\n\tpadding: var(--p-dialog) !important;\r\n\tbackground-color: var(--c-bg-dialog) !important;\r\n\tborder-radius: var(--br-dialog) !important;\r\n\tbox-shadow: var(--box-shadow);\r\n\r\n\t.border-token-border-light,\r\n\t.border-white,\r\n\t.border-black {\r\n\t\tborder-color: transparent !important;\r\n\t}\r\n\r\n\t/* Tab view transitions - In tab dialog part which is changing on tabpanel click (on right side) */\r\n\t[id*='-content-'] {\r\n\t\t--anim-duration: 0.18s;\r\n\t\t@extend %animFadeIn;\r\n\t}\r\n\r\n\t[role='tablist'] {\r\n\t\t/* ___ DIALOG - \"Settings\" on smaller devices then deskop */\r\n\t\t&[data-orientation='horizontal'].bg-gray-100 {\r\n\t\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\t\t// border-radius: var(--br-btn) !important;\r\n\r\n\t\t\t// button[role=\"tab\"][data-state=\"active\"] {\r\n\t\t\tbutton[data-state='active'] {\r\n\t\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/* Add padding y to tabpanel in \"Settings\" (Where \"Theme\",\"Archived chats\", \"Delete All chats\", etc are. Added because Theme dropdown was cutted on hover on smaller devices, because of OpenAI's `overflow-y: auto` */\r\n\t[role='tabpanel'][data-orientation='horizontal'] {\r\n\t\tpadding: 1rem !important;\r\n\t}\r\n\r\n\t/* Heading \"Settings\" in Settings Modal */\r\n\th2[as='h3'] {\r\n\t\ttext-transform: uppercase;\r\n\t}\r\n\r\n\t/* \"Your invite is valid until December X, 2023\" in \"YOU'RE INVITED TO PLUS\" footer */\r\n\t.text-gizmo-gray-500 {\r\n\t\ttext-align: center;\r\n\t\tmargin-top: 1rem;\r\n\t}\r\n\r\n\t.bg-token-surface-primary {\r\n\t\t--surface-primary: transparent !important;\r\n\t}\r\n\r\n\t/* DIALOG - \"Upgrade your plan\" only */\r\n\t&:has(a[href=\"https://openai.com/enterprise\"])\r\n\t{\r\n\t\t--popover-surface-primary: var(--c-bg-dialog) !important; /* Dialog bg */\r\n\t\t--main-surface-primary: transparent !important; /* Strange white bg behind ✔️ items - now is:  .bg-token-main-surface-primary */\r\n\t\t// Change `width: max-content;` to `max-width: max-content;` in `[role=\"dialog\"]:has(a[href=\"https://openai.com/enterprise\"])` because it disables shrinking the content in `Upgrade your plan` popup. But then I have to fix the content\r\n\t\tmax-width: max-content;\r\n\t\tpadding: 0 !important;\r\n\t\tborder: none !important;\r\n\r\n\t\t// .bg-token-popover-surface-primary {\r\n\t\t// \tbackground-color: var(--c-surface-2) !important;\r\n\t\t// }\r\n\t\t/* Strange white bg behind ✔️ items - now is:  .bg-token-main-surface-primary */\r\n\t\t/* .bg-white,\r\n\t\t.bg-gray-900 {\r\n\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t} */\r\n\r\n\t\t/* Border radius for \"Upgrade your plan\" dialog */\r\n\t\t.rounded-md {\r\n\t\t\tborder-radius: var(--br-chat-bubble) !important;\r\n\t\t}\r\n\r\n\t\t/*  Stroke color for ✔️ in \"Upgrade your plan\" dialog list */\r\n\t\tsvg[stroke='currentColor']:has(polyline) {\r\n\t\t\tstroke: var(--c-accent) !important;\r\n\t\t}\r\n\r\n\t\t/* See \"ChatGPT Enterprise\" */\r\n\t\ta[href=\"https://openai.com/enterprise\"]\r\n\t\t{\r\n\t\t\tcolor: var(--c-accent) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t&:has([data-testid^='conversation-turn-']) {\r\n\t\t[class*='dark:bg-gray-800'] {\r\n\t\t\tbackground-color: var(--c-surface-1) !important;\r\n\t\t\t// background-color: lightsalmon !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* DIALOG - textarea (\"Custom instructions\") */\r\n\ttextarea {\r\n\t\tborder-radius: var(--br-contextmenu) !important;\r\n\t\tborder-color: transparent !important;\r\n\t\tbackground-color: var(--c-surface-3) !important; // [class*='dark:bg-gray-800']\r\n\t\topacity: 0.7;\r\n\r\n\t\t/* Textarea feedback when click on like btn in gpt answers */\r\n\t\t&#feedback-other {\r\n\t\t\tpadding: 1.5rem;\r\n\t\t}\r\n\r\n\t\t&:focus {\r\n\t\t\tborder-color: var(--c-surface-3) !important;\r\n\t\t\topacity: 1;\r\n\t\t}\r\n\r\n\t\t&::placeholder {\r\n\t\t\tcolor: var(--c-subtext-1) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t& [class*='dark:bg-gray-700']:has(input[id]) {\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\r\n\t\tinput {\r\n\t\t\tbackground-color: inherit !important;\r\n\t\t}\r\n\t\t// background-color: red !important;\r\n\t}\r\n\r\n\t/* ___ Dialog - \"Share Chat\" White preview <div>  */\r\n\t&:has(main div[data-radix-aspect-ratio-wrapper]) .w-full.rounded-lg {\r\n\t\tborder-radius: var(--br-chat-bubble) !important;\r\n\t\tbox-shadow: var(--box-shadow);\r\n\t\tborder: none !important;\r\n\r\n\t\t/* Mini chat conversation */\r\n\t\t--main-surface-primary: var(--c-surface-1) !important; // mini chat preview background in \"Share Link to Chat\"\r\n\t\t--main-surface-secondary: var(--c-surface-1) !important; // footer of mini chat preview in \"Share Link to Chat\"\r\n\t\t--main-surface-tertiary: transparent !important; // border color of footer of mini chat preview in \"Share Link to Chat\"\r\n\t}\r\n\r\n\t/* ___ DIALOG - \"SHARED LINKS\" or \"ARCHIVED CHATS\" - Table  */\r\n\ttable {\r\n\t\t--main-surface-primary: transparent !important; /* BG of thead>th ---> .bg-token-main-surface-primary */\r\n\t\tpadding: var(--p-contextmenu) !important;\r\n\t\t// border-radius: var(--br-contextmenu);\r\n\r\n\t\tth,\r\n\t\ttd {\r\n\t\t\tpadding-top: var(--py-btn) !important;\r\n\t\t\tpadding-bottom: var(--py-btn) !important;\r\n\t\t}\r\n\r\n\t\tthead {\r\n\t\t\ttr {\r\n\t\t\t\t// border-radius: var(--br-btn) !important;\r\n\t\t\t\t// padding: var(--py-btn) var(--px-btn) !important;\r\n\t\t\t}\r\n\r\n\t\t\tth {\r\n\t\t\t\ttext-transform: uppercase !important;\r\n\t\t\t\t// color: var(--c-accent) !important;\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\ttbody {\r\n\t\t\t/* Link in table Shared Links/Archived Chats\r\n            \r\n                NAME - first column Links\r\n                \"Shared links\" & \"Archived Chats\" links in table, but a[href^=\"/c/\"] is also Conversation SVG in \"Shared Links\", ahh\r\n            */\r\n\t\t\ttd:first-child a {\r\n\t\t\t\t@extend %link_hover_underless;\r\n\t\t\t}\r\n\r\n\t\t\t/* Center the vertically svg icons next to each other in table */\r\n\t\t\ttd:has(button[aria-label^='Delete']) span[data-state] {\r\n\t\t\t\tdisplay: flex;\r\n\t\t\t\talign-items: center;\r\n\t\t\t\tjustify-items: center;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/* \"Delete shared link\" in Shared Links and \"Delete conversation\" in Archived Chats svg color */\r\n\t\tbutton[aria-label^='Delete'] {\r\n\t\t\tcolor: var(--c-danger) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* ___ DIALOG \"Delete account - are you sure?\" inputs parents */\r\n\tdiv[class*='focus-within:ring-1']:has(input) {\r\n\t\tpadding: 0.8rem !important;\r\n\t\tbackground-color: var(--c-surface-3);\r\n\r\n\t\tinput {\r\n\t\t\tbackground-color: var(--c-surface-3);\r\n\r\n\t\t\t&::placeholder {\r\n\t\t\t\tcolor: var(--c-subtext-1) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/* \"Create Workspace\" dialog when clicking \"Upgrade plan\" > \"Team\" */\r\n\t&:has(input#workspace-name) {\r\n\t\t/* \"Workspace name\" bg color: .bg-token-main-surface-primary */\r\n\t\t--main-surface-primary: transparent !important;\r\n\t}\r\n\r\n\t/* \"Select your Team Plan\" dialog radio buttons when clicking \"Upgrade plan\" > \"Team\" > \"Select billing options\" */\r\n\t&:has(input[name='seats']) {\r\n\t\t/* input counter for seats */\r\n\t\tinput[name='seats'] {\r\n\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.3) !important;\r\n\t\t\tpadding: var(--p-btn) !important;\r\n\t\t\theight: 100% !important;\r\n\t\t\tmargin: 0 0.8rem;\r\n\t\t}\r\n\t}\r\n}\r\n","/* === RIGHT - CONVERSATION CONTAINER === */\r\nmain [role='presentation'] {\r\n\t&,\r\n\t/* Shared Link Page */\r\n\t.bg-token-main-surface-primary.h-full {\r\n\t\tbackground-color: var(--c-bg-chats-container) !important;\r\n\t}\r\n}\r\n\r\n/* === RIGHT - Chats - Gap from heading and svg icons ===*/\r\nmain [data-message-author-role='user'],\r\nmain [data-message-author-role='assistant'] {\r\n\tmargin-top: var(--mt-chat-txt) !important;\r\n\tmargin-bottom: var(--mb-chat-txt) !important;\r\n}\r\n\r\n/* @ === RIGHT - CHATS BUBBLES ===*/\r\nmain [data-testid^='conversation-turn-'] {\r\n\tmargin-bottom: var(--mb-chat-bubble) !important;\r\n\r\n\t/* RIGHT - CHATS BUBBLES DIV */\r\n\t.group {\r\n\t\t// padding: var(--p-chat-bubble) !important;\r\n\t\tpadding: calc(var(--p-chat-bubble) * 1.3) var(--p-chat-bubble) var(--p-chat-bubble) var(--p-chat-bubble) !important;\r\n\t\tborder-radius: var(--br-chat-bubble) !important;\r\n\t\tletter-spacing: 0.3px;\r\n\t\tline-height: 1.8 !important;\r\n\r\n\t\t.agent-turn {\r\n\t\t\twidth: 80% !important;\r\n\t\t\t// border: 1px solid red !important;\r\n\t\t\t// overflow-x: scroll !important;\r\n\t\t}\r\n\r\n\t\t/*  TODO \r\n            gap: 0.75rem + width: 1.5rem = 2.25rem toliko treba da bude padding-right/margin-right i dodati flex-grow: 1;\r\n                ovome: relative flex w-full flex-col lg:w-[calc(100%-115px)] agent-turn \r\n                i ovome: lg:w-[calc(100%-115px)]    to je isti deo samo za user chat bubble\r\n            to je kao chat onaj deo gde je chat, cudno ima veliki space sa desne strane, \r\n        */\r\n\t\t// Fix original strange space on the right (left is svg of user/gpt) in the chat bubbles where text is\r\n\t\tdiv[class*='lg:w-[calc(100%-115px)]'] {\r\n\t\t\t// .agent-turn {\r\n\t\t\t--gap-3: 0.75rem;\r\n\t\t\t--svg-w: 1.5rem;\r\n\t\t\tflex-grow: 1 !important;\r\n\t\t\tmargin-right: calc(var(--gap-3) + var(--svg-w)) !important;\r\n\t\t\t// padding-right: calc(var(--gap-3) + var(--svg-w)) !important;\r\n\t\t\t// border: 2px solid red !important;\r\n\t\t}\r\n\r\n\t\t/* \"Was this response better or worse? 👍👎\" el when clicked on regenerate answer btn  */\r\n\t\t.bg-token-main-surface-secondary:has(button[title^='This response was']) {\r\n\t\t\tbackground-color: transparent !important;\r\n\t\t\tcolor: var(--c-subtext-2) !important;\r\n\t\t\tborder: 1px solid var(--c-border);\r\n\t\t\tborder-radius: var(--br-contextmenu);\r\n\r\n\t\t\t/* \"Same\" svg, fix white border for visualy consistency */\r\n\t\t\tsvg.rounded-full {\r\n\t\t\t\tborder-color: var(--avatar-color);\r\n\t\t\t}\r\n\t\t\t/* 👍👎 */\r\n\t\t\tbutton[title] {\r\n\t\t\t\tborder-radius: var(--br-btn) !important;\r\n\t\t\t\tborder: 1px solid transparent;\r\n\t\t\t\ttransition: transform 0.2s $easeInOutSine;\r\n\r\n\t\t\t\t/* \"Better\", \"Worse\", \"Same\" */\r\n\t\t\t\tspan {\r\n\t\t\t\t\ttransition: color 0.2s $easeInOutSine;\r\n\t\t\t\t\tcolor: var(--c-subtext-2) !important;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:hover {\r\n\t\t\t\t\tbackground-color: transparent !important;\r\n\t\t\t\t\tborder-color: var(--c-border) !important;\r\n\t\t\t\t\ttransform: translateY(-4%);\r\n\r\n\t\t\t\t\tspan {\r\n\t\t\t\t\t\tcolor: var(--avatar-color) !important;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/* RIGHT - CHATS USER/GPT NAMES */\r\n\t.font-semibold.select-none {\r\n\t\ttext-transform: uppercase;\r\n\t}\r\n\r\n\t.gizmo-shadow-stroke div {\r\n\t\tcolor: var(--c-on-accent) !important;\r\n\t}\r\n\r\n\t/* @ RIGHT - CHATS BUBBLES - USER  */\r\n\t// There is no [data-message-author-role=\"user\"] when we clicked on \"Edit Prompt\", so we need select and like this for that case scenario\r\n\t// &:not(&:has([data-message-author-role='assistant'])),\r\n\t&:has([data-message-author-role='user']) {\r\n\t\t/*  RIGHT - CHATS BUBBLE BG */\r\n\t\t.group {\r\n\t\t\tbackground-color: var(--c-bg-msg-user);\r\n\t\t\toutline: 2px solid transparent !important;\r\n\r\n\t\t\t/* === User/ChatGPT name === */\r\n\t\t\t.font-semibold.select-none {\r\n\t\t\t\tcolor: var(--c-msg-name-user);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/*  Chat bubble footer SVG icons */\r\n\t\tbutton svg {\r\n\t\t\tcolor: var(--c-msg-name-user);\r\n\t\t}\r\n\t}\r\n\t/* User chat bubble - Edit state. There is no [data-message-author-role=\"user\"] when we clicked on \"Edit Prompt\", so we need select and like this for that case scenario */\r\n\t&:has(textarea) {\r\n\t\t/* \t\t.flex.flex-grow.flex-col.max-w-full > div {\r\n\t\t\t@extend %animFadeIn;\r\n\t\t} */\r\n\t\t.group {\r\n\t\t\tbackground-color: var(--c-bg-chats-container) !important;\r\n\t\t\tbox-shadow: var(--box-shadow-textarea);\r\n\t\t\toutline: 2px solid hsla(var(--accent-hsl) / 0.1) !important;\r\n\t\t\ttransition: outline 0.2s ease-in-out, box-shadow 0.2s ease-in-out;\r\n\r\n\t\t\t/* === User/ChatGPT name === */\r\n\t\t\t.font-semibold.select-none {\r\n\t\t\t\tcolor: var(--c-msg-name-user);\r\n\t\t\t}\r\n\r\n\t\t\ttextarea {\r\n\t\t\t\t@extend %animFadeIn;\r\n\t\t\t\tcolor: var(--c-subtext-2) !important;\r\n\t\t\t\tpadding: 0.5rem 0;\r\n\t\t\t}\r\n\r\n\t\t\t/* Parent of buttons: \"Save & Submit\" and \"Cancel\" */\r\n\t\t\t.text-center.mt-2.flex.justify-center {\r\n\t\t\t\t@extend %animFadeIn;\r\n\t\t\t}\r\n\r\n\t\t\t.btn-neutral {\r\n\t\t\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/* @ RIGHT - CHATS BUBBLES - GPT */\r\n\t&:has([data-message-author-role='assistant']) {\r\n\t\t/*   RIGHT - CHATS BUBBLE BG  */\r\n\t\t.group {\r\n\t\t\tbackground-color: var(--c-bg-msg-gpt);\r\n\r\n\t\t\tsvg[role='img'] {\r\n\t\t\t\tcolor: var(--c-surface-1) !important;\r\n\t\t\t}\r\n\r\n\t\t\t/*  User/ChatGPT name  */\r\n\t\t\t.font-semibold.select-none {\r\n\t\t\t\t// color: var(--c-msg-name-gpt);\r\n\t\t\t\tcolor: var(--avatar-color);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/*  Chat bubble footer SVG icons */\r\n\t\tbutton svg {\r\n\t\t\tcolor: var(--avatar-color);\r\n\t\t}\r\n\t}\r\n}\r\n","/* === RIGHT - NEW CHAT - 4 BIG BTNS === */\r\n\r\nmain form .grow {\r\n\t/* recimo gap izmedju new chat example buttons*/\r\n\t.gap-2 {\r\n\t\tgap: 0.8rem !important;\r\n\t}\r\n\r\n\t.btn {\r\n\t\tpadding: 1.5rem !important;\r\n\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\tcolor: var(--c-txt) !important;\r\n\t\tborder-radius: var(--br-btn-big) !important;\r\n\t\toverflow: hidden; // Mora jer kad se hoveruje .btn, onda se  .bg-gradient-to-l radius ne uklapa s ovim, manji je i onda .btn cudno izgleda sa desne strane, ovaj ga overflowuje\r\n\r\n\t\t/* Gradient bg visible on hover */\r\n\t\t.bg-gradient-to-l {\r\n\t\t\t--gradient-color-from: var(--c-surface-3) !important;\r\n\t\t\t// --tw-gradient-from: var(--c-surface-3) var(--tw-gradient-from-position) !important;\r\n\r\n\t\t\t/* Button SVG parent ❌ \r\n\t\t\tNo more .bg-token-surface-primary class, now is .bg-token-main-surface-primary */\r\n\t\t\t// .bg-token-surface-primary {\r\n\t\t\t.bg-token-main-surface-primary {\r\n\t\t\t\t// --surface-secondary: var(--c-surface-2) !important;\r\n\t\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\t\tborder-radius: 100vw !important;\r\n\t\t\t\tpadding: 0.5rem !important;\r\n\r\n\t\t\t\t/* SVG icon*/\r\n\t\t\t\tsvg {\r\n\t\t\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n","/* === STICKY ChatGPT version ===*/\r\n/* Removing \"main\" before sticky caused this style is applied on many elements I don't want: Sidebar \"NEW CHT\" wrapper, and down the [aria-haspopup='menu']:hover caused also issues on in pop-up table on more options (3dots) svg icon.\r\nBut adding this \"main\" blocked this style to smaller screens so I have to add it down, out of this block */\r\nmain .sticky {\r\n\tbackground-color: var(--c-bg-chats-sticky) !important;\r\n\tbackdrop-filter: blur(var(--blur-sticky));\r\n\r\n\t/*  \"My GPTs\" page sticky headers w/ +CREATE btn (.top-0 and .top-14) */\r\n\t&:has([href='/gpts/editor']),\r\n\t&.top-14 {\r\n\t\t--c-bg-chats-sticky: var(--c-bg-chats-container) !important;\r\n\t\t--blur-sticky: 0 !important;\r\n\t}\r\n\t&.top-14 {\r\n\t\tpadding-bottom: 0.6rem !important;\r\n\t}\r\n\r\n\t[aria-haspopup='menu']:hover,\r\n\t[aria-haspopup='menu'][data-state='open'] {\r\n\t\tbackground-color: var(--c-surface-1) !important;\r\n\t}\r\n\r\n\t/* === STICKY ChatGPT version svg icon ===*/\r\n\t.btn {\r\n\t\tborder-radius: 50vw !important;\r\n\r\n\t\tsvg {\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* Sticky header for smaller screens. Remove border-bottom */\r\n.sticky.border-token-border-medium {\r\n\tborder: none !important;\r\n}\r\n","/* ===  RIGHT - TEXTAREA PARENT, message type and send button */\r\n// main form .overflow-hidden:has(textarea#prompt-textarea) {\r\nmain form [class*='[&:has(textarea:focus)]']:has(textarea#prompt-textarea) {\r\n\tpadding: var(--p-prompt-textarea) !important;\r\n\t// background-color: transparent !important;\r\n\t// background-color: var(--c-bg-chats-container) !important;\r\n\tbackground-color: var(--c-bg-textarea) !important;\r\n\tborder-radius: var(--br-prompt-textarea) !important;\r\n\t// border: 3px solid var(--c-border-textarea);\r\n\tborder: none !important;\r\n\tbox-shadow: var(--box-shadow-textarea);\r\n\ttransition: background-color 0.3s ease-in-out, box-shadow 0.3s ease-in-out;\r\n\t// box-shadow: var(--box-shadow-contextmenu) !important;\r\n\r\n\t&:has(textarea#prompt-textarea:focus) {\r\n\t\t// box-shadow: var(--box-shadow-contextmenu) !important;\r\n\t\t// border-color: transparent !important;\r\n\t\tbox-shadow: none !important;\r\n\t}\r\n\r\n\ttextarea::placeholder {\r\n\t\tcolor: var(--c-placeholder-textarea) !important;\r\n\t}\r\n\r\n\t/* Send button */\r\n\tbutton[data-testid='send-button'] {\r\n\t\tbackground-color: var(--c-accent) !important;\r\n\t\tcolor: var(--c-txt) !important;\r\n\t\tborder-color: var(--c-accent) !important;\r\n\t\tborder-radius: 100vw !important;\r\n\t\tpadding: 2px;\r\n\t\tright: 1.3rem !important;\r\n\t\tbottom: 1.2rem !important;\r\n\r\n\t\t&[disabled] {\r\n\t\t\topacity: 0.5 !important;\r\n\t\t}\r\n\r\n\t\tsvg {\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* === RIGHT - TEXTAREA part wrapper, margin-top ===*/\r\nmain div[role='presentation'] div.w-full:has(form) {\r\n\tmargin-top: 0.5rem !important;\r\n}\r\n\r\n/* === RIGHT - TEXTAREA PARENT ===*/\r\nmain div.flex.w-full.items-center > div {\r\n\tbox-shadow: none;\r\n\tborder: none;\r\n}\r\n","/* Footer tj wrapper for green btn \"Upgrade to Plus to create your own GPT\"  */\r\nmain [role=\"presentation\"] [class*=\"empty:hidden\"]:has(> a[href=\"/gpts/discovery\"]) {\r\n    padding: 1.5rem;\r\n\r\n    .bg-green-600 {\r\n        @extend .btn;\r\n    }\r\n}","main:has(.sticky [href='/gpts/editor']) {\r\n\t// /* Main Cards (big) */\r\n\t// .rounded-xl {\r\n\t// \tborder-radius: var(--br-btn-big) !important;\r\n\t// }\r\n\t// /* Search query list cards. Input search */\r\n\t// .rounded-lg {\r\n\t// \tborder-radius: var(--br-btn) !important;\r\n\t// }\r\n\t/* Sticky header tags aka \"Top Picks\", \"DALLE\", \"Writing\", etc */\r\n\t.sticky {\r\n\t\t[class*='md:rounded-none'],\r\n\t\t[class*='md:rounded-lg'] {\r\n\t\t\tborder-radius: 100vw !important;\r\n\t\t\tpadding-inline: 1rem !important;\r\n\t\t}\r\n\t\t/* Active tag aka \"Top Picks\" */\r\n\t\t[class*='md:rounded-none'] {\r\n\t\t\tborder: none !important;\r\n\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\r\n\t\t\t/* Fix active pill tag bg be overwritten by global [class*='bg-black'] */\r\n\t\t\t&[class*='bg-black'] {\r\n\t\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t\t/* No-active tags aka \"DALLE\", \"Writing\", etc */\r\n\t\t[class*='md:rounded-lg'] {\r\n\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.2) !important;\r\n\t\t\tcolor: var(--c-accent) !important;\r\n\t\t}\r\n\r\n\t\t/* Left/right arrows in tags track */\r\n\t\t[class*='bg-gradient-to-'] {\r\n\t\t\tbutton {\r\n\t\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/* Input search */\r\n\tinput[placeholder='Search public GPTs'] {\r\n\t\toutline: none;\r\n\t\tbackground-color: var(--c-surface-2) !important;\r\n\r\n\t\t&::placeholder {\r\n\t\t\tcolor: var(--c-subtext-1) !important;\r\n\t\t}\r\n\t}\r\n\r\n\t/* All the cards hover bg (on search query list and on main big ones) */\r\n\t[class*='dark:hover:bg-white/10'] {\r\n\t\t&:hover {\r\n\t\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\t}\r\n\t}\r\n\t/* Section visible on search query */\r\n\t[id*='headlessui-popover-panel-'] {\r\n\t\t// --main-surface-primary: var(--c-surface-2) !important;\r\n\t\t--br-search-query-section: calc(var(--br-btn) * 1.2) !important;\r\n\r\n\t\t/* Added to visually remove unstickness search query section from input search */\r\n\t\ttransform: translateY(-5px);\r\n\r\n\t\tborder-radius: 0 0 var(--br-search-query-section) var(--br-search-query-section) !important;\r\n\r\n\t\t/* Search query section items/cards */\r\n\t\t.gizmo-link {\r\n\t\t\tborder-radius: var(--br-btn) !important;\r\n\t\t\tmargin-bottom: 0.5rem;\r\n\r\n\t\t\tsvg.text-gray-400 {\r\n\t\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\t\t// color: red !important;\r\n\t\t\t}\r\n\r\n\t\t\t// &:hover {\r\n\t\t\t// \tbackground-color: var(--c-surface-3) !important;\r\n\t\t\t// }\r\n\t\t}\r\n\t}\r\n\r\n\t/* All the card items in GPTs Store main page */\r\n\t.h-fit {\r\n\t\t/* \"See more\" full-width buttons */\r\n\t\t.btn.w-full {\r\n\t\t\t// padding: calc(var(--p-btn) * 1.5) !important;\r\n\t\t\tpadding: 1.8rem !important;\r\n\t\t\tborder-radius: calc(var(--br-btn) * 1.2) !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* \r\n? Active tag classes (\"Top Picks\") vs no-active tag classes (\"DALLE\", \"Writing\", etc)\r\n```border-token-text-primary bg-black text-white dark:bg-gray-100 dark:text-gray-800 md:rounded-none md:border-b-2 md:text-black dark:md:text-white\r\ncursor-pointer scroll-mx-5 whitespace-nowrap rounded-3xl px-3 py-2 first:ml-4 last:mr-4 md:px-2 md:first:ml-0 md:last:mr-0 border-token-text-primary bg-black text-white dark:bg-gray-100 dark:text-gray-800 md:rounded-none md:border-b-2 md:bg-transparent md:text-black dark:md:bg-transparent dark:md:text-white\r\n\r\n```bg-gray-50, dark:bg-gray-700 md:rounded-lg md:text-token-text-tertiary md:hover:bg-gray-50 dark:md:hover:bg-gray-700\r\ncursor-pointer scroll-mx-5 whitespace-nowrap rounded-3xl px-3 py-2 first:ml-4 last:mr-4 md:px-2 md:first:ml-0 md:last:mr-0 bg-gray-50 hover:bg-gray-100 dark:bg-gray-700 dark:hover:bg-gray-600 md:rounded-lg md:bg-transparent md:text-token-text-tertiary md:hover:bg-gray-50 dark:md:bg-transparent dark:md:hover:bg-gray-700\r\n*/\r\n","/* ___ General */\r\nbutton,\r\nli,\r\na,\r\nsvg,\r\n[class*=':hover'],\r\n[role='switch'] span[data-state] {\r\n\ttransition: all 0.3s ease-in-out;\r\n\r\n\t// transition:\r\n\t//     all .35s var(--ease-default),\r\n\t//     opacity .3 ease-in-out,\r\n\t//     background-color .3 ease-in-out,\r\n\t//     color .3 ease-in-out;\r\n\r\n\t/*     transition:\r\n        transform .25s var(--ease-default),\r\n        opacity .3s ease-in-out,\r\n        background-color .3s ease-in-out,\r\n        color .3s ease-in-out,\r\n        border-color .3s ease-in-out,\r\n        box-shadow .3s ease-in-out,\r\n        scale .3s ease-in-out,\r\n        rotate .3s ease-in-out,\r\n        translate .3s ease-in-out,\r\n        filter .3s ease-in-out,\r\n        border-radius .3s ease-in-out, inset .3s ease-in-out; */\r\n}\r\n\r\n/* ___ BUTTON SVG icon which ARE NOT in:\r\n    - in .btn <button>\r\n    - Theme choosing <button>\r\n    - in active tab <button>\r\n    - in send message btn <button>\r\n    - btns in message bubble footer <button> ([class*=\"[.final-completion]\"]) \r\n------------------------------\r\n    - .btn  |  Button\r\n    - [role=\"tab\"]  |  Active tab\r\n    - [role=\"combobox\"]  |  Theme choosing\r\n    - [data-testid=\"send-button\"]  |  Send Message Button\r\n    - [class*=\"[.final-completion]\"]  |  Btns in Message bubble footer\r\n    - [aria-label^=\"Delete\"])  | \"Delete\" icon in \"Shared links\" and \"Archived Chats\" \r\n    - [aria-label=\"Unarchive conversation\"])  | \"Unarchive\" icon in \"Archived Chats\"\r\n   */\r\nbutton:not(\r\n\t\t.btn,\r\n\t\t[role='tab'],\r\n\t\t[role='combobox'],\r\n\t\t[data-testid='send-button'],\r\n\t\t[class*='[.final-completion]'],\r\n\t\t[aria-label^='Delete'],\r\n\t\t[aria-label='Unarchive conversation']\r\n\t) {\r\n\tsvg {\r\n\t\ttransform-origin: center center;\r\n\t\t// border: 1px solid red !important;\r\n\t}\r\n\r\n\tsvg:hover {\r\n\t\ttransform: scale(1.12);\r\n\t}\r\n}\r\n\r\n.btn {\r\n\twill-change: transform, opacity;\r\n\r\n\t// transition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out, background-color 0.3s ease-in-out, color 0.3s ease-in-out !important;\r\n\ttransition: transform 0.2s $easeInOutQuad, opacity 0.3s ease-in-out, background-color 0.3s ease-in-out,\r\n\t\tcolor 0.3s ease-in-out !important;\r\n\r\n\t&:is(:hover, :active) {\r\n\t\ttransform: translateY(-2px);\r\n\t\topacity: 0.8;\r\n\t}\r\n}\r\n\r\n/* dialog buttons */\r\n[role='dialog'] {\r\n\t/* \".PopoverContent\" je recimo menu od btn u \"Shared Link to Chat\" 3dots menu (Shared your Name & Delete Link) */\r\n\t&.PopoverContent {\r\n\t\t.btn-neutral:is(:hover, :focus) {\r\n\t\t\tbackground-color: var(--c-surface-2) !important;\r\n\t\t\tcolor: var(--c-txt) !important;\r\n\t\t\ttransform: none !important;\r\n\t\t\topacity: 1 !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* ___ Switch button circle hover. Ovde ne moze :focus, ostane style kao da je checked ili obrnuto i kad se unhoveruje */\r\nbutton[role='switch'] {\r\n\tspan[data-state] {\r\n\t\ttransition: transform 0.4s $easeInOutBack, background-color 0.3s ease-in-out;\r\n\t}\r\n\r\n\t&:hover {\r\n\t\tspan[data-state] {\r\n\t\t\t/* Ovo se kosi sa openai klasama, jer on dodaje translate-x -19px, pa se circle pomera levo, sto i nije lose, lol. Ako to ne zelimo, mozemo koristiti scale umesto transform: scale */\r\n\t\t\ttransform: scale(0.8);\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* ___ New Chat big buttons */\r\nmain form .grow .btn {\r\n\t// transition: .4s $easeOutBack, background-color .3s ease-in-out opacity .3s ease-in-out;\r\n\r\n\t/* Gradient bg visible on hover */\r\n\t.bg-gradient-to-l {\r\n\t\ttransition: all 0.3s ease-in-out;\r\n\r\n\t\t/* Button SVG parent wrapper */\r\n\t\tspan[data-state] {\r\n\t\t\toverflow: hidden;\r\n\t\t\tpadding: 4px; // because svg btn looks cut off in firefox, so add a little space around\r\n\r\n\t\t\t/* Button w/ SVG */\r\n\t\t\t// .bg-token-surface-primary { this class doesnt exist anymore...\r\n\t\t\t.bg-token-main-surface-primary {\r\n\t\t\t\ttransform: translateY(120%) scale(0.5);\r\n\t\t\t\ttransition: transform 0.5s $easeOutBack;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t&:hover {\r\n\t\tbackground-color: var(--c-surface-3) !important;\r\n\t\ttransform: translateY(-4px);\r\n\r\n\t\t.bg-gradient-to-l {\r\n\t\t\tspan[data-state] {\r\n\t\t\t\t/* Button w/ SVG */\r\n\t\t\t\t// .bg-token-surface-primary {\r\n\t\t\t\t.bg-token-main-surface-primary {\r\n\t\t\t\t\ttransform: translateY(0%) scale(1);\r\n\t\t\t\t\topacity: 1 !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* ___ Textarea send message send-button */\r\n[data-testid='send-button']:not([disabled]) {\r\n\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out;\r\n\r\n\t&:hover {\r\n\t\ttransform: translateY(-10%);\r\n\t}\r\n}\r\n\r\n/* ___ Chat Bubbles */\r\nmain [data-testid^='conversation-turn-'] {\r\n\t.group {\r\n\t\t&:hover {\r\n\t\t\t/* Bubble message footer (icons wrapper) */\r\n\t\t\tdiv[class*='empty:hidden']:has(button[class*='[.final-completion]']) .visible {\r\n\t\t\t\ttransform: translateY(0);\r\n\t\t\t\topacity: 1;\r\n\t\t\t}\r\n\r\n\t\t\t/* Bubble message footer (svg icons) */\r\n\t\t\t[class*='[.final-completion]'] svg {\r\n\t\t\t\ttransform: scale(1);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/* Bubble message footer */\r\n\t\tdiv[class*='empty:hidden']:has(button[class*='[.final-completion]']) {\r\n\t\t\toverflow-y: clip;\r\n\t\t\t// padding-inline: 10px; // to make counter answer (<2/4>) visible when this is overflow-hidden, we need to add padding-inline, or we can use overflow-y: clip; And overflow is \"important\" for translate transition\r\n\r\n\t\t\t/* Bubble message footer (icons wrapper) */\r\n\t\t\t.visible {\r\n\t\t\t\ttransform: translateY(100%);\r\n\t\t\t\topacity: 0;\r\n\t\t\t\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t/* Bubble message footer (svg icons) */\r\n\t\t[class*='[.final-completion]'] svg {\r\n\t\t\ttransform: translateY(0px);\r\n\t\t\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out;\r\n\r\n\t\t\t&:hover {\r\n\t\t\t\topacity: 0.8;\r\n\t\t\t\ttransform: translateY(-3px);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* \"Copy code\" btn */\r\npre {\r\n\tbutton:has(svg) {\r\n\t\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out, background-color 0.2s ease-in-out,\r\n\t\t\tcolor 0.1s ease-in-out !important;\r\n\r\n\t\tsvg {\r\n\t\t\ttransition: color 0.1s ease-in-out !important;\r\n\t\t}\r\n\r\n\t\t&:hover {\r\n\t\t\tbackground-color: var(--c-accent-light) !important;\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t\ttransform: translateY(2px);\r\n\t\t}\r\n\t}\r\n}\r\n\r\nhtml.light pre button:has(svg):hover {\r\n\tcolor: var(--c-txt) !important;\r\n}\r\n\r\n/* ___ Scroll down button */\r\nmain [role='presentation'] button.absolute.rounded-full {\r\n\ttransition: transform 0.4s $easeOutBack, opacity 0.3s ease-in-out;\r\n\r\n\t&:hover {\r\n\t\ttransform: translateY(10%);\r\n\t\topacity: 1 !important;\r\n\t}\r\n}\r\n\r\n/* ___ Table \"Archived Chats\" or \"Shared Links\" */\r\n[role='dialog'] table {\r\n\ttbody {\r\n\t\t/* Table column that contains \"Delete\" svg icon */\r\n\t\ttd:has(button[aria-label^='Delete']) {\r\n\t\t\tsvg {\r\n\t\t\t\ttransition: transform 0.4s $easeOutBack;\r\n\t\t\t}\r\n\r\n\t\t\t/* SVG parent wrapper */\r\n\t\t\tspan[data-state]:hover {\r\n\t\t\t\tsvg {\r\n\t\t\t\t\ttransform: translateY(2px) scale(1) !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/* === ❓ circle btn on bottom right */\r\nbutton[id*='headlessui-menu-button'][class*='rounded-full'] {\r\n\ttransition: transform 0.3s $easeOutCirc;\r\n\r\n\t&:hover {\r\n\t\ttransform: scale(1.06);\r\n\t}\r\n}\r\n\r\n/* GPTs Store page - All the card items */\r\nmain:has(.sticky [href='/gpts/editor']) {\r\n\t.sticky {\r\n\t\t/* Sticky header with tags aka \"Top Picks\", \"DALLE\", \"Writing\", etc */\r\n\t\t[class*='md:rounded-none'],\r\n\t\t[class*='md:rounded-lg'] {\r\n\t\t\t// transition: background-color 0.3s ease, color 0.3s ease, transform 0.2s $easeInCirc;\r\n\t\t\ttransition: background-color 0.3s $easeInOutSine, color 0.3s $easeInOutSine, transform 0.3s $easeInOutSine;\r\n\t\t}\r\n\t\t/* Non-active pill-tag */\r\n\t\t[class*='md:rounded-lg']:hover {\r\n\t\t\ttransform: scale(0.955);\r\n\t\t\tbackground-color: var(--c-accent) !important;\r\n\t\t\tcolor: var(--c-on-accent) !important;\r\n\t\t}\r\n\r\n\t\t/* Left/right arrows in tags track */\r\n\t\t[class*='bg-gradient-to-'] button {\r\n\t\t\ttransition: transform 0.3s $easeInQuart;\r\n\t\t}\r\n\t\t/* Right tags arrow */\r\n\t\t[class*='bg-gradient-to-l'] button {\r\n\t\t\t&:hover {\r\n\t\t\t\ttransform: translateX(3px);\r\n\t\t\t}\r\n\t\t}\r\n\t\t/* Left tags arrow */\r\n\t\t[class*='bg-gradient-to-r'] button {\r\n\t\t\t&:hover {\r\n\t\t\t\ttransform: translateX(-3px);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\t/* All the card items in GPTs Store main page */\r\n\t.h-fit {\r\n\t\ta[href*='/g/g-'] {\r\n\t\t\t// border: 1px solid red !important;\r\n\t\t\ttransition: transform 0.3s $easeInOutSine, background-color 0.3s ease-in-out;\r\n\r\n\t\t\t&:hover {\r\n\t\t\t\ttransform: translateY(-3px);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n",".gpth {\r\n\t&__svg {\r\n\t\t--svg-size: 2.25rem;\r\n\t\t--top: calc(var(--h-header) + 0.5rem);\r\n\t\t--right: 1.3rem;\r\n\t\tposition: fixed;\r\n\t\ttop: var(--top);\r\n\t\tright: var(--right);\r\n\t\tz-index: 10;\r\n\r\n\t\t// this add only for Firefox\r\n\t\t@-moz-document url-prefix() {\r\n\t\t\t--right: 0.95rem;\r\n\t\t}\r\n\r\n\t\t&-icon {\r\n\t\t\t--icon-shadow-blur: 0px;\r\n\t\t\t--icon-shadow-offset: 6px;\r\n\t\t\t--icon-shadow-color: hsla(var(--accent-hsl) / 0.1);\r\n\t\t\tposition: relative;\r\n\t\t\tdisplay: grid;\r\n\t\t\tplace-items: center;\r\n\t\t\twidth: var(--svg-size);\r\n\t\t\theight: var(--svg-size);\r\n\t\t\tborder-radius: 50vw;\r\n\t\t\tbox-shadow: var(--box-shadow);\r\n\t\t\ttransition: transform 0.15s $easeOutCubic, outline 0.25s $easeOutCubic;\r\n\t\t\tcursor: pointer;\r\n\r\n\t\t\timg {\r\n\t\t\t\tobject-fit: cover;\r\n\t\t\t\twidth: var(--svg-size);\r\n\t\t\t\theight: var(--svg-size);\r\n\t\t\t\tborder-radius: 50vw;\r\n\t\t\t\tbox-shadow: 0px 0px var(--icon-shadow-blur) var(--icon-shadow-offset) hsla(var(--accent-hsl) / 0.3);\r\n\t\t\t\ttransition: box-shadow 0.2s $easeOutCubic;\r\n\t\t\t}\r\n\r\n\t\t\t&::after {\r\n\t\t\t\tcontent: 'Change theme';\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\ttop: 50%;\r\n\t\t\t\tleft: 0;\r\n\t\t\t\tfont-size: 0.75rem;\r\n\t\t\t\tborder-radius: 1.2rem;\r\n\t\t\t\twidth: max-content;\r\n\t\t\t\theight: max-content;\r\n\t\t\t\tpadding: 0.5rem 0.8rem;\r\n\t\t\t\tpointer-events: none;\r\n\t\t\t\tbackground-color: var(--c-bg-tooltip);\r\n\t\t\t\topacity: 0;\r\n\t\t\t\ttransform: translate(-100%, -50%);\r\n\t\t\t\ttransition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out;\r\n\t\t\t}\r\n\r\n\t\t\t&:hover {\r\n\t\t\t\t--icon-shadow-blur: 30px;\r\n\t\t\t\t--icon-shadow-offset: 7px;\r\n\t\t\t\t--icon-shadow-color: hsla(var(--accent-hsl) / 0.2);\r\n\t\t\t\ttransform: translateY(2px);\r\n\r\n\t\t\t\toutline: 5px solid hsla(var(--accent-hsl) / 0.05);\r\n\t\t\t\toutline-offset: 8px;\r\n\r\n\t\t\t\t&::after {\r\n\t\t\t\t\topacity: 1;\r\n\t\t\t\t\ttransform: translate(-115%, -50%);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\t&__options {\r\n\t\tpointer-events: none;\r\n\t\topacity: 0;\r\n\t\tdisplay: grid;\r\n\t\tplace-items: center;\r\n\t\tgap: 3rem;\r\n\t\twidth: max-content;\r\n\t\theight: max-content;\r\n\t\tpadding: 0.8rem;\r\n\t\tposition: absolute;\r\n\t\tright: 50%;\r\n\t\ttop: 150%;\r\n\t\ttransform: translateX(50%);\r\n\t\tborder-radius: 20vw;\r\n\t\tbackground-color: var(--c-surface-3);\r\n\t\tbox-shadow: var(--box-shadow);\r\n\r\n\t\t// background-image: linear-gradient(-135deg, #716782, #42335d, #2e1f48);\r\n\t\tbackground-image: linear-gradient(135deg, #332250, #42335d 40%, #6c607f 100%);\r\n\r\n\t\tclip-path: polygon(0 0, 100% 0, 100% 0, 0% 0);\r\n\t\ttransition: all 0.3s ease-in-out;\r\n\t\tbackdrop-filter: blur(5px);\r\n\r\n\t\t&.gpth-options-shown {\r\n\t\t\topacity: 1;\r\n\t\t\tpointer-events: all !important;\r\n\t\t\tclip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%) !important;\r\n\r\n\t\t\tbutton {\r\n\t\t\t\ttransform: scale(1);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\th5 {\r\n\t\t\tmargin-bottom: 1rem;\r\n\t\t\tdisplay: inline-block;\r\n\t\t\tfont-size: 1.3rem;\r\n\t\t\tletter-spacing: 1px;\r\n\t\t\tfont-weight: 100;\r\n\t\t}\r\n\t}\r\n\t&__themes {\r\n\t\tdisplay: grid;\r\n\t\tplace-items: center;\r\n\r\n\t\t&-btns {\r\n\t\t\tgap: 1rem;\r\n\t\t\tdisplay: grid;\r\n\t\t\tborder-radius: var(--br-btn);\r\n\r\n\t\t\tbutton {\r\n\t\t\t\t--btn-size: 2rem;\r\n\t\t\t\t--btn-bg: var(--c-surface-2);\r\n\t\t\t\t--btn-shadow-color: var(--btn-bg);\r\n\t\t\t\tcursor: pointer;\r\n\t\t\t\tposition: relative;\r\n\t\t\t\twidth: var(--btn-size);\r\n\t\t\t\theight: var(--btn-size);\r\n\t\t\t\tdisplay: grid;\r\n\t\t\t\tplace-items: center;\r\n\t\t\t\tline-height: 1;\r\n\t\t\t\tborder-radius: 50vw;\r\n\t\t\t\tborder: none;\r\n\t\t\t\tbackground-color: var(--btn-bg);\r\n\t\t\t\t// box-shadow: inset 0px 0px 5px 1px var(--btn-shadow-color);\r\n\t\t\t\t// box-shadow: inset 0px 0px 8px 1px var(--btn-shadow-color);\r\n\t\t\t\t// box-shadow: 0px 0px 5px 2px hsla(var(--accent-hsl) / 0.2)\r\n\t\t\t\ttransform: scale(0);\r\n\t\t\t\ttransition: background-color 0.2s ease, background-image 0.2s ease, transform 0.3s ease-in-out;\r\n\r\n\t\t\t\t&::after {\r\n\t\t\t\t\tcontent: attr(data-gpth-theme);\r\n\t\t\t\t\tposition: absolute;\r\n\t\t\t\t\ttop: 50%;\r\n\t\t\t\t\tleft: 50%;\r\n\t\t\t\t\twidth: max-content;\r\n\t\t\t\t\tfont-size: 0.8rem;\r\n\t\t\t\t\tpadding: 4px 4px;\r\n\t\t\t\t\tborder-radius: 5px;\r\n\t\t\t\t\tbackground-color: var(--c-accent-light);\r\n\t\t\t\t\topacity: 0;\r\n\t\t\t\t\tborder-radius: 50vw;\r\n\t\t\t\t\ttransform: translate(-50%, -50%) scale(0);\r\n\t\t\t\t\ttransition: 0.25s ease-in-out;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:hover {\r\n\t\t\t\t\t--btn-bg: hsla(0, 0%, 0%, 0) !important;\r\n\r\n\t\t\t\t\t&#dark {\r\n\t\t\t\t\t\tbackground-image: none;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&::after {\r\n\t\t\t\t\t\topacity: 1;\r\n\t\t\t\t\t\ttransform: translate(-50%, -50%) scale(1);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&#light {\r\n\t\t\t\t\t--btn-bg: var(--c-accent-light);\r\n\t\t\t\t}\r\n\t\t\t\t&#dark {\r\n\t\t\t\t\t--btn-shadow-color: hsla(255, 12%, 7%, 0.2);\r\n\t\t\t\t\t--btn-bg: hsl(272, 19%, 20%);\r\n\t\t\t\t\tbackground-image: linear-gradient(135deg, #8d80a0, #50416b, #2f1f49);\r\n\t\t\t\t}\r\n\t\t\t\t&#oled {\r\n\t\t\t\t\t--btn-shadow-color: hsla(0, 0%, 100%, 0.2);\r\n\t\t\t\t\t--btn-bg: #000;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t&__upload {\r\n\t\tdisplay: grid;\r\n\t\tjustify-items: center;\r\n\r\n\t\t&--content {\r\n\t\t\tdisplay: grid;\r\n\t\t\talign-items: center;\r\n\t\t\tgap: 1rem;\r\n\t\t}\r\n\r\n\t\tinput {\r\n\t\t\tdisplay: none;\r\n\t\t}\r\n\r\n\t\tlabel,\r\n\t\tbutton {\r\n\t\t\ttext-align: center;\r\n\t\t\toutline: none;\r\n\t\t\tborder: none;\r\n\t\t\tcursor: pointer;\r\n\t\t\twidth: 100%;\r\n\t\t\tpadding: var(--p-btn);\r\n\t\t\tborder-radius: var(--br-btn);\r\n\t\t\tbackground-color: var(--c-accent);\r\n\t\t\tcolor: var(--c-on-accent);\r\n\t\t\tfont-size: 1rem;\r\n\t\t}\r\n\r\n\t\tbutton#uploadImage {\r\n\t\t\tdisplay: none;\r\n\t\t}\r\n\t\tbutton#removeImage {\r\n\t\t\tdisplay: none;\r\n\t\t}\r\n\r\n\t\t&--preview {\r\n\t\t\tdisplay: grid;\r\n\t\t\tjustify-items: center;\r\n\r\n\t\t\tp {\r\n\t\t\t\ttext-align: center;\r\n\t\t\t\tmargin-bottom: 1rem;\r\n\t\t\t\tcolor: var(--c-subtext-2);\r\n\t\t\t}\r\n\t\t}\r\n\t\t&--placeholderImg {\r\n\t\t\tdisplay: grid;\r\n\t\t\tjustify-items: center;\r\n\t\t\t// --img-w: 11rem;\r\n\t\t\t--img-w: 95%;\r\n\t\t\t--img-h: 7rem;\r\n\t\t\t// margin: 0 auto;\r\n\t\t\twidth: var(--img-w);\r\n\t\t\theight: var(--img-h);\r\n\t\t\tborder-radius: var(--br-btn);\r\n\r\n\t\t\timg {\r\n\t\t\t\twidth: var(--img-w);\r\n\t\t\t\theight: var(--img-h);\r\n\t\t\t\t// width: 100%;\r\n\t\t\t\t// height: 100%;\r\n\t\t\t\tobject-fit: cover;\r\n\t\t\t\tobject-position: center;\r\n\t\t\t\tborder-radius: inherit;\r\n\t\t\t\tdisplay: none;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t&--placeholder {\r\n\t\t\twidth: var(--img-w);\r\n\t\t\theight: var(--img-h);\r\n\t\t\tdisplay: grid;\r\n\t\t\tgrid-template-columns: 1fr 3fr;\r\n\t\t\toverflow: clip;\r\n\t\t\tbox-shadow: 0 0 0 2px hsla(var(--accent-hsl) / 0.2);\r\n\t\t\tborder-radius: inherit;\r\n\r\n\t\t\taside {\r\n\t\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.2);\r\n\t\t\t}\r\n\t\t\tsection {\r\n\t\t\t\t// background-color: hsla(var(--accent-hsl) / 0.01);\r\n\t\t\t\tdisplay: grid;\r\n\t\t\t\tgrid-template-rows: 3fr 4fr 2.5fr;\r\n\t\t\t\tgap: 6px;\r\n\t\t\t\tpadding: 5px 10px;\r\n\r\n\t\t\t\tarticle {\r\n\t\t\t\t\twidth: 70%;\r\n\t\t\t\t\tborder-radius: 10px;\r\n\r\n\t\t\t\t\t&:nth-child(1) {\r\n\t\t\t\t\t\t// height: 50%;\r\n\t\t\t\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.4);\r\n\t\t\t\t\t}\r\n\t\t\t\t\t&:nth-child(2) {\r\n\t\t\t\t\t\t// height: 2rem;\r\n\t\t\t\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.2);\r\n\t\t\t\t\t\tjustify-self: flex-end;\r\n\t\t\t\t\t}\r\n\t\t\t\t\t&:nth-child(3) {\r\n\t\t\t\t\t\t// height: 4rem;\r\n\t\t\t\t\t\tbackground-color: hsla(var(--accent-hsl) / 0.4);\r\n\t\t\t\t\t\t// justify-self: flex-end;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\nhtml.light {\r\n\t& [data-gpth-theme]::after,\r\n\t.gpth__svg-icon::after {\r\n\t\tcolor: var(--c-txt);\r\n\t}\r\n}\r\nhtml.dark {\r\n\t& [data-gpth-theme]::after,\r\n\t.gpth__svg-icon::after {\r\n\t\tcolor: var(--c-on-accent);\r\n\t}\r\n}\r\n"],"names":[],"version":3,"file":"sass.faed8373.css.map"} */ diff --git a/package.json b/package.json index a15fd2c..c231568 100644 --- a/package.json +++ b/package.json @@ -11,15 +11,15 @@ }, "homepage": "https://github.com/itsmartashub/GPThemes/", "scripts": { - "clean_dev": "rimraf .parcel-cache extension-dev", - "clean_prod": "rimraf .parcel-cache extension-prod", - "clean_zips": "rimraf extension-zips", + "clean-dev": "rimraf .parcel-cache extension-dev", + "clean-prod": "rimraf .parcel-cache extension-prod", + "clean-zips": "rimraf extension-zips", "dev": "parcel watch src/manifests/chrome/manifest.json --host localhost --dist-dir extension-dev/chromium", - "dev_ff": "parcel watch src/manifests/firefox-mv2/manifest.json --host localhost --dist-dir extension-dev/firefox-mv2", + "dev-ff": "parcel watch src/manifests/firefox-mv2/manifest.json --host localhost --dist-dir extension-dev/firefox-mv2", "build": "parcel build src/manifests/chrome/manifest.json --dist-dir extension-prod/gpthemes-chromium --no-source-maps", - "build_ff": "parcel build src/manifests/firefox-mv2/manifest.json --dist-dir extension-prod/gpthemes-firefox-mv2 --no-source-maps", + "build-ff": "parcel build src/manifests/firefox-mv2/manifest.json --dist-dir extension-prod/gpthemes-firefox-mv2 --no-source-maps", "zip": "node ./scripts/zip.js", - "build_all": "npm run clean_prod && npm run build && npm run build_ff && npm run zip" + "build-all": "npm run clean-prod && npm run build && npm run build-ff && npm run zip" }, "author": "itsmarta", "keywords": [ diff --git a/src/sass/elements/_menu.scss b/src/sass/elements/_menu.scss index 78766fb..17153ab 100644 --- a/src/sass/elements/_menu.scss +++ b/src/sass/elements/_menu.scss @@ -52,6 +52,15 @@ div[data-radix-popper-content-wrapper] { z-index: calc(var(--z-modal) + 50) !important; // z-index: 200 !important; + /* "Custom Instructions" dialog */ + &:has([role='dialog']) { + /* "Custom Instructions" dialog context menu visible on textarea focus */ + [role='dialog'] { + --box-shadow: var(--box-shadow-contextmenu) !important; + // box-shadow: var(--box-shadow-contextmenu) !important; + } + } + /* Mora not role=menu da ne bih selektovala i onaj contextmenu u sidebar kad se klikne na prompt listitem 3 dots za opcije i div[data-radix-popper-content-wrapper]:has([role='tooltip']) da ne bih selektovala tooltip */ &:not( div[data-radix-popper-content-wrapper]:has(div[role='menu']),