.jn20 {
--jn-bg:        #0a1830; --jn-bg-deep:   #06122a; --jn-hero-bg:   #03101e; --jn-glow:      #0a3a6e;
--jn-glow-soft: #143a78;
--jn-gold:      #f2b451;
--jn-gold-line: #d6b15e;
--jn-white:     #ffffff;
--jn-sub:       #cfd8ec;
--jn-card:      #0f2750; --jn-card-bd:   rgba(214,177,94,.35);
--jn-ff-min:    "Shippori Mincho B1", "Noto Serif JP", serif;
--jn-ff-sans:   "Noto Sans JP", sans-serif;
} .jn20 *,
.jn20 *::before,
.jn20 *::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
.jn20 img {
max-width: 100%;
height: auto;
display: block;
}
.jn20 svg {
max-width: none;
}
.jn20 ul,
.jn20 ol {
list-style: none;
}
.jn20 a {
color: inherit;
text-decoration: none;
} .jn20 {
font-family: var(--jn-ff-sans);
color: var(--jn-white);
background: var(--jn-bg);
line-height: 1.75;
overflow-x: hidden;
width: 100%;
} .jn20-hero {
position: relative;
min-height: clamp(560px, 68svh, 780px);
background-color: var(--jn-hero-bg); background-image: url(//mmin-net.co.jp/jinny/wp-content/themes/robodachi/assets/images/application/hero-night.webp);
background-size: cover;
background-position: right center; display: flex;
align-items: flex-end;
overflow: hidden;
} .jn20-hero::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(
100deg,
rgba(0,3,12,.72) 0%,
rgba(0,3,12,.45) 55%,
rgba(0,3,12,.05) 100%
);
pointer-events: none;
z-index: 0;
} .admin-bar .jn20-hero {
padding-top: 32px;
}
@media (max-width: 782px) {
.admin-bar .jn20-hero {
padding-top: 46px;
}
} .jn20-hero__text {
position: relative;
z-index: 1;
padding: 80px 40px 96px 72px;
max-width: 640px;
}
.jn20-hero__sub {
font-family: var(--jn-ff-min);
font-size: clamp(.85rem, 1.6vw, 1.05rem);
font-weight: 600;
color: var(--jn-sub);
letter-spacing: .08em;
text-shadow: 0 0 16px rgba(60,120,255,.5);
margin-bottom: .6em;
}
.jn20-hero__h1 {
font-family: var(--jn-ff-min);
font-size: clamp(48px, 6.5vw, 92px);
font-weight: 700;
line-height: 1.1;
letter-spacing: .04em;
text-shadow: 0 0 24px rgba(80,140,255,.45), 0 2px 8px rgba(0,0,0,.7);
} .jn20-hero__brand {
display: flex;
align-items: flex-end; flex-wrap: wrap; gap: clamp(8px, 1.4vw, 18px);
}
.jn20-hero__brand-logo {
width: clamp(220px, 30vw, 420px);
height: auto;
display: block; filter: drop-shadow(0 0 20px rgba(80,140,255,.4))
drop-shadow(0 2px 8px rgba(0,0,0,.65));
}
.jn20-hero__brand-num {
color: var(--jn-gold);
font-size: clamp(26px, 3.5vw, 50px); line-height: 1;
} .jn20-hero__tagline {
display: block;
font-size: clamp(24px, 3.2vw, 40px);
margin-top: .25em;
color: var(--jn-white);
} .jn20-hero__lockup {
position: absolute;
top: 24px;
right: 28px;
z-index: 2;
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 4px;
}
.jn20-hero__lockup-logo {
width: clamp(100px, 14vw, 180px);
height: auto;
}
.jn20-hero__lockup-num {
font-family: var(--jn-ff-min);
font-size: clamp(1.4rem, 2.8vw, 2.2rem);
font-weight: 700;
color: var(--jn-gold);
letter-spacing: .05em;
text-shadow: 0 0 12px rgba(242,180,81,.5);
line-height: 1;
}
.jn20-hero__lockup-sub {
font-family: var(--jn-ff-sans);
font-size: clamp(.8rem, 1.35vw, 1.05rem); font-weight: 700; color: rgba(255, 255, 255, .95); letter-spacing: .08em;
text-shadow: 0 1px 6px rgba(0, 0, 0, .55); white-space: nowrap; } .jn20-section {
background: var(--jn-bg);
padding: 80px 0;
}
.jn20-inner {
max-width: 1080px;
margin: 0 auto;
padding: 0 40px;
} .jn20-value {
background: var(--jn-bg);
padding: 80px 0 60px;
} .jn20-value__grid {
display: grid;
grid-template-columns: 45fr 55fr;
gap: 48px;
align-items: start;
}
.jn20-value__left { }
.jn20-value__right { position: relative;
} .jn20-value__h2 {
font-family: var(--jn-ff-min);
font-size: clamp(1.65rem, 3vw, 2.45rem);
font-weight: 700;
line-height: 1.35;
letter-spacing: .03em;
margin-bottom: 1em;
word-break: keep-all;
overflow-wrap: break-word;
}
.jn20-value__h2-white {
color: var(--jn-white);
}
.jn20-value__h2-gold {
color: var(--jn-gold);
} .jn20-value__lead {
font-family: var(--jn-ff-sans); font-size: clamp(1rem, 1.4vw, 1.125rem);
color: var(--jn-sub);
line-height: 1.9;
margin-bottom: 2.5em;
} .jn20-cards {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 12px;
margin-bottom: 0;
}
.jn20-card {
background: var(--jn-card);
border: 1px solid var(--jn-card-bd);
border-radius: 8px;
padding: 24px 16px 20px;
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 12px;
}
.jn20-card__icon {
width: 44px;
height: 44px;
flex-shrink: 0;
}
.jn20-card__h3 {
font-family: var(--jn-ff-min);
font-size: .95rem;
font-weight: 700;
color: var(--jn-gold);
letter-spacing: .04em;
}
.jn20-card__p {
font-family: var(--jn-ff-sans); font-size: clamp(1rem, 1.2vw, 1.0625rem);
color: var(--jn-sub);
line-height: 1.8;
}  .jn20-value__right {
display: flex;
align-items: center;
justify-content: center;
}
.jn20-diagram {
position: relative;
width: 100%;
aspect-ratio: 1 / 1;
max-width: 540px;
} .jn20-diagram[role="img"] { } .jn20-diagram__svg {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
z-index: 0;
pointer-events: none;
overflow: visible;
} .jn20-diagram__center {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
z-index: 2;
text-align: center;
width: 170px;
height: 170px;
border-radius: 50%;
background: #0f2750; border: 2px solid var(--jn-gold-line);
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 2px;
pointer-events: none;
}
.jn20-diagram__center-main {
font-family: var(--jn-ff-min);
font-size: clamp(1.15rem, 2.8vw, 1.55rem);
font-weight: 700;
line-height: 1.1;
color: var(--jn-white);
letter-spacing: .05em;
}
.jn20-diagram__center-main .jn20-gold {
color: var(--jn-gold);
}
.jn20-diagram__center-sub1 {
font-family: var(--jn-ff-sans); font-size: .75rem;
color: var(--jn-sub);
margin-top: .35em;
line-height: 1.5;
}
.jn20-diagram__center-sub2 {
font-family: var(--jn-ff-min); font-size: .75rem;
font-weight: 600;
color: var(--jn-gold);
line-height: 1.5;
} .jn20-diagram__nodes {
position: absolute;
inset: 0;
z-index: 2;
pointer-events: none;
}
.jn20-node {
position: absolute;
pointer-events: auto;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 2px;
text-align: center;
width: 152px;
height: 152px;
border-radius: 50%;
background: #0f2750; border: 2px solid var(--jn-gold-line); padding: 12px 16px;
} .jn20-node--tl {
top: 3%;
left: 1%;
} .jn20-node--tr {
top: 3%;
right: 1%;
} .jn20-node--bl {
bottom: 3%;
left: 1%;
} .jn20-node--br {
bottom: 3%;
right: 1%;
}
.jn20-node__icon {
width: 24px;
height: 24px;
flex-shrink: 0;
}
.jn20-node__h3 {
font-family: var(--jn-ff-min); font-size: clamp(.75rem, .95vw, .8rem);
font-weight: 700;
color: var(--jn-gold);
letter-spacing: .02em;
line-height: 1.2;
}
.jn20-node__p {
font-family: var(--jn-ff-sans); font-size: .75rem;
color: var(--jn-sub);
line-height: 1.4;
} @media (max-width: 959px) { .jn20-value__grid { grid-template-columns: 1fr; gap: 40px; } .jn20-value__right {
flex-direction: column;
align-items: stretch;
justify-content: flex-start;
}
.jn20-diagram {
aspect-ratio: unset;
max-width: 100%;
min-height: unset;
height: auto;
position: static;
display: block;
background: transparent;
border: none;
width: auto;
}
.jn20-diagram__svg {
display: none;
}
.jn20-diagram__center {
display: none; }
.jn20-diagram__nodes {
position: static;
display: grid;
grid-template-columns: 1fr 1fr;
gap: 16px;
pointer-events: auto;
}
.jn20-node {
position: static;
width: 100%;
height: auto;
border-radius: 8px;
align-items: flex-start;
text-align: left;
background: var(--jn-card);
border: 1px solid var(--jn-card-bd);
padding: 20px 16px;
}
.jn20-node--tr,
.jn20-node--br {
align-items: flex-start;
text-align: left;
}
.jn20-node__p {
font-size: .75rem;
}
} .jn20-diagram-sp-title {
display: none;
text-align: center;
margin-bottom: 24px;
}
.jn20-diagram-sp-title .jn20-diagram__center-main {
font-size: 1.4rem;
}
@media (max-width: 959px) {
.jn20-diagram-sp-title {
display: block;
}
} .jn20-message { background:
radial-gradient(ellipse 72% 56% at 50% 52%, rgba(196, 148, 60, .17) 0%, transparent 64%),
radial-gradient(ellipse 94% 76% at 50% 46%, rgba(24, 64, 130, .30) 0%, transparent 72%),
radial-gradient(ellipse 120% 104% at 50% 50%, transparent 58%, rgba(0, 0, 0, .38) 100%),
var(--jn-bg-deep);
padding: 88px 0;
} .jn20-message__inner {
max-width: 800px;
margin: 0 auto;
padding: 0 40px;
display: flex;
flex-direction: column;
align-items: center;
gap: 36px;
text-align: center;
} .jn20-message__heading {
font-family: var(--jn-ff-min);
font-weight: 700;
letter-spacing: .06em;
line-height: 1.4;
color: var(--jn-gold); text-align: center; }
.jn20-message__heading-white { display: block;
font-size: clamp(17px, 2.8vw, 26px);
}
.jn20-message__heading-gold {
display: block;
font-size: clamp(17px, 2.8vw, 26px);
margin-top: .15em;
} .jn20-message__body {
display: flex;
flex-direction: column;
align-items: center; gap: 4px;
text-align: center;
}
.jn20-message__p {
font-family: var(--jn-ff-sans); font-size: clamp(1rem, 1.35vw, 1.0625rem);
color: var(--jn-sub);
line-height: 1.9;
letter-spacing: .03em;
text-align: center; } .jn20-message__tagline {
margin-top: 16px; font-family: var(--jn-ff-min);
font-size: clamp(30px, 5.2vw, 62px);
font-weight: 700;
color: var(--jn-white);
letter-spacing: .04em;
line-height: 1.35;
text-align: center; text-shadow: 0 0 30px rgba(90, 140, 255, .16), 0 2px 10px rgba(0, 0, 0, .55);
} .jn20-cta {
background: var(--jn-bg);
padding: 72px 0 80px;
text-align: center;
}
.jn20-cta__lead {
font-family: var(--jn-ff-min); font-size: clamp(1rem, 1.5vw, 1.1rem);
color: var(--jn-sub);
margin-bottom: 1.5em;
letter-spacing: .05em;
}
.jn20-cta__btn {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 56px;
padding: 0 48px;
background: linear-gradient(135deg, var(--jn-gold) 0%, #e09030 100%);
color: #1a0a00;
font-family: var(--jn-ff-min);
font-size: clamp(.95rem, 1.6vw, 1.15rem);
font-weight: 700;
letter-spacing: .06em;
border-radius: 4px;
border: none;
cursor: pointer;
transition: opacity .2s, box-shadow .2s, transform .1s;
box-shadow: 0 4px 24px rgba(242,180,81,.35);
text-decoration: none;
}
.jn20-cta__btn:hover,
.jn20-cta__btn:focus {
opacity: .88;
box-shadow: 0 6px 32px rgba(242,180,81,.55);
transform: translateY(-1px);
outline: 3px solid var(--jn-gold);
outline-offset: 3px;
}
.jn20-cta__btn:active {
transform: translateY(0);
} .jn20-footer {
background: #060e1c; padding: 36px 40px;
text-align: center;
}
.jn20-footer__company {
font-family: var(--jn-ff-sans);
font-size: .82rem;
color: var(--jn-sub);
margin-bottom: .4em;
}
.jn20-footer__address {
font-family: var(--jn-ff-sans);
font-size: .78rem;
color: rgba(207,216,236,.6);
margin-bottom: .8em;
}
.jn20-footer__copy {
font-family: var(--jn-ff-sans);
font-size: .75rem;
color: rgba(207,216,236,.45);
} @media (max-width: 767px) { .jn20-hero {
min-height: clamp(380px, 65svh, 580px);
background-position: right 35%; align-items: flex-end;
}
.jn20-hero__text {
padding: 40px 24px 36px;
max-width: 100%;
}
.jn20-hero__lockup {
top: 16px;
right: 16px;
} .jn20-inner {
padding: 0 20px;
}
.jn20-value {
padding: 60px 0 40px;
}  .jn20-cards {
grid-template-columns: 1fr 1fr;
gap: 12px;
margin-bottom: 0;
}
.jn20-card {
padding: 20px 14px 18px;
}
.jn20-card__icon {
width: 40px;
height: 40px;
} .jn20-message {
padding: 60px 0;
}
.jn20-message__inner {
padding: 0 24px;
gap: 28px;
}
.jn20-message__tagline {
margin-top: 8px;
} .jn20-cta {
padding: 56px 0 64px;
}
.jn20-cta__btn {
padding: 0 28px;
font-size: .95rem;
min-height: 52px;
} .jn20-footer {
padding: 28px 20px;
text-align: left;
}
} @media (max-width: 360px) {
.jn20-message__tagline {
font-size: 26px;
letter-spacing: .02em;
}
} .jn20-gold { color: var(--jn-gold); }
.jn20-white { color: var(--jn-white); } .jn20 :focus-visible {
outline: 3px solid var(--jn-gold);
outline-offset: 3px;
} @media (prefers-reduced-motion: reduce) {
.jn20 * {
transition: none !important;
animation: none !important;
}
}