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

Auto Save

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

              
                .explain
  div
    h1 How to demo:
    p
      | Hold 
      strong CTRL
      |  and move the mouse around to outline the hovered DOM element.
    p
      | Hold 
      strong CTRL
      | +
      strong SHIFT
      |  to outline every element.
    p
      | Go into editor mode (Top-right ➡ "Change View" ➡ "Editor mode") and play with commented out custom configuration for Debucsser class.
    p Debucsser make it easy to debug your CSS.
    p
      | You can apply custom class on hover, or grayscale all the page, everything you want... check it out 😎
    button Got it
.wrapper
  header.box.header
    h1#title Debucsser
    i#this-is-what-it-is “CSS debugging made easy”
    .git
      a.github-button(href='https://github.com/lucagez/Debucsser', data-icon='octicon-star', data-size='large', data-show-count='true', aria-label='Star lucagez/Debucsser on GitHub') Star
    hr.bar
  #main-article.box
    .content
      img.main-article-image(src='', alt='')
      h1.title Duties of American Citizenship
      i.subtitle
        strong.author Theodore Roosevelt
        | , January 26, 1883; Buffalo, New York
      p.text
        | Of course, in one sense, the first essential for a man’s being a good citizen is his possession
        | of the home
        | virtues of which we think when we call a man by the emphatic adjective of manly. No man can be a good citizen
        | who is not a good husband and a good father, who is not honest in his dealings with other men and women,
        | faithful to his friends and fearless in the presence of his foes, who has not got a sound heart, a sound
        | mind, and a sound body; exactly as no amount of attention to civil duties will save a nation if the domestic
        | life is undermined, or there is lack of the rude military virtues which alone can assure a country’s position
        | in the world. In a free republic the ideal citizen must be one willing and able to take arms for the defense
        | of the flag, exactly as the ideal citizen must be the father of many healthy children. A race must be strong
        | and vigorous; it must be a race of good fighters and good breeders, else its wisdom will come to naught and
        | its virtue be ineffective; and no sweetness and delicacy, no love for and appreciation of beauty in art or
        | literature, no capacity for building up material prosperity can possibly atone for the lack of the great
        | virile virtues. But this is aside from my subject, for what I wish to talk of is the attitude of the American
        | citizen in civic life. It ought to be axiomatic in this country that every man must devote a reasonable share
        | of his time to doing his duty in the Political life of the community. No man has a right to shirk his
        | political duties under whatever plea of pleasure or business; and while such shirking may be pardoned in
        | those of small cleans it is entirely unpardonable in those among whom it is most common–in the people whose
        | circumstances give them freedom in the struggle for life. In so far as the community grows to think rightly,
        | it will likewise grow to regard the young man of means who shirks his duty to the State in time of peace as
        | being only one degree worse than the man who thus shirks it in time of war. A great many of our men in
        | business, or of our young men who are bent on enjoying life (as they have a perfect right to do if only they
        | do not sacrifice other things to enjoyment), rather plume themselves upon being good citizens if they even
        | vote; yet voting is the very least of their duties, Nothing worth gaining is ever gained without effort. You
        | can no more have freedom without striving and suffering for it than you can win success as a banker or a
        | lawyer without labor and effort, without self-denial in youth and the display of a ready and alert
        | intelligence in middle age. The people who say that they have not time to attend to politics are simply
        | saying that they are unfit to live in a free community.
    hr.bar
  aside.box.sidebar
    .content
      img.Demostenes(src='https://upload.wikimedia.org/wikipedia/commons/thumb/4/48/D%C3%A9mosth%C3%A8ne_s%27exer%C3%A7ant_%C3%A0_la_parole_%281870%29_by_Jean-Jules-Antoine_Lecomte_du_Nou%C3%BF.jpg/220px-D%C3%A9mosth%C3%A8ne_s%27exer%C3%A7ant_%C3%A0_la_parole_%281870%29_by_Jean-Jules-Antoine_Lecomte_du_Nou%C3%BF.jpg', alt='')
      h1.title The Third Philippic
      i.subtitle
        strong.author Demosthenes
        | , 342 B.C., Athens, Greece
      p.text
        | It is this fate, I solemnly assure you, that I dread for you, when the time comes that you make
        | your
        | reckoning, and realize that there is no longer anything that can be done. May you never find yourselves, men
        | of Athens, in such a position! Yet in any case, it were better to die ten thousand deaths, than to do
        | anything out of servility towards Philip [or to sacrifice any of those who speak for your good]. A noble
        | recompense did the people in Oreus receive, for entrusting themselves to Philip’s friends, and thrusting
        | Euphraeus aside! And a noble recompense the democracy of Eretria, for driving away your envoys, and
        | surrendering to Cleitarchus! They are slaves, scourged and butchered! A noble clemency did he show to the
        | Olynthians, who elected Lasthenes to command the cavalry, and banished Apollonides! It is folly, and it is
        | cowardice, to cherish hopes like these, to give way to evil counsels, to refuse to do anything that you
        | should do, to listen to the advocates of the enemy’s cause, and to fancy that you dwell in so great a city
        | that, whatever happens, you will not suffer any harm.
    hr.bar
    .content
      img.The-luckiest-man(src='https://upload.wikimedia.org/wikipedia/commons/thumb/3/38/Lou_Gehrig_as_a_new_Yankee_11_Jun_1923.jpg/235px-Lou_Gehrig_as_a_new_Yankee_11_Jun_1923.jpg', alt='')
      h1.title Farewell to Baseball Address
      i.subtitle
        strong.author Lou Gehrig
        | , July 4, 1939, Yankee Stadium
      p.text
        | Fans, for the past two weeks you have been reading about a bad break I got. Yet today I
        | consider myself the
        | luckiest man on the face of the earth. I have been in ballparks for seventeen years and have never received
        | anything but kindness and encouragement from you fans. Look at these grand men. Which of you wouldn’t
        | consider it the highlight of his career to associate with them for even one day? Sure, I’m lucky. Who
        | wouldn’t consider it an honor to have known Jacob Ruppert – also the builder of baseball’s greatest empire,
        | Ed Barrow – to have spent the next nine years with that wonderful little fellow Miller Huggins – then to have
        | spent the next nine years with that outstanding leader, that smart student of psychology – the best manager
        | in baseball today, Joe McCarthy! Sure, I’m lucky. When the New York Giants, a team you would give your right
        | arm to beat, and vice versa, sends you a gift, that’s something! When everybody down to the groundskeepers
        | and those boys in white coats remember you with trophies, that’s something. When you have a wonderful
        | mother-in-law who takes sides with you in squabbles against her own daughter, that’s something. When you have
        | a father and mother who work all their lives so that you can have an education and build your body, it’s a
        | blessing! When you have a wife who has been a tower of strength and shown more courage than you dreamed
        | existed, that’s the finest I know. So I close in saying that I might have had a tough break – but I have an
        | awful lot to live for!
    hr.bar
  .box.article-container
    .box.article
      .content
        img#Chief-Joseph(src='', alt='')
        h1.title Surrender Speech
        i.subtitle
          strong.author Chief Joseph
          | , October 5, 1877, Montana Territory
        p.text
          | Tell General Howard I know his heart. What he told me before, I have it in my heart. I am
          | tired of
          | fighting. Our Chiefs are killed; Looking Glass is dead, Ta Hool Hool Shute is dead. The old men are all
          | dead. It is the young men who say yes or no. He who led on the young men is dead. It is cold, and we have
          | no blankets; the little children are freezing to death. My people, some of them, have run away to the
          | hills, and have no blankets, no food. No one knows where they are – perhaps freezing to death. I want to
          | have time to look for my children, and see how many of them I can find. Maybe I shall find them among the
          | dead. Hear me, my Chiefs! I am tired; my heart is sick and sad. From where the sun now stands I will fight
          | no more forever.
    .box.article
      .content
        img#jfk(src='', alt='')
        h1.title Inauguration Address
        i.subtitle
          strong.author John F. Kennedy
          | , January 20, 1961, Washington, D.C.
        p.text
          | We’ve grown used to wonders in this century. It’s hard to dazzle us. But for 25 years the
          | United States
          | space program has been doing just that. We’ve grown used to the idea of space, and perhaps we forget that
          | we’ve only just begun. We’re still pioneers. They, the members of the Challenger crew, were pioneers.
          | And I want to say something to the school children of America who were watching the live coverage of the
          | shuttle’s takeoff. I know it is hard to understand, but sometimes painful things like this happen. It’s all
          | part of the process of exploration and discovery. It’s all part of taking a chance and expanding man’s
          | horizons. The future doesn’t belong to the fainthearted; it belongs to the brave. The Challenger crew was
          | pulling us into the future, and we’ll continue to follow them……
          | The crew of the space shuttle Challenger honoured us by the manner in which they lived their lives. We will
          | never forget them, nor the last time we saw them, this morning, as they prepared for the journey and waved
          | goodbye and ‘slipped the surly bonds of earth’ to ‘touch the face of God.’
    .box.article
      .content
        img#Alexander(src='', alt='')
        h1.title Speech of Alexander
        i.subtitle
          strong.author Alexander the Great
          | , 326 B.C., Hydaspes River, India
        p.text
          | I could not have blamed you for being the first to lose heart if I, your commander, had not
          | shared in your
          | exhausting marches and your perilous campaigns; it would have been natural enough if you had done all the
          | work merely for others to reap the reward. But it is not so. You and I, gentlemen, have shared the labour
          | and shared the danger, and the rewards are for us all. The conquered territory belongs to you; from your
          | ranks the governors of it are chosen; already the greater part of its treasure passes into your hands, and
          | when all Asia is overrun, then indeed I will go further than the mere satisfaction of our ambitions: the
          | utmost hopes of riches or power which each one of you cherishes will be far surpassed, and whoever wishes
          | to return home will be allowed to go, either with me or without me. I will make those who stay the envy of
          | those who return.
      script(async='', defer='', src='https://buttons.github.io/buttons.js')

              
            
