quill.snow.css 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950
  1. /*!
  2. * Quill Editor v1.3.6
  3. * https://quilljs.com/
  4. * Copyright (c) 2014, Jason Chen
  5. * Copyright (c) 2013, salesforce.com
  6. */
  7. .ql-container {
  8. box-sizing: border-box;
  9. font-family: Helvetica, Arial, sans-serif;
  10. font-size: 13px;
  11. height: 100%;
  12. margin: 0px;
  13. position: relative;
  14. }
  15. .ql-container.ql-disabled .ql-tooltip {
  16. visibility: hidden;
  17. }
  18. .ql-container.ql-disabled .ql-editor ul[data-checked] > li::before {
  19. pointer-events: none;
  20. }
  21. .ql-clipboard {
  22. left: -100000px;
  23. height: 1px;
  24. overflow-y: hidden;
  25. position: absolute;
  26. top: 50%;
  27. }
  28. .ql-clipboard p {
  29. margin: 0;
  30. padding: 0;
  31. }
  32. .ql-editor {
  33. box-sizing: border-box;
  34. line-height: 1.42;
  35. height: 100%;
  36. outline: none;
  37. overflow-y: auto;
  38. padding: 12px 15px;
  39. tab-size: 4;
  40. -moz-tab-size: 4;
  41. text-align: left;
  42. white-space: pre-wrap;
  43. word-wrap: break-word;
  44. }
  45. .ql-editor > * {
  46. cursor: text;
  47. }
  48. .ql-editor p,
  49. .ql-editor ol,
  50. .ql-editor ul,
  51. .ql-editor pre,
  52. .ql-editor blockquote,
  53. .ql-editor h1,
  54. .ql-editor h2,
  55. .ql-editor h3,
  56. .ql-editor h4,
  57. .ql-editor h5,
  58. .ql-editor h6 {
  59. margin: 0;
  60. padding: 0;
  61. counter-reset: list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;
  62. }
  63. .ql-editor ol,
  64. .ql-editor ul {
  65. padding-left: 1.5em;
  66. }
  67. .ql-editor ol > li,
  68. .ql-editor ul > li {
  69. list-style-type: none;
  70. }
  71. .ql-editor ul > li::before {
  72. content: '\2022';
  73. }
  74. .ql-editor ul[data-checked=true],
  75. .ql-editor ul[data-checked=false] {
  76. pointer-events: none;
  77. }
  78. .ql-editor ul[data-checked=true] > li *,
  79. .ql-editor ul[data-checked=false] > li * {
  80. pointer-events: all;
  81. }
  82. .ql-editor ul[data-checked=true] > li::before,
  83. .ql-editor ul[data-checked=false] > li::before {
  84. color: #777;
  85. cursor: pointer;
  86. pointer-events: all;
  87. }
  88. .ql-editor ul[data-checked=true] > li::before {
  89. content: '\2611';
  90. }
  91. .ql-editor ul[data-checked=false] > li::before {
  92. content: '\2610';
  93. }
  94. .ql-editor li::before {
  95. display: inline-block;
  96. white-space: nowrap;
  97. width: 1.2em;
  98. }
  99. .ql-editor li:not(.ql-direction-rtl)::before {
  100. margin-left: -1.5em;
  101. margin-right: 0.3em;
  102. text-align: right;
  103. }
  104. .ql-editor li.ql-direction-rtl::before {
  105. margin-left: 0.3em;
  106. margin-right: -1.5em;
  107. }
  108. .ql-editor ol li:not(.ql-direction-rtl),
  109. .ql-editor ul li:not(.ql-direction-rtl) {
  110. padding-left: 1.5em;
  111. }
  112. .ql-editor ol li.ql-direction-rtl,
  113. .ql-editor ul li.ql-direction-rtl {
  114. padding-right: 1.5em;
  115. }
  116. .ql-editor ol li {
  117. counter-reset: list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;
  118. counter-increment: list-0;
  119. }
  120. .ql-editor ol li:before {
  121. content: counter(list-0, decimal) '. ';
  122. }
  123. .ql-editor ol li.ql-indent-1 {
  124. counter-increment: list-1;
  125. }
  126. .ql-editor ol li.ql-indent-1:before {
  127. content: counter(list-1, lower-alpha) '. ';
  128. }
  129. .ql-editor ol li.ql-indent-1 {
  130. counter-reset: list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;
  131. }
  132. .ql-editor ol li.ql-indent-2 {
  133. counter-increment: list-2;
  134. }
  135. .ql-editor ol li.ql-indent-2:before {
  136. content: counter(list-2, lower-roman) '. ';
  137. }
  138. .ql-editor ol li.ql-indent-2 {
  139. counter-reset: list-3 list-4 list-5 list-6 list-7 list-8 list-9;
  140. }
  141. .ql-editor ol li.ql-indent-3 {
  142. counter-increment: list-3;
  143. }
  144. .ql-editor ol li.ql-indent-3:before {
  145. content: counter(list-3, decimal) '. ';
  146. }
  147. .ql-editor ol li.ql-indent-3 {
  148. counter-reset: list-4 list-5 list-6 list-7 list-8 list-9;
  149. }
  150. .ql-editor ol li.ql-indent-4 {
  151. counter-increment: list-4;
  152. }
  153. .ql-editor ol li.ql-indent-4:before {
  154. content: counter(list-4, lower-alpha) '. ';
  155. }
  156. .ql-editor ol li.ql-indent-4 {
  157. counter-reset: list-5 list-6 list-7 list-8 list-9;
  158. }
  159. .ql-editor ol li.ql-indent-5 {
  160. counter-increment: list-5;
  161. }
  162. .ql-editor ol li.ql-indent-5:before {
  163. content: counter(list-5, lower-roman) '. ';
  164. }
  165. .ql-editor ol li.ql-indent-5 {
  166. counter-reset: list-6 list-7 list-8 list-9;
  167. }
  168. .ql-editor ol li.ql-indent-6 {
  169. counter-increment: list-6;
  170. }
  171. .ql-editor ol li.ql-indent-6:before {
  172. content: counter(list-6, decimal) '. ';
  173. }
  174. .ql-editor ol li.ql-indent-6 {
  175. counter-reset: list-7 list-8 list-9;
  176. }
  177. .ql-editor ol li.ql-indent-7 {
  178. counter-increment: list-7;
  179. }
  180. .ql-editor ol li.ql-indent-7:before {
  181. content: counter(list-7, lower-alpha) '. ';
  182. }
  183. .ql-editor ol li.ql-indent-7 {
  184. counter-reset: list-8 list-9;
  185. }
  186. .ql-editor ol li.ql-indent-8 {
  187. counter-increment: list-8;
  188. }
  189. .ql-editor ol li.ql-indent-8:before {
  190. content: counter(list-8, lower-roman) '. ';
  191. }
  192. .ql-editor ol li.ql-indent-8 {
  193. counter-reset: list-9;
  194. }
  195. .ql-editor ol li.ql-indent-9 {
  196. counter-increment: list-9;
  197. }
  198. .ql-editor ol li.ql-indent-9:before {
  199. content: counter(list-9, decimal) '. ';
  200. }
  201. .ql-editor .ql-indent-1:not(.ql-direction-rtl) {
  202. padding-left: 3em;
  203. }
  204. .ql-editor li.ql-indent-1:not(.ql-direction-rtl) {
  205. padding-left: 4.5em;
  206. }
  207. .ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right {
  208. padding-right: 3em;
  209. }
  210. .ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right {
  211. padding-right: 4.5em;
  212. }
  213. .ql-editor .ql-indent-2:not(.ql-direction-rtl) {
  214. padding-left: 6em;
  215. }
  216. .ql-editor li.ql-indent-2:not(.ql-direction-rtl) {
  217. padding-left: 7.5em;
  218. }
  219. .ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right {
  220. padding-right: 6em;
  221. }
  222. .ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right {
  223. padding-right: 7.5em;
  224. }
  225. .ql-editor .ql-indent-3:not(.ql-direction-rtl) {
  226. padding-left: 9em;
  227. }
  228. .ql-editor li.ql-indent-3:not(.ql-direction-rtl) {
  229. padding-left: 10.5em;
  230. }
  231. .ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right {
  232. padding-right: 9em;
  233. }
  234. .ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right {
  235. padding-right: 10.5em;
  236. }
  237. .ql-editor .ql-indent-4:not(.ql-direction-rtl) {
  238. padding-left: 12em;
  239. }
  240. .ql-editor li.ql-indent-4:not(.ql-direction-rtl) {
  241. padding-left: 13.5em;
  242. }
  243. .ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right {
  244. padding-right: 12em;
  245. }
  246. .ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right {
  247. padding-right: 13.5em;
  248. }
  249. .ql-editor .ql-indent-5:not(.ql-direction-rtl) {
  250. padding-left: 15em;
  251. }
  252. .ql-editor li.ql-indent-5:not(.ql-direction-rtl) {
  253. padding-left: 16.5em;
  254. }
  255. .ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right {
  256. padding-right: 15em;
  257. }
  258. .ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right {
  259. padding-right: 16.5em;
  260. }
  261. .ql-editor .ql-indent-6:not(.ql-direction-rtl) {
  262. padding-left: 18em;
  263. }
  264. .ql-editor li.ql-indent-6:not(.ql-direction-rtl) {
  265. padding-left: 19.5em;
  266. }
  267. .ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right {
  268. padding-right: 18em;
  269. }
  270. .ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right {
  271. padding-right: 19.5em;
  272. }
  273. .ql-editor .ql-indent-7:not(.ql-direction-rtl) {
  274. padding-left: 21em;
  275. }
  276. .ql-editor li.ql-indent-7:not(.ql-direction-rtl) {
  277. padding-left: 22.5em;
  278. }
  279. .ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right {
  280. padding-right: 21em;
  281. }
  282. .ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right {
  283. padding-right: 22.5em;
  284. }
  285. .ql-editor .ql-indent-8:not(.ql-direction-rtl) {
  286. padding-left: 24em;
  287. }
  288. .ql-editor li.ql-indent-8:not(.ql-direction-rtl) {
  289. padding-left: 25.5em;
  290. }
  291. .ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right {
  292. padding-right: 24em;
  293. }
  294. .ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right {
  295. padding-right: 25.5em;
  296. }
  297. .ql-editor .ql-indent-9:not(.ql-direction-rtl) {
  298. padding-left: 27em;
  299. }
  300. .ql-editor li.ql-indent-9:not(.ql-direction-rtl) {
  301. padding-left: 28.5em;
  302. }
  303. .ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right {
  304. padding-right: 27em;
  305. }
  306. .ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right {
  307. padding-right: 28.5em;
  308. }
  309. .ql-editor .ql-video {
  310. display: block;
  311. max-width: 100%;
  312. }
  313. .ql-editor .ql-video.ql-align-center {
  314. margin: 0 auto;
  315. }
  316. .ql-editor .ql-video.ql-align-right {
  317. margin: 0 0 0 auto;
  318. }
  319. .ql-editor .ql-bg-black {
  320. background-color: #000;
  321. }
  322. .ql-editor .ql-bg-red {
  323. background-color: #e60000;
  324. }
  325. .ql-editor .ql-bg-orange {
  326. background-color: #f90;
  327. }
  328. .ql-editor .ql-bg-yellow {
  329. background-color: #ff0;
  330. }
  331. .ql-editor .ql-bg-green {
  332. background-color: #008a00;
  333. }
  334. .ql-editor .ql-bg-blue {
  335. background-color: #06c;
  336. }
  337. .ql-editor .ql-bg-purple {
  338. background-color: #93f;
  339. }
  340. .ql-editor .ql-color-white {
  341. color: #fff;
  342. }
  343. .ql-editor .ql-color-red {
  344. color: #e60000;
  345. }
  346. .ql-editor .ql-color-orange {
  347. color: #f90;
  348. }
  349. .ql-editor .ql-color-yellow {
  350. color: #ff0;
  351. }
  352. .ql-editor .ql-color-green {
  353. color: #008a00;
  354. }
  355. .ql-editor .ql-color-blue {
  356. color: #06c;
  357. }
  358. .ql-editor .ql-color-purple {
  359. color: #93f;
  360. }
  361. .ql-editor .ql-font-serif {
  362. font-family: Georgia, Times New Roman, serif;
  363. }
  364. .ql-editor .ql-font-monospace {
  365. font-family: Monaco, Courier New, monospace;
  366. }
  367. .ql-editor .ql-size-small {
  368. font-size: 0.75em;
  369. }
  370. .ql-editor .ql-size-large {
  371. font-size: 1.5em;
  372. }
  373. .ql-editor .ql-size-huge {
  374. font-size: 2.5em;
  375. }
  376. .ql-editor .ql-direction-rtl {
  377. direction: rtl;
  378. text-align: inherit;
  379. }
  380. .ql-editor .ql-align-center {
  381. text-align: center;
  382. }
  383. .ql-editor .ql-align-justify {
  384. text-align: justify;
  385. }
  386. .ql-editor .ql-align-right {
  387. text-align: right;
  388. }
  389. .ql-editor.ql-blank::before {
  390. color: rgba(0,0,0,0.6);
  391. content: attr(data-placeholder);
  392. font-style: normal;
  393. left: 15px;
  394. pointer-events: none;
  395. position: absolute;
  396. right: 15px;
  397. color: #c7c7c7;
  398. }
  399. .ql-snow.ql-toolbar:after,
  400. .ql-snow .ql-toolbar:after {
  401. clear: both;
  402. content: '';
  403. display: table;
  404. }
  405. .ql-snow.ql-toolbar button,
  406. .ql-snow .ql-toolbar button {
  407. background: none;
  408. border: none;
  409. cursor: pointer;
  410. display: inline-block;
  411. float: left;
  412. height: 24px;
  413. padding: 3px 5px;
  414. width: 28px;
  415. }
  416. .ql-snow.ql-toolbar button svg,
  417. .ql-snow .ql-toolbar button svg {
  418. float: left;
  419. height: 100%;
  420. }
  421. .ql-snow.ql-toolbar button:active:hover,
  422. .ql-snow .ql-toolbar button:active:hover {
  423. outline: none;
  424. }
  425. .ql-snow.ql-toolbar input.ql-image[type=file],
  426. .ql-snow .ql-toolbar input.ql-image[type=file] {
  427. display: none;
  428. }
  429. .ql-snow.ql-toolbar button:hover,
  430. .ql-snow .ql-toolbar button:hover,
  431. .ql-snow.ql-toolbar button:focus,
  432. .ql-snow .ql-toolbar button:focus,
  433. .ql-snow.ql-toolbar button.ql-active,
  434. .ql-snow .ql-toolbar button.ql-active,
  435. .ql-snow.ql-toolbar .ql-picker-label:hover,
  436. .ql-snow .ql-toolbar .ql-picker-label:hover,
  437. .ql-snow.ql-toolbar .ql-picker-label.ql-active,
  438. .ql-snow .ql-toolbar .ql-picker-label.ql-active,
  439. .ql-snow.ql-toolbar .ql-picker-item:hover,
  440. .ql-snow .ql-toolbar .ql-picker-item:hover,
  441. .ql-snow.ql-toolbar .ql-picker-item.ql-selected,
  442. .ql-snow .ql-toolbar .ql-picker-item.ql-selected {
  443. color: #06c;
  444. }
  445. .ql-snow.ql-toolbar button:hover .ql-fill,
  446. .ql-snow .ql-toolbar button:hover .ql-fill,
  447. .ql-snow.ql-toolbar button:focus .ql-fill,
  448. .ql-snow .ql-toolbar button:focus .ql-fill,
  449. .ql-snow.ql-toolbar button.ql-active .ql-fill,
  450. .ql-snow .ql-toolbar button.ql-active .ql-fill,
  451. .ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,
  452. .ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,
  453. .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,
  454. .ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,
  455. .ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,
  456. .ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,
  457. .ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,
  458. .ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,
  459. .ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,
  460. .ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,
  461. .ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,
  462. .ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,
  463. .ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,
  464. .ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,
  465. .ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,
  466. .ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,
  467. .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,
  468. .ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,
  469. .ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,
  470. .ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,
  471. .ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,
  472. .ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill {
  473. fill: #06c;
  474. }
  475. .ql-snow.ql-toolbar button:hover .ql-stroke,
  476. .ql-snow .ql-toolbar button:hover .ql-stroke,
  477. .ql-snow.ql-toolbar button:focus .ql-stroke,
  478. .ql-snow .ql-toolbar button:focus .ql-stroke,
  479. .ql-snow.ql-toolbar button.ql-active .ql-stroke,
  480. .ql-snow .ql-toolbar button.ql-active .ql-stroke,
  481. .ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,
  482. .ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,
  483. .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,
  484. .ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,
  485. .ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,
  486. .ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,
  487. .ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,
  488. .ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,
  489. .ql-snow.ql-toolbar button:hover .ql-stroke-miter,
  490. .ql-snow .ql-toolbar button:hover .ql-stroke-miter,
  491. .ql-snow.ql-toolbar button:focus .ql-stroke-miter,
  492. .ql-snow .ql-toolbar button:focus .ql-stroke-miter,
  493. .ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,
  494. .ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,
  495. .ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,
  496. .ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,
  497. .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,
  498. .ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,
  499. .ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,
  500. .ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,
  501. .ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,
  502. .ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter {
  503. stroke: #06c;
  504. }
  505. @media (pointer: coarse) {
  506. .ql-snow.ql-toolbar button:hover:not(.ql-active),
  507. .ql-snow .ql-toolbar button:hover:not(.ql-active) {
  508. color: #444;
  509. }
  510. .ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,
  511. .ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,
  512. .ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,
  513. .ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill {
  514. fill: #444;
  515. }
  516. .ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,
  517. .ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,
  518. .ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,
  519. .ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter {
  520. stroke: #444;
  521. }
  522. }
  523. .ql-snow {
  524. box-sizing: border-box;
  525. }
  526. .ql-snow * {
  527. box-sizing: border-box;
  528. }
  529. .ql-snow .ql-hidden {
  530. display: none;
  531. }
  532. .ql-snow .ql-out-bottom,
  533. .ql-snow .ql-out-top {
  534. visibility: hidden;
  535. }
  536. .ql-snow .ql-tooltip {
  537. position: absolute;
  538. transform: translateY(10px);
  539. }
  540. .ql-snow .ql-tooltip a {
  541. cursor: pointer;
  542. text-decoration: none;
  543. }
  544. .ql-snow .ql-tooltip.ql-flip {
  545. transform: translateY(-10px);
  546. }
  547. .ql-snow .ql-formats {
  548. display: inline-block;
  549. vertical-align: middle;
  550. }
  551. .ql-snow .ql-formats:after {
  552. clear: both;
  553. content: '';
  554. display: table;
  555. }
  556. .ql-snow .ql-stroke {
  557. fill: none;
  558. stroke: #444;
  559. stroke-linecap: round;
  560. stroke-linejoin: round;
  561. stroke-width: 2;
  562. }
  563. .ql-snow .ql-stroke-miter {
  564. fill: none;
  565. stroke: #444;
  566. stroke-miterlimit: 10;
  567. stroke-width: 2;
  568. }
  569. .ql-snow .ql-fill,
  570. .ql-snow .ql-stroke.ql-fill {
  571. fill: #444;
  572. }
  573. .ql-snow .ql-empty {
  574. fill: none;
  575. }
  576. .ql-snow .ql-even {
  577. fill-rule: evenodd;
  578. }
  579. .ql-snow .ql-thin,
  580. .ql-snow .ql-stroke.ql-thin {
  581. stroke-width: 1;
  582. }
  583. .ql-snow .ql-transparent {
  584. opacity: 0.4;
  585. }
  586. .ql-snow .ql-direction svg:last-child {
  587. display: none;
  588. }
  589. .ql-snow .ql-direction.ql-active svg:last-child {
  590. display: inline;
  591. }
  592. .ql-snow .ql-direction.ql-active svg:first-child {
  593. display: none;
  594. }
  595. .ql-snow .ql-editor h1 {
  596. font-size: 2em;
  597. }
  598. .ql-snow .ql-editor h2 {
  599. font-size: 1.5em;
  600. }
  601. .ql-snow .ql-editor h3 {
  602. font-size: 1.17em;
  603. }
  604. .ql-snow .ql-editor h4 {
  605. font-size: 1em;
  606. }
  607. .ql-snow .ql-editor h5 {
  608. font-size: 0.83em;
  609. }
  610. .ql-snow .ql-editor h6 {
  611. font-size: 0.67em;
  612. }
  613. .ql-snow .ql-editor a {
  614. text-decoration: underline;
  615. }
  616. .ql-snow .ql-editor blockquote {
  617. border-left: 4px solid #ccc;
  618. margin-bottom: 5px;
  619. margin-top: 5px;
  620. padding-left: 16px;
  621. }
  622. .ql-snow .ql-editor code,
  623. .ql-snow .ql-editor pre {
  624. background-color: #f0f0f0;
  625. border-radius: 3px;
  626. }
  627. .ql-snow .ql-editor pre {
  628. white-space: pre-wrap;
  629. margin-bottom: 5px;
  630. margin-top: 5px;
  631. padding: 5px 10px;
  632. }
  633. .ql-snow .ql-editor code {
  634. font-size: 85%;
  635. padding: 2px 4px;
  636. }
  637. .ql-snow .ql-editor pre.ql-syntax {
  638. background-color: #23241f;
  639. color: #f8f8f2;
  640. overflow: visible;
  641. }
  642. .ql-snow .ql-editor img {
  643. max-width: 100%;
  644. }
  645. .ql-snow .ql-picker {
  646. color: #444;
  647. display: inline-block;
  648. float: left;
  649. font-size: 14px;
  650. font-weight: 500;
  651. height: 24px;
  652. position: relative;
  653. vertical-align: middle;
  654. }
  655. .ql-snow .ql-picker-label {
  656. cursor: pointer;
  657. display: inline-block;
  658. height: 100%;
  659. padding-left: 8px;
  660. padding-right: 2px;
  661. position: relative;
  662. width: 100%;
  663. }
  664. .ql-snow .ql-picker-label::before {
  665. display: inline-block;
  666. line-height: 22px;
  667. }
  668. .ql-snow .ql-picker-options {
  669. background-color: #fff;
  670. display: none;
  671. min-width: 100%;
  672. padding: 4px 8px;
  673. position: absolute;
  674. white-space: nowrap;
  675. }
  676. .ql-snow .ql-picker-options .ql-picker-item {
  677. cursor: pointer;
  678. display: block;
  679. padding-bottom: 5px;
  680. padding-top: 5px;
  681. }
  682. .ql-snow .ql-picker.ql-expanded .ql-picker-label {
  683. color: #ccc;
  684. z-index: 2;
  685. }
  686. .ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill {
  687. fill: #ccc;
  688. }
  689. .ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke {
  690. stroke: #ccc;
  691. }
  692. .ql-snow .ql-picker.ql-expanded .ql-picker-options {
  693. display: block;
  694. margin-top: -1px;
  695. top: 100%;
  696. z-index: 1;
  697. }
  698. .ql-snow .ql-color-picker,
  699. .ql-snow .ql-icon-picker {
  700. width: 28px;
  701. }
  702. .ql-snow .ql-color-picker .ql-picker-label,
  703. .ql-snow .ql-icon-picker .ql-picker-label {
  704. padding: 2px 4px;
  705. }
  706. .ql-snow .ql-color-picker .ql-picker-label svg,
  707. .ql-snow .ql-icon-picker .ql-picker-label svg {
  708. right: 4px;
  709. }
  710. .ql-snow .ql-icon-picker .ql-picker-options {
  711. padding: 4px 0px;
  712. }
  713. .ql-snow .ql-icon-picker .ql-picker-item {
  714. height: 24px;
  715. width: 24px;
  716. padding: 2px 4px;
  717. }
  718. .ql-snow .ql-color-picker .ql-picker-options {
  719. padding: 3px 5px;
  720. width: 152px;
  721. }
  722. .ql-snow .ql-color-picker .ql-picker-item {
  723. border: 1px solid transparent;
  724. float: left;
  725. height: 16px;
  726. margin: 2px;
  727. padding: 0px;
  728. width: 16px;
  729. }
  730. .ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg {
  731. position: absolute;
  732. margin-top: -9px;
  733. right: 0;
  734. top: 50%;
  735. width: 18px;
  736. }
  737. .ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=''])::before,
  738. .ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=''])::before,
  739. .ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=''])::before,
  740. .ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=''])::before,
  741. .ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=''])::before,
  742. .ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=''])::before {
  743. content: attr(data-label);
  744. }
  745. .ql-snow .ql-picker.ql-header {
  746. width: 98px;
  747. }
  748. .ql-snow .ql-picker.ql-header .ql-picker-label::before,
  749. .ql-snow .ql-picker.ql-header .ql-picker-item::before {
  750. content: 'Normal';
  751. }
  752. .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]::before,
  753. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before {
  754. content: 'Heading 1';
  755. }
  756. .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]::before,
  757. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before {
  758. content: 'Heading 2';
  759. }
  760. .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]::before,
  761. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before {
  762. content: 'Heading 3';
  763. }
  764. .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]::before,
  765. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before {
  766. content: 'Heading 4';
  767. }
  768. .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]::before,
  769. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before {
  770. content: 'Heading 5';
  771. }
  772. .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]::before,
  773. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before {
  774. content: 'Heading 6';
  775. }
  776. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before {
  777. font-size: 2em;
  778. }
  779. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before {
  780. font-size: 1.5em;
  781. }
  782. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before {
  783. font-size: 1.17em;
  784. }
  785. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before {
  786. font-size: 1em;
  787. }
  788. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before {
  789. font-size: 0.83em;
  790. }
  791. .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before {
  792. font-size: 0.67em;
  793. }
  794. .ql-snow .ql-picker.ql-font {
  795. width: 108px;
  796. }
  797. .ql-snow .ql-picker.ql-font .ql-picker-label::before,
  798. .ql-snow .ql-picker.ql-font .ql-picker-item::before {
  799. content: 'Sans Serif';
  800. }
  801. .ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]::before,
  802. .ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]::before {
  803. content: 'Serif';
  804. }
  805. .ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]::before,
  806. .ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]::before {
  807. content: 'Monospace';
  808. }
  809. .ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]::before {
  810. font-family: Georgia, Times New Roman, serif;
  811. }
  812. .ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]::before {
  813. font-family: Monaco, Courier New, monospace;
  814. }
  815. .ql-snow .ql-picker.ql-size {
  816. width: 98px;
  817. }
  818. .ql-snow .ql-picker.ql-size .ql-picker-label::before,
  819. .ql-snow .ql-picker.ql-size .ql-picker-item::before {
  820. content: 'Normal';
  821. }
  822. .ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]::before,
  823. .ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]::before {
  824. content: 'Small';
  825. }
  826. .ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]::before,
  827. .ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]::before {
  828. content: 'Large';
  829. }
  830. .ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]::before,
  831. .ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]::before {
  832. content: 'Huge';
  833. }
  834. .ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]::before {
  835. font-size: 10px;
  836. }
  837. .ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]::before {
  838. font-size: 18px;
  839. }
  840. .ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]::before {
  841. font-size: 32px;
  842. }
  843. .ql-snow .ql-color-picker.ql-background .ql-picker-item {
  844. background-color: #fff;
  845. }
  846. .ql-snow .ql-color-picker.ql-color .ql-picker-item {
  847. background-color: #000;
  848. }
  849. .ql-toolbar.ql-snow {
  850. border: 1px solid #ccc;
  851. box-sizing: border-box;
  852. font-family: 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  853. padding: 8px;
  854. }
  855. .ql-toolbar.ql-snow .ql-formats {
  856. margin-right: 15px;
  857. }
  858. .ql-toolbar.ql-snow .ql-picker-label {
  859. border: 1px solid transparent;
  860. }
  861. .ql-toolbar.ql-snow .ql-picker-options {
  862. border: 1px solid transparent;
  863. box-shadow: rgba(0,0,0,0.2) 0 2px 8px;
  864. }
  865. .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label {
  866. border-color: #ccc;
  867. }
  868. .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options {
  869. border-color: #ccc;
  870. }
  871. .ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,
  872. .ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover {
  873. border-color: #000;
  874. }
  875. .ql-toolbar.ql-snow + .ql-container.ql-snow {
  876. border-top: 0px;
  877. }
  878. .ql-snow .ql-tooltip {
  879. background-color: #fff;
  880. border: 1px solid #ccc;
  881. box-shadow: 0px 0px 5px #ddd;
  882. color: #444;
  883. padding: 5px 12px;
  884. white-space: nowrap;
  885. }
  886. .ql-snow .ql-tooltip::before {
  887. content: "Visit URL:";
  888. line-height: 26px;
  889. margin-right: 8px;
  890. }
  891. .ql-snow .ql-tooltip input[type=text] {
  892. display: none;
  893. border: 1px solid #ccc;
  894. font-size: 13px;
  895. height: 26px;
  896. margin: 0px;
  897. padding: 3px 5px;
  898. width: 170px;
  899. }
  900. .ql-snow .ql-tooltip a.ql-preview {
  901. display: inline-block;
  902. max-width: 200px;
  903. overflow-x: hidden;
  904. text-overflow: ellipsis;
  905. vertical-align: top;
  906. }
  907. .ql-snow .ql-tooltip a.ql-action::after {
  908. border-right: 1px solid #ccc;
  909. content: 'Edit';
  910. margin-left: 16px;
  911. padding-right: 8px;
  912. }
  913. .ql-snow .ql-tooltip a.ql-remove::before {
  914. content: 'Remove';
  915. margin-left: 8px;
  916. }
  917. .ql-snow .ql-tooltip a {
  918. line-height: 26px;
  919. }
  920. .ql-snow .ql-tooltip.ql-editing a.ql-preview,
  921. .ql-snow .ql-tooltip.ql-editing a.ql-remove {
  922. display: none;
  923. }
  924. .ql-snow .ql-tooltip.ql-editing input[type=text] {
  925. display: inline-block;
  926. }
  927. .ql-snow .ql-tooltip.ql-editing a.ql-action::after {
  928. border-right: 0px;
  929. content: 'Save';
  930. padding-right: 0px;
  931. }
  932. .ql-snow .ql-tooltip[data-mode=link]::before {
  933. content: "Enter link:";
  934. }
  935. .ql-snow .ql-tooltip[data-mode=formula]::before {
  936. content: "Enter formula:";
  937. }
  938. .ql-snow .ql-tooltip[data-mode=video]::before {
  939. content: "Enter video:";
  940. }
  941. .ql-snow a {
  942. color: #06c;
  943. }
  944. .ql-container.ql-snow {
  945. border: 1px solid #ccc;
  946. }
  947. .ql-editor a{
  948. color: #02c8ae;
  949. }