@charset "UTF-8";
/*
Theme Name: Extraperlo21
Theme URI: https://www.davidpenuela.com
Author: David Penuela
Author URI: https://www.davidpenuela.com.com
Description:  🏗 Website for Jorge Penadés, 2021
Version: 0.1

*/
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0; }

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent; }

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  /* 2 */ }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; }

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline; }

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */ }

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none; }

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none; }

/************************************************************************************
*******************    UTILS                                *************************
*************************************************************************************/
/**
 * Removes the scroll bar
 *
 * Usage:
 * .selector {
 *   @include remove-scrollbar;
 * }
 */
/************************************************************************************
*******************    VARIABLES                            *************************
*************************************************************************************/
/**
 * Typography
 */
/*https://snook.ca/archives/html_and_css/font-size-with-rem*/
/**
 * Colors
 */
/**
 * Transitions
 */
/**
 * margin, padding, widths column
 */
/************************************************************************************
*******************    BREAKPOINTS                          *************************
*************************************************************************************/
/************************************************************************************
*******************    CLEARFIX                             *************************
*************************************************************************************/
.clear:before, .clear:after {
  content: ' ';
  display: table; }

.clear {
  *zoom: 1; }
  .clear:after {
    clear: both; }

/************************************************************************************
*******************    DEFAULTS                             *************************
*************************************************************************************/
* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none; }

html,
body {
  font-family: "C-Std", Helvetica, sans-serif;
  font-size: 62.5%;
  line-height: 1.5;
  color: black;
  background-color: transparent;
  margin: 0;
  padding: 0;
  width: 120%;
  min-height: 100%;
  height: auto;
  position: relative;
  background-color: white;
  background-color: black; }
  @media (min-width: 768px) {
    html,
    body {
      width: 100%; } }

h1,
h2,
h3,
h4 {
  font-weight: normal;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

::-moz-selection {
  background: transparent;
  color: black;
  text-shadow: none; }

::selection {
  background: transparent;
  color: black;
  text-shadow: none; }

::-moz-selection {
  background: transparent;
  color: black;
  text-shadow: none; }

::-webkit-selection {
  background: transparent;
  color: black;
  text-shadow: none; }

ul {
  margin: 0;
  padding: 0; }
  ul li {
    list-style: none;
    margin: 0;
    padding: 0; }

a:link, a:visited, a:active {
  color: black;
  text-decoration: none; }

a:hover {
  text-decoration: none; }

body footer,
body header {
  opacity: 1;
  -webkit-transition: all 300ms ease-in-out;
  transition: all 300ms ease-in-out; }

body.showing-info footer,
body.showing-info header {
  opacity: 0;
  pointer-events: none;
  -ms-touch-action: none;
      touch-action: none; }

body.showing-info .grid-names-single:not(.active) .name {
  display: none; }

body.showing-info .grid-names-single:not(.active) .short-text {
  display: none; }

@media (min-width: 768px) {
  body.showing-info .grid-names-single.active .name {
    display: none; } }

/************************************************************************************
*******************    ANIMATION                            *************************
*************************************************************************************/
@-webkit-keyframes glow {
  10% {
    opacity: 1; }
  15% {
    opacity: 0; }
  20% {
    opacity: 1; }
  25% {
    opacity: 0; }
  30% {
    opacity: 1; }
  90% {
    opacity: 1; }
  100% {
    opacity: 1; } }
@keyframes glow {
  10% {
    opacity: 1; }
  15% {
    opacity: 0; }
  20% {
    opacity: 1; }
  25% {
    opacity: 0; }
  30% {
    opacity: 1; }
  90% {
    opacity: 1; }
  100% {
    opacity: 1; } }

@-webkit-keyframes spotlight_rotate {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg); }
  50% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg); }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg); } }

@keyframes spotlight_rotate {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg); }
  50% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg); }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg); } }