!

CSS

              
                @import url("https://fonts.googleapis.com/css?family=UnifrakturCook:700");

/* ⬇ class for test purpose ⬇ */

.testShadow {
  box-shadow: 0 19px 38px rgba(0, 0, 0, 0.3), 0 15px 12px rgba(0, 0, 0, 0.22);
}

/* ⬇ code useful only for this pen ⬇ */

body {
  margin: 0;
  font-family: Georgia, serif;
}

hr {
  width: 70%;
}

button {
  display: block;
  margin: auto;
  border: none;
  padding: 10px 20px;
  border-radius: 3px;
  color: #444;
  font-size: 21px;
  cursor: pointer;
}

.wrapper {
  filter: brightness(10%);
  width: 100%;
  margin: 0;
  display: grid;
  grid-gap: 10px;
  grid-template-columns: 3fr 2fr;
  grid-template-rows: auto;
  grid-template-areas:
    "header header"
    "main sidebar"
    "article-container sidebar";
  background-color: #fff;
  color: #444;
}

.box {
  color: #444;
  padding: 20px;
}

.header {
  grid-area: header;
  text-align: center;
}

.header h1 {
  font-family: "UnifrakturCook", cursive;
  font-size: 48px;
  margin: 0;
}

#main-article {
  grid-area: main;
  border-right: 1px solid #999;
}

