@charset "UTF-8";

:root{
  --oj-bg:#0d1014;
  --oj-bg-deep:#080a0d;
  --oj-text:#f5f7fa;
  --oj-muted:rgba(245,247,250,.48);
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html,
body{
  min-height:100%;
  background:var(--oj-bg);
}

body{
  color:var(--oj-text);
  font-family:"Cormorant Garamond","Noto Serif JP",serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.oj-links-body{
  overflow-x:hidden;
}

/* =====================================================
  PAGE
===================================================== */

.oj-links-page{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;

  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.03), transparent 34%),
    linear-gradient(180deg, var(--oj-bg) 0%, var(--oj-bg-deep) 100%);

  opacity:0;
  transition:opacity 1.1s cubic-bezier(.22,.61,.36,1);
}

html.is-oj-links-ready .oj-links-page{
  opacity:1;
}

/* =====================================================
  GRAIN
===================================================== */

.oj-links-page::before{
  content:"";
  position:absolute;
  inset:-40%;
  z-index:1;
  pointer-events:none;

  background-image:
    radial-gradient(circle, rgba(255,255,255,.025) 1px, transparent 1px);

  background-size:3px 3px;

  opacity:.14;
  mix-blend-mode:soft-light;
  animation:grain 1.6s steps(2,end) infinite;
}

@keyframes grain{
  0%{transform:translate(0,0)}
  50%{transform:translate(-2%,2%)}
  100%{transform:translate(0,0)}
}

/* =====================================================
  INNER
===================================================== */

.oj-links-inner{
  position:relative;
  z-index:3;

  width:240px;

  display:flex;
  flex-direction:column;
  align-items:center;

  padding:20px;
}

/* =====================================================
  LOGO
===================================================== */

.oj-links-logo{
  width:100%;
  text-align:center;
  margin-bottom:24px;

  opacity:0;
  transform:translateY(6px);

  transition:all 1s cubic-bezier(.22,.61,.36,1);
}

html.is-oj-links-ready .oj-links-logo{
  opacity:1;
  transform:translateY(0);
}

.oj-links-logo img{
  width:78px;
  opacity:.86;
}

/* =====================================================
  TITLE
===================================================== */

.oj-links-title{
  width:100%;

  font-size:14px;
  letter-spacing:.14em;
  line-height:1;

  margin-bottom:22px;

  color:var(--oj-muted);
  text-align:center;

  opacity:0;
  transform:translateY(6px);

  transition:all 1s cubic-bezier(.22,.61,.36,1) .1s;
}

html.is-oj-links-ready .oj-links-title{
  opacity:1;
  transform:translateY(0);
}

/* =====================================================
  LINKS
===================================================== */

.oj-links-list{
  width:100%;
  list-style:none;

  opacity:0;
  transform:translateY(8px);

  transition:all 1s cubic-bezier(.22,.61,.36,1) .2s;
}

html.is-oj-links-ready .oj-links-list{
  opacity:1;
  transform:translateY(0);
}

.oj-links-item{
  width:100%;
}

.oj-links-item a{
  display:block;
  width:100%;

  padding:13px 0;

  color:var(--oj-text);
  text-decoration:none;

  font-size:14px;
  letter-spacing:.18em;
  line-height:1;
  text-align:left;

  transition:opacity .4s ease;
}

.oj-links-item a:hover{
  opacity:.78;
}

/* =====================================================
  SP
===================================================== */

@media (max-width:640px){

  .oj-links-inner{
    width:220px;
    padding:20px;
  }

  .oj-links-logo img{
    width:68px;
  }

  .oj-links-title,
  .oj-links-item a{
    font-size:12.6px;
  }

}

/* =====================================================
  SELECTION
===================================================== */

::selection{
  background:rgba(180,180,180,.18);
  color:#f5f7fa;
}

::-moz-selection{
  background:rgba(180,180,180,.18);
  color:#f5f7fa;
}


.oj-links-list{
  width:100%;
  padding-left:34px;
}