/************************************************************************************
*******************    HEADER                               *************************
*************************************************************************************/
header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  text-transform: uppercase;
  padding: 30vh 4vmin 0;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  text-align: left; }
  header .header-logo svg {
    width: auto;
    height: 1.3em; }
    @media (min-width: 768px) {
      header .header-logo svg {
        height: 1em; } }
  @media (min-width: 768px) {
    header .header-logo {
      margin-top: 0; } }
  header .header-nav {
    padding-bottom: 25vh;
    text-align: right; }
    header .header-nav span,
    header .header-nav a {
      display: inline-block;
      margin-right: 4rem; }
      header .header-nav span:last-child,
      header .header-nav a:last-child {
        margin-right: 0; }
      header .header-nav span:hover,
      header .header-nav a:hover {
        font-style: italic;
        cursor: pointer; }
    @media (min-width: 768px) {
      header .header-nav {
        padding-bottom: 0; } }
  @media (min-width: 768px) {
    header {
      padding: 4vmin 5vmin 0;
      -webkit-box-orient: horizontal;
      -webkit-box-direction: normal;
          -ms-flex-direction: row;
              flex-direction: row;
      text-align: left; } }

/************************************************************************************
*******************    NAVIGATION                           *************************
*************************************************************************************/
/************************************************************************************
*******************    MAIN                                 *************************
*************************************************************************************/
main {
  position: relative;
  z-index: 2;
  min-height: 100vh;
  padding: 4vmin; }
  @media (min-width: 768px) {
    main {
      padding: 5vmin;
      height: 100vh; } }

/************************************************************************************
*******************    FOOTER                               *************************
*************************************************************************************/
footer {
  position: relative;
  z-index: 2;
  padding: 0 0 35vh 4vmin; }
  footer .footer-info {
    text-transform: uppercase;
    display: inline-block; }
    footer .footer-info p {
      margin: 0.5em 0; }
      footer .footer-info p:last-child {
        margin-bottom: 0; }
  footer .footer-mobile-line {
    margin: 40vh 0 0; }
    @media (min-width: 768px) {
      footer .footer-mobile-line {
        display: none; } }
  @media (min-width: 768px) {
    footer {
      position: absolute;
      bottom: 0;
      left: 0;
      padding: 0 0 4vmin 5vmin; } }

/************************************************************************************
*******************    SPOTLIGHT                            *************************
*************************************************************************************/
.spotlight {
  position: fixed;
  z-index: 1;
  width: 100vw;
  height: 100vh;
  top: 0em;
  left: 0em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  opacity: 0; }
  .spotlight.active {
    -webkit-animation: glow 1s linear forwards;
            animation: glow 1s linear forwards; }
  @media (min-width: 768px) {
    .spotlight {
      width: 30vw;
      height: 30vw;
      top: 5em;
      left: 3em;
      -webkit-transform: translateX(-50%) translateY(-50%);
              transform: translateX(-50%) translateY(-50%);
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; } }

