Pen Settings

HTML

CSS

CSS Base

Vendor Prefixing

Add External Stylesheets/Pens

Any URLs added here will be added as <link>s in order, and before the CSS in the editor. You can use the CSS from another Pen by using its URL and the proper URL extension.

+ add another resource

JavaScript

Babel includes JSX processing.

Add External Scripts/Pens

Any URL's added here will be added as <script>s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.

+ add another resource

Packages

Add Packages

Search for and use JavaScript packages from npm here. By selecting a package, an import statement will be added to the top of the JavaScript editor for this package.

Behavior

Save Automatically?

If active, Pens will autosave every 30 seconds after being saved once.

Auto-Updating Preview

If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.

Format on Save

If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.

Editor Settings

Code Indentation

Want to change your Syntax Highlighting theme, Fonts and more?

Visit your global Editor Settings.

HTML

              
                
      <section class="test">
          <div class="sample" lang="la">Lorem ipsum dolor sit <i>amet</i>, consectetur adipiscing elit. In blandit tempus ligula, vel placerat <i>nunc</i>. Proin tempus <n>gravida</n> tri<i>sti</i>que. Duis sed condimentum enim, si<j>t</j> amet tempus justo. Curabitur vehicula dignissim nunc. Don<i>ec</i> ornare ornare massa, eget dignissim est commodo vitae. In hac habitasse platea dictum<i>st.</i> Etiam nec diam ri<i>sus.</i> Nullam lectus nibh, ve-hicula et nulla vel, <i>temp</i>or mollis turpis. Nulla urna nunc, accumsan quis condimen<i>tum</i> eu, feugiat et tellus. Sed convallis ipsum eu suscipit fermentum. Suspendisse mattis sed nulla vel aliquam. Vestibulum commodo metus placerat enim vulputate gravida. Nulla dui ligula, volutpat et accumsan in, viverra ut sem. Donec a elementum ipsum, eu ultricies justo. Duis ac nisi non tortor finibus auctor sit amet eget augue. Donec eget est tincidunt, bibendum mi non, facilisis enim. Cras vitae ex id augue vestibulum bibendum. Aliquam aliquet cursus efficitur. Aenean bibendum lectus eget sapien egestas, sed dictum odio fermentum. Integer quam lorem, condimentum a metus id, congue egestas eros. Ut pellentesque turpis sollicitudin sapien lobortis ullamcorper vitae id augue. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Morbi condimentum viverra orci, a ultrices ipsum mattis faucibus. Aliquam posuere purus risus, sit amet bibendum nisi ultricies quis. Nam commodo est sem, at sollicitudin orci sagittis eu. Proin ac erat mauris. Maecenas quis maximus nisl. Nunc in mattis nulla. Sed eu egestas nisl, at rutrum massa. Morbi porttitor, augue non malesuada ultrices, justo justo posuere magna, sed maximus nunc sapien nec magna. </div>
        
        
          <div class="sample exclude" lang="la">Lorem ipsum dolor sit <i>amet</i>, consectetur adipiscing elit. In blandit tempus ligula, vel placerat <i>nunc</i>. Proin tempus <n>gravida</n> tri<i>sti</i>que. Duis sed condimentum enim, si<j>t</j> amet tempus justo. Curabitur vehicula dignissim nunc. Don<i>ec</i> ornare ornare massa, eget dignissim est commodo vitae. In hac habitasse platea dictum<i>st.</i> Etiam nec diam ri<i>sus.</i> Nullam lectus nibh, ve-hicula et nulla vel, <i>temp</i>or mollis turpis. Nulla urna nunc, accumsan quis condimen<i>tum</i> eu, feugiat et tellus. Sed convallis ipsum eu suscipit fermentum. Suspendisse mattis sed nulla vel aliquam. Vestibulum commodo metus placerat enim vulputate gravida. Nulla dui ligula, volutpat et accumsan in, viverra ut sem. Donec a elementum ipsum, eu ultricies justo. Duis ac nisi non tortor finibus auctor sit amet eget augue. Donec eget est tincidunt, bibendum mi non, facilisis enim. Cras vitae ex id augue vestibulum bibendum. Aliquam aliquet cursus efficitur. Aenean bibendum lectus eget sapien egestas, sed dictum odio fermentum. Integer quam lorem, condimentum a metus id, congue egestas eros. Ut pellentesque turpis sollicitudin sapien lobortis ullamcorper vitae id augue. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Morbi condimentum viverra orci, a ultrices ipsum mattis faucibus. Aliquam posuere purus risus, sit amet bibendum nisi ultricies quis. Nam commodo est sem, at sollicitudin orci sagittis eu. Proin ac erat mauris. Maecenas quis maximus nisl. Nunc in mattis nulla. Sed eu egestas nisl, at rutrum massa. Morbi porttitor, augue non malesuada ultrices, justo justo posuere magna, sed maximus nunc sapien nec magna. </div>
      </section>
              
            
!

CSS

              
                /*** The new CSS Reset - version 1.4.5 (last updated 13.1.2022) ***/

/*
    Remove all the styles of the "User-Agent-Stylesheet", except for the 'display' property
    - The "symbol *" part is to solve Firefox SVG sprite bug
 */
*:where(:not(.exclude,iframe, canvas, img, svg, video):not(svg *, symbol *)) {
    all: unset;
    display: revert;
}

/* Preferred box-sizing value */
*,
*::before,
*::after {
    box-sizing: border-box;
}

/* Reapply the pointer cursor for anchor tags */
a {
    cursor: revert;
}

/* Remove list styles (bullets/numbers) */
ol, ul, menu {
    list-style: none;
}

/* For images to not be able to exceed their container */
img {
    max-width: 100%;
}

/* removes spacing between cells in tables */
table {
    border-collapse: collapse;
}

/* revert the 'white-space' property for textarea elements on Safari */
textarea {
    white-space: revert;
}

/* fix the feature of 'hidden' attribute.
   display:revert; revert to element instead of attribute */
:where([hidden]){
    display:none;
}

/* revert for bug in Chromium browsers
   - fix for the content editable attribute will work properly. */
:where([contenteditable]){
    -moz-user-modify: read-write;
    -webkit-user-modify: read-write;
    overflow-wrap: break-word;
    -webkit-line-break: after-white-space;
}

/* apply back the draggable feature - exist only in Chromium and Safari */
:where([draggable="true"]) {
    -webkit-user-drag: element;
}


.sample {
  /* toggling this on fixes difference in Chrome but does not bring back hyphenation */
  /*   all: revert; */
  
  width: 700px;
  font-size: 60px;
  font-family: Georgia;
  hyphens: auto;
  margin-right: 50px;
}

section {
  display: flex;
}
              
            
!

JS

              
                
              
            
!
999px

Console