#main-article .content {
  padding: 0 20px;
  -webkit-columns: 150px 3;
  -moz-columns: 150px 3;
  columns: 150px 3;
}

aside .content {
  padding: 0 20px;
  -webkit-columns: 150px 2;
  -moz-columns: 150px 2;
  columns: 150px 2;
}

.sidebar {
  grid-area: sidebar;
}

.article-container {
  grid-area: article-container;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}

.content {
  margin: 40px 0 40px 0;
  font-family: Georgia, serif;
  font-weight: 400;
}

.main-article-image,
.The-luckiest-man,
.Demostenes,
#Chief-Joseph,
#jfk,
#Alexander {
  border-radius: 3px;
  display: block;
  margin: auto;
}

.git {
  margin: 20px;
}

.explain {
  opacity: 0.9;
  background: #444;
  color: #fff;
  position: fixed;
  max-width: 500px;
  max-height: 500px;
  padding: 30px;
  z-index: 999;
  border-radius: 3px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
  top: 50%;
  left: 50%;
  transition: transform 1s;
  transform: translate(-50%, -50%);
}

.explain h1,
.explain strong {
  color: palegoldenrod;
}

@media screen and (max-width: 960px) {
  .article-container {
    grid-template-columns: 1fr 1fr;
  }
}

@media screen and (max-width: 1024px) {
  .wrapper {
    grid-template-columns: auto;
    grid-template-areas:
      "header"
      "main"
      "sidebar"
      "article-container";
  }
}

              
            
!

JS

              
                // Scroll down for Debucsser configurations
// check out repo and docs at:
// https://github.com/lucagez/Debucsser