.noise {
  position: absolute;
  top: 40%;
  left: 50%;
  -webkit-transform: translate3d(-50%, -50%, 0);
          transform: translate3d(-50%, -50%, 0);
  width: 120%;
  height: 120%;
  background: radial-gradient(circle at 50% 50%, black, rgba(0, 0, 0, 0)), url("data:image/svg+xml,%3Csvg viewBox='0 0 600 600' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
  -webkit-filter: contrast(125%) brightness(500%) invert(100%) grayscale(100%);
          filter: contrast(125%) brightness(500%) invert(100%) grayscale(100%);
  mix-blend-mode: exclusion; }
  @media (min-width: 768px) {
    .noise {
      position: unset;
      top: unset;
      left: unset;
      -webkit-transform: unset;
              transform: unset; } }

.center {
  position: absolute;
  top: 40%;
  left: 50%;
  width: 100vw;
  height: 100vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 50%;
  -webkit-transform: translate3d(-50%, -50%, 0);
          transform: translate3d(-50%, -50%, 0);
  background-color: white;
  -webkit-box-shadow: 0 0 1rem 2rem white;
          box-shadow: 0 0 1rem 2rem white; }
  @media (min-width: 768px) {
    .center {
      top: 50%;
      left: 50%;
      width: 60%;
      height: 60%;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; } }

.circle {
  width: 80vw;
  height: 80vw; }
  @media (min-width: 768px) {
    .circle {
      width: 40%;
      height: 40%; } }

/************************************************************************************
*******************    ABOUT                                 *************************
*************************************************************************************/
/************************************************************************************
*******************    FOR INFO AND ABOUT                    *************************
*************************************************************************************/
.s-text {
  position: fixed;
  z-index: 1;
  padding: 30vh 4vmin 40vh;
  width: 100vw;
  height: 100vh;
  top: 0;
  left: 0;
  display: none;
  overflow: scroll; }
  .s-text.active .s-text-inside {
    opacity: 1; }
  .s-text .s-text-inside {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    -webkit-column-gap: 4rem;
       -moz-column-gap: 4rem;
            column-gap: 4rem;
    width: 140%;
    height: auto;
    -webkit-transition: opacity 300ms ease-in-out;
    transition: opacity 300ms ease-in-out;
    opacity: 0; }
    .s-text .s-text-inside .s-text-inside-main {
      grid-row: 1;
      margin-bottom: 7rem;
      overflow: scroll; }
      .s-text .s-text-inside .s-text-inside-main::-webkit-scrollbar {
        width: 0px;
        background: transparent; }
      .s-text .s-text-inside .s-text-inside-main * {
        -ms-overflow-style: none !important; }
      .s-text .s-text-inside .s-text-inside-main::-webkit-scrollbar {
        width: 0; }
      .s-text .s-text-inside .s-text-inside-main::-webkit-scrollbar-track {
        -webkit-box-shadow: none;
                box-shadow: none;
        border-radius: 0; }
      .s-text .s-text-inside .s-text-inside-main::-webkit-scrollbar-thumb {
        border-radius: 0;
        background-color: transparent; }
      .s-text .s-text-inside .s-text-inside-main .s-text-inside-main-container {
        padding: 2.5vmin 0; }
      .s-text .s-text-inside .s-text-inside-main p {
        margin-top: 0; }
        .s-text .s-text-inside .s-text-inside-main p span.p_i_close,
        .s-text .s-text-inside .s-text-inside-main p span.p_a_close {
          font-style: italic;
          margin-left: 2rem; }
          @media (min-width: 768px) {
            .s-text .s-text-inside .s-text-inside-main p span.p_i_close,
            .s-text .s-text-inside .s-text-inside-main p span.p_a_close {
              margin-top: 0.7em;
              margin-left: 4rem;
              font-style: normal;
              cursor: pointer; }
              .s-text .s-text-inside .s-text-inside-main p span.p_i_close:hover,
              .s-text .s-text-inside .s-text-inside-main p span.p_a_close:hover {
                font-style: italic; } }
        .s-text .s-text-inside .s-text-inside-main p:last-child {
          margin-bottom: 0; }
      @media (min-width: 768px) {
        .s-text .s-text-inside .s-text-inside-main {
          padding-top: 0;
          grid-column: 3 / span 5;
          grid-row: 1;
          height: 100%;
          margin-bottom: 0; } }
    .s-text .s-text-inside .s-text-small {
      grid-row: 2;
      padding: 0 0 4vmin; }
      .s-text .s-text-inside .s-text-small p:last-child {
        margin-bottom: 0; }
      @media (min-width: 768px) {
        .s-text .s-text-inside .s-text-small p {
          max-width: 40rem; } }
      @media (min-width: 768px) {
        .s-text .s-text-inside .s-text-small {
          grid-column: 1 / span 2;
          grid-row: 1;
          align-self: end; } }
    @media (min-width: 768px) {
      .s-text .s-text-inside {
        grid-template-columns: repeat(7, 1fr);
        height: 100%;
        width: 100%; } }
  @media (min-width: 768px) {
    .s-text {
      padding: 0 5vmin;
      width: 100vw;
      height: 100vh;
      overflow: hidden; } }

.s-about .s-about-small {
  grid-row: 2;
  padding: 0 0 4vmin; }
  .s-about .s-about-small p:last-child {
    margin-bottom: 0; }
  @media (min-width: 768px) {
    .s-about .s-about-small p {
      max-width: 40rem; } }
  @media (min-width: 768px) {
    .s-about .s-about-small {
      grid-column: 1 / span 2;
      grid-row: 1;
      align-self: end; } }

/************************************************************************************
*******************    FRONT PAGE                           *************************
*************************************************************************************/
.p-front-page {
  width: 100%;
  height: 100%;
  padding: 4vmin 0; }
  @media (min-width: 768px) {
    .p-front-page {
      padding: 5vmin 0; } }

.grid-names {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-template-rows: 2em;
  row-gap: 1.8em;
  -webkit-column-gap: 4rem;
     -moz-column-gap: 4rem;
          column-gap: 4rem;
  margin: 100vh 0 85vw; }
  .grid-names .grid-names-single {
    position: relative; }
    @media (max-width: 767.98px) {
      .grid-names .grid-names-single {
        grid-column: 1 / -1;
        grid-column: 1; }
        .grid-names .grid-names-single .name {
          float: left; }
        .grid-names .grid-names-single:nth-child(2n) .name {
          float: right; }
        .grid-names .grid-names-single.active .name {
          display: none; } }
    .grid-names .grid-names-single .name {
      position: relative;
      z-index: 2; }
      .grid-names .grid-names-single .name.clickable-name span {
        font-style: italic; }
        @media (min-width: 768px) {
          .grid-names .grid-names-single .name.clickable-name span {
            font-style: normal; }
            .grid-names .grid-names-single .name.clickable-name span:hover {
              font-style: italic;
              cursor: pointer; } }
    .grid-names .grid-names-single .short-text {
      display: none;
      position: absolute;
      top: 0;
      left: 0; }
      .grid-names .grid-names-single .short-text .short-text-text {
        display: inline-block; }
        .grid-names .grid-names-single .short-text .short-text-text p span.p_close {
          font-style: italic;
          margin-left: 2em;
          display: inline-block; }
          @media (min-width: 768px) {
            .grid-names .grid-names-single .short-text .short-text-text p span.p_close {
              margin-top: 0.7em;
              margin-left: 4rem;
              font-style: normal;
              cursor: pointer; }
              .grid-names .grid-names-single .short-text .short-text-text p span.p_close:hover {
                font-style: italic; } }
      @media (min-width: 768px) {
        .grid-names .grid-names-single .short-text {
          position: fixed;
          top: 50%;
          left: 50%;
          width: 71.42857%;
          padding: 0 4vmin;
          max-width: 90vw;
          -webkit-transform: translate3d(-50%, -50%, 0);
                  transform: translate3d(-50%, -50%, 0); } }
      @media (min-width: 992px) {
        .grid-names .grid-names-single .short-text {
          max-width: 120rem;
          padding: 0 5vmin; } }
  .grid-names.v0 .n1 {
    grid-row: 1; }
    @media (min-width: 768px) {
      .grid-names.v0 .n1 {
        grid-column: 5 / span 3;
        grid-row: auto; } }
    @media (min-width: 992px) {
      .grid-names.v0 .n1 {
        grid-column: 5 / span 3; } }
  .grid-names.v0 .n2 {
    grid-row: 2 / span 1; }
    @media (min-width: 768px) {
      .grid-names.v0 .n2 {
        grid-column: 6 / span 2;
        grid-row: 3 / span 1; } }
  .grid-names.v0 .n3 {
    grid-row: 3 / span 1; }
    @media (min-width: 768px) {
      .grid-names.v0 .n3 {
        grid-column: 3 / span 4;
        grid-row: auto; } }
  .grid-names.v0 .n4 {
    grid-row: 4 / span 1; }
    @media (min-width: 768px) {
      .grid-names.v0 .n4 {
        grid-column: 1 / span 2;
        grid-row: 3 / span 1; } }
  .grid-names.v0 .n5 {
    grid-row: 5 / span 1; }
    @media (min-width: 768px) {
      .grid-names.v0 .n5 {
        grid-column: 5 / span 2;
        grid-row: 1 / span 1; } }
  .grid-names.v0 .n6 {
    grid-row: 6 / span 1; }
    @media (min-width: 768px) {
      .grid-names.v0 .n6 {
        grid-column: 2 / span 2;
        grid-row: 2 / span 1; } }
  .grid-names.v0 .n7 {
    grid-row: 7 / span 1; }
    @media (min-width: 768px) {
      .grid-names.v0 .n7 {
        grid-column: 4 / span 2;
        grid-row: 2 / span 1; } }
  .grid-names.v1 .n1 {
    grid-row: 7; }
    @media (min-width: 768px) {
      .grid-names.v1 .n1 {
        grid-row: 3;
        grid-column: 2 / span 3; } }
  .grid-names.v1 .n2 {
    grid-row: 6; }
    @media (min-width: 768px) {
      .grid-names.v1 .n2 {
        grid-column: 3 / span 2;
        grid-row: 1 / span 1; } }
  .grid-names.v1 .n3 {
    grid-row: 5; }
    @media (min-width: 768px) {
      .grid-names.v1 .n3 {
        grid-row: 2;
        grid-column: 4 / span 4; } }
  .grid-names.v1 .n4 {
    grid-row: 4; }
    @media (min-width: 768px) {
      .grid-names.v1 .n4 {
        grid-row: 4;
        grid-column: 3 / span 2; } }
  .grid-names.v1 .n5 {
    grid-row: 3; }
    @media (min-width: 768px) {
      .grid-names.v1 .n5 {
        grid-column: 5 / span 2;
        grid-row: 5 / span 1; } }
  .grid-names.v1 .n6 {
    grid-row: 2; }
    @media (min-width: 768px) {
      .grid-names.v1 .n6 {
        grid-column: 6 / span 2;
        grid-row: 3 / span 1; } }
  .grid-names.v1 .n7 {
    grid-row: 1; }
    @media (min-width: 768px) {
      .grid-names.v1 .n7 {
        grid-column: 1 / span 2;
        grid-row: 2 / span 1; } }
  .grid-names.v2 .n1 {
    grid-row: 3; }
    @media (min-width: 768px) {
      .grid-names.v2 .n1 {
        grid-column: 1 / span 3;
        grid-row: 2 / span 1; } }
  .grid-names.v2 .n2 {
    grid-row: 6; }
    @media (min-width: 768px) {
      .grid-names.v2 .n2 {
        grid-column: 6 / span 2;
        grid-row: 1 / span 1; } }
  .grid-names.v2 .n3 {
    grid-row: 1; }
    @media (min-width: 768px) {
      .grid-names.v2 .n3 {
        grid-column: 2 / span 4;
        grid-row: 1 / span 1; } }
  .grid-names.v2 .n4 {
    grid-row: 2; }
    @media (min-width: 768px) {
      .grid-names.v2 .n4 {
        grid-column: 5 / span 2;
        grid-row: 3 / span 1; } }
  .grid-names.v2 .n5 {
    grid-row: 5; }
    @media (min-width: 768px) {
      .grid-names.v2 .n5 {
        grid-column: 3 / span 2;
        grid-row: 4 / span 1; } }
  .grid-names.v2 .n6 {
    grid-row: 4; }
    @media (min-width: 768px) {
      .grid-names.v2 .n6 {
        grid-column: 4 / span 2;
        grid-row: 5 / span 1; } }
  .grid-names.v2 .n7 {
    grid-row: 7; }
    @media (min-width: 768px) {
      .grid-names.v2 .n7 {
        grid-column: 6 / span 2;
        grid-row: 4 / span 1; } }
  @media (min-width: 768px) {
    .grid-names {
      display: grid;
      grid-template-columns: repeat(7, 1fr);
      grid-template-rows: repeat(5, 1fr);
      row-gap: 2rem;
      -webkit-column-gap: 4rem;
         -moz-column-gap: 4rem;
              column-gap: 4rem;
      margin: 0; } }

/************************************************************************************
*******************    TYPOGRAPHY IMPORT                      ***********************
*************************************************************************************/
@font-face {
  font-family: "C-Std";
  src: url("/wp-content/themes/Extraperlo21/fonts/CircularStd-Medium.woff") format("woff");
  font-weight: 300;
  font-style: normal; }

@font-face {
  font-family: "C-Std";
  src: url("/wp-content/themes/Extraperlo21/fonts/CircularStd-MediumItalic.woff") format("woff");
  font-weight: 300;
  font-style: italic; }

/************************************************************************************
*******************    TYPOGRAPHY                           *************************
*************************************************************************************/
body {
  font-size: 1.5rem;
  line-height: 1.2; }
  @media (min-width: 768px) {
    body {
      font-size: 1.6vmin; } }
  @media (min-width: 1200px) {
    body {
      font-size: 1.9vmin; } }
  @media (min-width: 1500px) {
    body {
      font-size: 1.8rem; } }

.s-text-inside-main p,
.short-text-text p {
  margin: 0 0 0.5em; }
  .s-text-inside-main p:last-child,
  .short-text-text p:last-child {
    margin-top: 0.5em; }
    .s-text-inside-main p:last-child::after:hover,
    .short-text-text p:last-child::after:hover {
      font-style: italic; }

.short-text-text p span.p_close,
.s-text-inside-main p span.p_a_close,
.s-text-inside-main p span.p_i_close {
  font-size: 3rem;
  line-height: 1.2; }
  @media (min-width: 768px) {
    .short-text-text p span.p_close,
    .s-text-inside-main p span.p_a_close,
    .s-text-inside-main p span.p_i_close {
      font-size: 0.5em; } }

sup {
  vertical-align: middle;
  font-size: 0.6em;
  padding-left: 0.1em; }

header {
  line-height: 0.9; }

.grid-names {
  font-size: 17vw;
  line-height: 1.1; }
  @media (min-width: 768px) {
    .grid-names {
      font-size: 5vmin; } }
  @media (min-width: 1200px) {
    .grid-names {
      font-size: 6vmin; } }
  @media (min-width: 1500px) {
    .grid-names {
      font-size: 6.2rem; } }
  @media (max-width: 767.98px) {
    .grid-names .short-text-text {
      font-size: 4.8rem; } }

footer .footer-mobile-line {
  font-size: 0.8em;
  padding-left: 0.1em;
  text-align: center; }

/*****************************************
*****    ABOUT            **************
******************************************/
.s-text .s-text-inside-main {
  font-size: 4.8rem;
  line-height: 1.1; }
  @media (min-width: 768px) {
    .s-text .s-text-inside-main {
      font-size: 5vmin; } }
  @media (min-width: 1200px) {
    .s-text .s-text-inside-main {
      font-size: 6vmin; } }
  @media (min-width: 1500px) {
    .s-text .s-text-inside-main {
      font-size: 6.2rem; } }

/*****************************************
*****    GENERAL            **************
******************************************/
/************************************************************************************
******************* EXTERNAL *************************
*************************************************************************************/
.grid-columns {
  position: fixed;
  background-color: red;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  pointer-events: none;
  -ms-touch-action: none;
      touch-action: none;
  z-index: 9999999;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-column-gap: 4vmin;
  padding: 4vmin;
  margin: 0 auto;
  opacity: 0; }
  .grid-columns .grid-columns-column {
    background-color: blue;
    height: 100%;
    display: none; }
    .grid-columns .grid-columns-column:nth-child(1), .grid-columns .grid-columns-column:nth-child(2), .grid-columns .grid-columns-column:nth-child(3) {
      display: block; }
    @media (min-width: 768px) {
      .grid-columns .grid-columns-column {
        display: block; } }
  .grid-columns.active {
    opacity: 0.4; }
  @media (min-width: 768px) {
    .grid-columns {
      grid-template-columns: repeat(7, 1fr);
      grid-column-gap: 4rem;
      padding: 5vmin; } }

.debug-resolutions {
  position: fixed;
  left: 0;
  top: 0;
  background-color: black;
  color: #5df4ff;
  padding: 3rem;
  font-family: "Helvetica", serif;
  font-size: 2rem;
  line-height: 1.3;
  z-index: 99999;
  opacity: 0;
  pointer-events: none;
  -ms-touch-action: none;
      touch-action: none; }
  .debug-resolutions.active {
    opacity: 1; }
  .debug-resolutions .debug-resolution-type {
    display: none; }
  @media (max-width: 575.98px) {
    .debug-resolutions .debug-resolution-type-xs {
      display: block; } }
  @media (min-width: 576px) and (max-width: 767.98px) {
    .debug-resolutions .debug-resolution-type-sm {
      display: block; } }
  @media (min-width: 768px) and (max-width: 991.98px) {
    .debug-resolutions .debug-resolution-type-md {
      display: block; } }
  @media (min-width: 992px) and (max-width: 1199.98px) {
    .debug-resolutions .debug-resolution-type-lg {
      display: block; } }
  @media (min-width: 1200px) and (max-width: 1499.98px) {
    .debug-resolutions .debug-resolution-type-xl {
      display: block; } }
  @media (min-width: 1500px) {
    .debug-resolutions .debug-resolution-type-xxl {
      display: block; } }