class Debucsser {
  constructor(props) {
    this.config = props || {};
    this.color = this.config.color || 'palevioletred';
    this.width = this.config.width || '3px';
    this.style = this.config.style || 'solid';
    this.customClass = this.config.customClass || null;
    this.grayscaleOnDebug = this.config.grayscaleOnDebug || false;
    this.grayscaleOnDebugAll = this.config.grayscaleOnDebugAll || false;
    this.string = `${this.width} ${this.style} ${this.color}`;
    this.mainKey = this.config.mainKey || 17;
    this.secondKey = this.config.secondKey || 16;
    this.init = this.init.bind(this);
    this.debug = this.debug.bind(this);
    this.debugAll = this.debugAll.bind(this);
    this.stop = this.stop.bind(this);
    this.addClass = this.addClass.bind(this);
    this.labels = this.labels.bind(this);
    this.createGlobalClass = this.createGlobalClass.bind(this);
    this.removeGlobalClass = this.removeGlobalClass.bind(this);
  }
  init() {
    // initialize invisible label element => we'll make it visible on selected keystroke
    this.label = document.createElement('div');
    this.label.classList.add('debucsser-label');
    this.label.style = 'display: none;';
    document.body.appendChild(this.label);

    this.inject_label_style();
    this.createDebugStyle();
    this.debug();
    this.globalStyle = this.createGlobalClass();
  }
  debug() {
    console.log(this);
    document.addEventListener('keydown', (key) => {
      if (key.keyCode == this.mainKey) {
        document.addEventListener('mousemove', this.labels, true);
        document.addEventListener('mouseover', this.addClass, true);
        document.addEventListener('keydown', this.debugAll, true);
      }
      this.stop();
    });
  }
  stop() {
    document.addEventListener('keyup', (key) => {
      if (key.keyCode == this.mainKey) {
        document.removeEventListener('mouseover', this.addClass, true);
        document.removeEventListener('mousemove', this.labels, true);
        this.label.style = 'display: none;';
      }
    })
  }
  addClass(over) {
    over.target.classList.add(this.customClass ? this.customClass : 'debucsser');
    document.addEventListener('mouseout', (out) => {
      out.target.classList.remove(this.customClass ? this.customClass : 'debucsser');
    }, true);
  }
  debugAll(key) {
    if (key.keyCode == this.secondKey) {
      document.body.appendChild(this.globalStyle);
      document.addEventListener('keyup', this.removeGlobalClass, true)
    }
  }
  createDebugStyle() {
    const style = document.createElement('style');
    style.innerHTML = `
      .debucsser {
        outline: ${this.string};
        ${this.config.grayscaleOnDebug && 'filter: grayscale(100%);'}
      }
    `;
    document.body.appendChild(style);
  }
  createGlobalClass() {
    const global = document.createElement('style');
    console.log(this.config.grayscaleOnDebugAll)
    global.innerHTML = `
      * {
        outline: ${this.string};
        ${this.config.grayscaleOnDebugAll && 'filter: grayscale(100%);'}
      }
    `;
    return global;
  }
  removeGlobalClass(key) {
    if (key.keyCode == this.secondKey) {
      document.body.removeChild(this.globalStyle);
    }
  }
  labels(e) {
    if (e.target) {
      const classList = e.target.classList ? e.target.classList.value.replace('debucsser', '') : undefined;
      const id = e.target.id ? '#' + e.target.id : undefined;
      const dimensions = e.target.getBoundingClientRect();
      this.label.innerHTML = `
        <h2>class: <strong>${classList || `¯\\_(ツ)_/¯`}</strong></h2>
        <h2>id: <strong>${id || `¯\\_(ツ)_/¯`}</strong></h2>
        <h2><strong>${dimensions.width.toFixed(0)}px</strong> × <strong>${dimensions.height.toFixed(0)}px</strong></h2>
      `;
      this.label.style = `display: block; top:${e.clientY + 20}px; left:${e.clientX + 20}px;`;
    } else {
      this.label.style = 'display: none;';
    }
  }
  inject_label_style() {
    const style = document.createElement('div');
    style.innerHTML = `
    <style>
      .debucsser-label {
        position: fixed; 
        font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
        padding: 10px 20px; 
        background: #333; 
        border-radius: 3px;
        color: #f9f9f9; 
        opacity: 0.9;
        z-index: 999;
      }
      .debucsser-label strong {
        color: palevioletred;
      }
    </style>`;
    document.body.appendChild(style);
  }
}

// init Debucsser

// comment out config properties to customize how Debucsser behave
const config = {
    // color: 'palevioletred',
    // width: '4px',
    // grayscaleOnDebugAll: true,
    // customClass: 'testShadow',
    }
const debug = new Debucsser(config).init();


// demo initial explanation
const explain = document.querySelector('.explain');
explain.querySelector('button').addEventListener('click', () => {
  explain.style.transform = 'translateX(2000px)';
  document.querySelector('.wrapper').style.filter = 'none';
});
              
            
!
999px

Console