﻿.c-contain--padding {
    padding-bottom: 50px
}

.c-contain__main {
    max-width: 1400px;
    padding: 0 15px;
    margin: 0 auto;
    overflow: auto;
}

.c-contain__main--through {
    padding: 0
}

.c-contain--label {
    position: relative;
    z-index: 0;
    background: #f1f6f9;
    background: url("data:image/svg+xml,%3csvg%20width='127'%20height='553'%20viewBox='0%200%20127%20553'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M126.573%200L0.181876%20553H0V0H126.573Z'%20fill='%23DF0E1A'/%3e%3c/svg%3e") no-repeat 0 0/20px, url("data:image/svg+xml,%3csvg%20width='220'%20height='958'%20viewBox='0%200%20220%20958'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M220%20957.5H0L218.842%200H220V957.5Z'%20fill='%23DF0E1A'/%3e%3c/svg%3e") no-repeat 100% 100%/70px;
    background-color: #f1f6f9
}

@media (min-width: 768px) {
    .c-contain--padding {
        padding-bottom: 100px
    }

    .c-contain__main {
        padding: 0 !important
    }

    .c-contain--label {
        background-size: 120px, 185px
    }
}

.c-title {
    display: flex;
    padding: 25px 0 10px;
    justify-content: space-between
}

.c-title__left {
    display: flex;
    align-items: center;
    color: #161515;
    font-size: 20px;
    font-weight: 700
}

.c-title__more {
    display: flex;
    width: 90px;
    height: 30px;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    border: 2px #df0e1a solid;
    font-size: 13px;
    color: #df0e1a
}

.c-title__more:after {
    content: "";
    width: 14px;
    height: 14px;
    background: url("data:image/svg+xml,%3csvg%20width='19'%20height='18'%20viewBox='0%200%2019%2018'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cg%20id='Icons/Arrow_drop_right'%3e%3cpath%20id='Vector%2010'%20d='M12.258%208.79834L7.27637%204.64698C6.84894%204.29078%206.2%204.59473%206.2%205.15112V12.8489C6.2%2013.4053%206.84894%2013.7092%207.27637%2013.353L12.258%209.20166C12.3839%209.09671%2012.3839%208.90329%2012.258%208.79834Z'%20fill='%23DF0E1A'/%3e%3c/g%3e%3c/svg%3e") no-repeat 0 0/contain
}

.c-title svg {
    width: 20px;
    height: 20px;
    margin-right: 5px;
    color: #df0e1a
}

.c-game-list-container {
    padding-bottom: 50px;
    background-color: #f1f6f9
}

.c-game-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-column-gap: 10px;
    grid-row-gap: 9px
}

.c-game {
    padding: 10px;
    border-radius: 6px;
    background: #fff;
    box-shadow: 0 5px 8px #00000014
}

.c-game__cover {
    position: relative;
    overflow: hidden;
    cursor: pointer
}

.c-game img {
    width: 100%;
    height: 180px;
    vertical-align: middle;
    object-fit: cover
}

.c-game__info {
    position: absolute;
    display: flex;
    bottom: 0;
    left: 0;
    right: 0
}

.c-game__info-item {
    display: flex;
    flex: 1;
    height: 30px;
    flex-direction: column;
    justify-content: center;
    border: 1px solid #000;
    border-radius: 2px;
    background: #fff;
    font-size: 8px
}

.c-game__info-item:not(:last-child) {
    margin-right: 1px
}

.c-game__info-title {
    background: #000;
    color: #fff;
    white-space: nowrap;
    text-align: center
}

.c-game__info-value {
    display: flex;
    flex: 1;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    font-weight: 700;
    word-break: break-all;
    white-space: nowrap
}

.c-game__title {
    padding-top: 10px;
    line-height: 18px;
    text-align: center;
    font-size: 13px;
    font-weight: 700;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis
}

@media (min-width: 768px) {
    .c-game {
        border-radius: 10px
    }

    .c-game img {
        height: 254px
    }

    .c-game__info-item {
        height: 44px;
        border: 1px solid #8b8b8b;
        border-radius: 2px;
        font-size: 12px
    }

    .c-game__info-item:not(:last-child) {
        margin-right: 2px
    }

    .c-game__info-value {
        font-size: 10px
    }

    .c-game__title {
        font-size: 14px
    }
}
@media (min-width: 768px) {
    .c-title {
        padding: 50px 0 25px
    }

    .c-title__left {
        font-size: 28px
    }

    .c-title__more {
        width: 120px;
        height: 48px;
        font-size: 16px
    }

    .c-title__more:after {
        width: 18px;
        height: 18px;
        background: url("data:image/svg+xml,%3csvg%20width='19'%20height='18'%20viewBox='0%200%2019%2018'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cg%20id='Icons/Arrow_drop_right'%3e%3cpath%20id='Vector%2010'%20d='M12.258%208.79834L7.27637%204.64698C6.84894%204.29078%206.2%204.59473%206.2%205.15112V12.8489C6.2%2013.4053%206.84894%2013.7092%207.27637%2013.353L12.258%209.20166C12.3839%209.09671%2012.3839%208.90329%2012.258%208.79834Z'%20fill='%23DF0E1A'/%3e%3c/g%3e%3c/svg%3e") no-repeat 0 0/contain
    }

    .c-title svg {
        width: 28px;
        height: 28px
    }

    .c-banner {
        height: 606px
    }

    .c-banner__swiper-item {
        height: 500px
    }

    .c-notice__main {
        height: 60px
    }

    .c-notice__left-icon {
        width: 24px;
        height: 24px
    }

    .c-notice__right-icon {
        padding: 2px 2px 2px 6px
    }

    .c-game-list-container {
        padding-bottom: 110px;
        background-color: #f1f6f9
    }

    .c-game-list {
        grid-template-columns: repeat(7, 1fr);
        grid-column-gap: 20px;
        grid-row-gap: 20px
    }
}
.c-auth {
    display: flex;
    width: 82vw;
    height: 610px;
    border-radius: 8px
}

.c-auth__left {
    display: none;
    width: 600px;
    height: 650px;
    margin: -20px 0 -20px -15px
}

.c-auth__left-bg {
    vertical-align: middle
}

.c-auth__left-logo {
    position: absolute;
    width: 160px;
    height: 60px;
    top: 10px;
    left: 20px;
    object-fit: contain
}

.c-auth__main {
    flex: 1
}
.c-user-info__amount {
    display: flex;
    font-size: 15px;
    align-items: center;
    color: #fff
}

.c-user-info__amount:before {
    content: "";
    width: 14px;
    height: 14px;
    margin-right: 5px;
    background: url("data:image/svg+xml,%3csvg%20width='16'%20height='17'%20viewBox='0%200%2016%2017'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cg%20id='Group'%3e%3cpath%20id='Vector'%20d='M8%2016.1475C11.9375%2016.1475%2014.75%2014.7525%2014.75%2011.6475C14.75%208.2725%2013.0625%206.0225%209.6875%204.335L11.015%202.625C11.0824%202.5128%2011.119%202.38477%2011.121%202.25388C11.123%202.12299%2011.0904%201.9939%2011.0265%201.87968C10.9625%201.76547%2010.8695%201.67019%2010.7568%201.60352C10.6442%201.53684%2010.5159%201.50112%2010.385%201.5H5.615C5.4841%201.50112%205.35582%201.53684%205.24317%201.60352C5.13052%201.67019%205.0375%201.76547%204.97354%201.87968C4.90958%201.9939%204.87696%202.12299%204.87897%202.25388C4.88098%202.38477%204.91756%202.5128%204.985%202.625L6.3125%204.34625C2.9375%206.045%201.25%208.295%201.25%2011.67C1.25%2014.7525%204.0625%2016.1475%208%2016.1475Z'%20fill='%23FEA521'%20stroke='%23FEA521'%20stroke-width='1.125'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3cg%20id='Group_2'%3e%3cpath%20id='Vector_2'%20d='M8%2012.2437V13.38'%20stroke='white'%20stroke-width='1.125'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3cpath%20id='Vector_3'%20d='M8%206.60748V7.66498'%20stroke='white'%20stroke-width='1.125'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/g%3e%3cpath%20id='Vector_4'%20d='M6.87488%2011.7263C7.01215%2011.8892%207.18492%2012.0185%207.37993%2012.1043C7.57494%2012.1902%207.78701%2012.2302%207.99988%2012.2213C8.32524%2012.2435%208.64652%2012.1386%208.89619%2011.9288C9.14585%2011.719%209.30445%2011.4206%209.33863%2011.0963C9.30445%2010.772%209.14585%2010.4735%208.89619%2010.2637C8.64652%2010.0539%208.32524%209.94909%207.99988%209.97127C7.67453%209.99345%207.35324%209.88862%207.10358%209.67882C6.85391%209.46902%206.69532%209.17059%206.66113%208.84627C6.69257%208.52082%206.8504%208.22068%207.10072%208.01033C7.35104%207.79998%207.67388%207.69619%207.99988%207.72127C8.209%207.70848%208.41836%207.7422%208.61289%207.82001C8.80741%207.89782%208.98227%208.01779%209.12488%208.17127'%20stroke='white'%20stroke-width='1.125'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/g%3e%3c/svg%3e") no-repeat 0 0/cover
}

.c-table {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    border: 1px #ddd solid;
    border-radius: 7px;
    overflow: hidden;
    background: #fff
}

.c-table__cell {
    display: flex;
    height: 42px;
    padding-left: 20px;
    align-items: center;
    border-bottom: 1px #ddd solid
}

.c-table__cell:nth-child(odd) {
    background: #f7f7f7
}

.c-table__balance {
    color: #0ab189;
    font-weight: 700
}

.c-table__link {
    color: #f56b32;
    text-decoration: underline;
    cursor: pointer
}

.c-table__link--disabled {
    color: #ccc;
    cursor: not-allowed
}

@media (min-width: 768px) {
    .c-table {
        grid-template-columns: repeat(6, 1fr);
        grid-template-areas: "a1 b1 c1 d1 e1 f1" "a2 b2 c2 d2 e2 f2" "a3 b3 c3 d3 d3 d3"
    }
}

.c-content {
    margin-top: 20px
}

.c-content__left {
    width: 100%
}

.c-content__right {
    flex: 1;
    width: 100%;
    min-height: 534px;
    padding: 20px 20px 40px;
    border-radius: 6px;
    background: #fff;
    box-shadow: 0 5px 8px #00000014
}

.c-menu__item {
    position: relative;
    display: flex;
    height: 46px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    background: #fff;
    box-shadow: 0 2px 5px #0000000d;
    cursor: pointer
}

.c-menu__item:not(:last-child) {
    margin-bottom: 10px
}

.c-menu__item span {
    color: #df0e1a
}

.c-menu__item:after {
    content: "";
    position: absolute;
    width: 16px;
    height: 16px;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    mask: url("data:image/svg+xml,%3csvg%20width='16'%20height='16'%20viewBox='0%200%2016%2016'%20xmlns='http://www.w3.org/2000/svg'%3e%3cg%20id='Icons/Arrow_drop_right'%3e%3cpath%20id='Vector%2010'%20d='M10.4515%207.82067L6.0234%204.13056C5.64346%203.81395%205.06663%204.08412%205.06663%204.57869V11.4211C5.06663%2011.9157%205.64346%2012.1859%206.0234%2011.8693L10.4515%208.17917C10.5635%208.08589%2010.5635%207.91395%2010.4515%207.82067Z'%20fill='currentColor'/%3e%3c/g%3e%3c/svg%3e") no-repeat center/contain;
    background-color: #6b6b6b
}

.c-menu__item--active {
    background: linear-gradient(180deg, #fb4650, #df0d1a);
    color: #fff
}

.c-menu__item--active:before {
    content: "";
    position: absolute;
    width: 31px;
    height: 100%;
    right: 0;
    top: 0;
    background: url("data:image/svg+xml,%3csvg%20width='31'%20height='66'%20viewBox='0%200%2031%2066'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cg%20id='Frame%2014'%3e%3cg%20clip-path='url(%23clip0_735_2295)'%3e%3cpath%20id='Rectangle%2057'%20d='M33%200H43V66H13L33%200Z'%20fill='url(%23paint0_linear_735_2295)'/%3e%3cpath%20id='Rectangle%2058'%20opacity='0.5'%20d='M23%200H43V66H3L23%200Z'%20fill='url(%23paint1_linear_735_2295)'/%3e%3c/g%3e%3c/g%3e%3cdefs%3e%3clinearGradient%20id='paint0_linear_735_2295'%20x1='32.2254'%20y1='0'%20x2='32.2254'%20y2='66'%20gradientUnits='userSpaceOnUse'%3e%3cstop%20stop-color='%23FF8857'/%3e%3cstop%20offset='1'%20stop-color='%23E15217'/%3e%3c/linearGradient%3e%3clinearGradient%20id='paint1_linear_735_2295'%20x1='28.6338'%20y1='0'%20x2='28.6338'%20y2='66'%20gradientUnits='userSpaceOnUse'%3e%3cstop%20stop-color='%23FF8857'/%3e%3cstop%20offset='1'%20stop-color='%23E15217'/%3e%3c/linearGradient%3e%3cclipPath%20id='clip0_735_2295'%3e%3cpath%20d='M0%200H25C28.3137%200%2031%202.68629%2031%206V60C31%2063.3137%2028.3137%2066%2025%2066H0V0Z'%20fill='white'/%3e%3c/clipPath%3e%3c/defs%3e%3c/svg%3e") no-repeat 100% 0/contain;
    mask: none
}

.c-menu__item--active:after {
    background-color: #fff
}

.c-menu__item--active span {
    color: #fff
}

@media (min-width: 768px) {
    .c-content {
        display : flex;
        margin-top: 20px
    }
    .c-content__left {
        width: 144px;
        margin-right: 20px
    }

    .c-content__right {
        padding: 40px 60px 80px
    }

    .c-menu__item {
        height: 66px
    }

    .c-menu__item:after {
        visibility: hidden
    }

    .c-menu__item--active:before {
        width: 40px
    }

    .c-menu__item--active:after {
        content: "";
        position: absolute;
        width: 8px;
        height: 18px;
        right: -8px;
        top: 50%;
        transform: translateY(-50%);
        background: url("data:image/svg+xml,%3csvg%20width='6'%20height='16'%20viewBox='0%200%206%2016'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20id='Polygon%201'%20d='M6%208L0%200.205772V15.7942L6%208Z'%20fill='%23F06D37'/%3e%3c/svg%3e") no-repeat 0 0/contain;
        mask: none;
        visibility: visible
    }
}
.van-form .van-cell__right-icon {
    display: flex;
    height: 54px;
    position: absolute;
    top: 40px;
    right: 22px;
    align-items: center
}

.van-field {
    padding: 0
}

.van-field:not(:last-child) {
    margin-bottom: 20px
}

.van-field:after {
    border: none !important
}

.van-field__value {
    position: initial;
    height: 100%
}

.van-field__body:has(>input[type=text], >input[type=password], textarea) {
    display: flex;
    height: 100%;
    align-items: center;
    justify-content: center
}

.van-field__body:has(>input[type=text], >input[type=password], textarea) input,
.van-field__body:has(>input[type=text], >input[type=password], textarea) textarea {
    height: 100%;
    color: #161515;
    border: none;
    font-size: 14px
}

.van-field__button {
    margin-right: 8px;
    color: #3f8cff
}

.van-field__control--custom {
    display: initial
}

.van-field__right-icon {
    display: inline-flex;
    align-items: center
}

.van-field:not(.van-field--label-top) {
    overflow: visible
}

.van-field:not(.van-field--label-top):has(input[type=text], input[type=password]):not(:has(.van-field)) {
    display: flex;
    height: 42px;
    align-items: center;
    justify-content: center
}

.van-field:not(.van-field--label-top):has(input[type=text], input[type=password], textarea):not(:has(.van-field)) {
    padding: 0 10px;
    border-radius: 8px;
    border: 1px solid #d3d3d3
}

.van-field:not(.van-field--label-top) .van-field__label {
    width: auto;
    margin-right: 0;
    font-size: 14px;
    color: #7d8592 !important
}

.van-field:not(.van-field--label-top) .van-field__error-message {
    position: absolute;
    left: 0
}

.van-field:is(.van-field--label-top) .van-field__label {
    color: #161515
}

.van-field:is(.van-field--label-top) > .van-field__body:has(>input[type=text], >input[type=password]) {
    height: 40px;
    padding: 0 10px;
    border-radius: 8px;
    border: 1px solid #d3d3d3
}

.van-field:is(.van-field--label-top) > .van-field__body:has(>input[type=text], >input[type=password]) input {
    color: #7d8592
}

.van-tabs .van-tab--active {
    color: var(--primary-color) !important
}

.van-tabs__nav {
    border-radius: 6px;
    box-shadow: 0 2px 1px #0000001f
}

.van-tabs__content {
    margin-top: 20px;
    background: #fff;
    box-shadow: 0 5px 8px #00000014;
    border-radius: 6px
}

.van-popup--bottom {
    max-width: 100%
}

.van-collapse-item__title {
    padding-left: 0 !important;
    padding-right: 0
}

.van-collapse-item__title:after {
    left: 0;
    right: 0
}

.van-collapse-item__content {
    padding-left: 0 !important;
    padding-right: 0 !important
}

.van-collapse-item--border:after {
    right: 0 !important;
    left: 0 !important
}

.van-step--finish .van-step__circle,
.van-step--finish .van-step__line {
    background-color: #0ab189
}

.van-loading {
    --van-loading-spinner-color: var(--primary-color) !important
}

/* ✅ 머신 카드 */

.status-board-header h1 {
    font-size: 28px;
    font-weight: 800;
    margin-bottom: 6px;
}

/* 부제목 */
.subtitle {
    font-size: 14px;
    color: #666;
    margin-bottom: 20px;
    line-height: 1.6;
}

.subtitle .highlight {
    color: #e74c3c;
    font-weight: bold;
}

/* 상태 태그 */
.status-tags {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.tag {
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    border-radius: 20px;
    padding: 6px 16px;
    display: inline-block;
}

.maintance {
    background: #7f8c8d;
}

.offline {
    background: #2c3e50;
}

.occupied {
    background: #e74c3c;
}

.reserved {
    background: #f39c12;
}

.available {
    background: #27ae60;
}

/* 단가 필터 영역 */
.filter-section {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    padding-top: 16px;
}

.filter-label {
    font-weight: 700;
    font-size: 15px;
    margin-right: 12px;
}

.filter-buttons {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.filter {
    border: 1px solid #ccc;
    background: #fff;
    border-radius: 20px;
    padding: 4px 8px;
    cursor: pointer;
    transition: all 0.2s;
    font-size: 14px;
}

.filter:hover {
    border-color: #888;
}

.filter.active {
    background: #222;
    color: #fff;
    border-color: #222;
}

.display-count {
    margin-left: auto;
    font-size: 14px;
    color: #555;
}

.display-count strong {
    font-weight: 700;
}

/* 반응형 */
@media (max-width: 768px) {
    .filter-section {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .display-count {
        align-self: flex-end;
    }
}

.machine-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 20px;
}

.machine-card {
    background: white;
    border-radius: 14px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    overflow: hidden;
    padding: 18px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.machine-card.available {
    border-top: 6px solid #28A745;
}
.machine-card.reserved {
    border-top: 6px solid #FFC107;
}
.machine-card.occupied {
    border-top: 6px solid #DC3545;
}
.machine-card.maintance {
    border-top: 6px solid #6C757D;
}
.machine-card.offline {
    border-top: 6px solid #343A40;
}
.card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    position: relative;
}

.machine-info {
    flex: 1;
}

.machine-label {
    font-size: 12px;
    color: #888;
    margin-bottom: 2px;
}

.machine-number {
    font-size: 28px;
    margin: 0;
    color: #222;
}

.machine-id {
    font-size: 13px;
    color: #777;
}

.price-badge {
    position: absolute;
    right: 160px;
    top: 20px;
    background: black;
    color: white;
    padding: 5px 8px;
    border-radius: 20px;
    font-size: 13px;
    line-height: 1.2;
    text-align: center;
}

.price-badge span {
    font-size: 10px;
    opacity: 0.8;
}

.machineprogress-section {
    position: absolute;
    top: 20px;
}

.machineprogress-bar {
    display: flex;
    align-items: center;
    gap: 2px;
    padding: 2px;
}

.progress-dot {
    width: 15px;
    height: 15px;
    border-radius: 50%; /* 원 모양 */
    display: inline-block;
}

.green-dot {
    background-color: #00b164; /* 진한 녹색 */
}

.light-green-dot {
    background-color: #8fe4bf; /* 연한 녹색 */
}

.status {
    background: #e74c3c;
    color: white;
    font-weight: 600;
    border-radius: 20px;
    padding: 8px 14px;
    font-size: 13px;
    white-space: nowrap;
}

/* AVAILABLE 색상 */
.status.available {
    background: #28A745;
}

.status.reserved {
    background: #FFC107;
}

.status.occupied {
    background: #DC3545;
}

.status.maintance {
    background: #6C757D;
}

.status.offline {
    background: #343A40;
}
.machine-rotate-container {
    position: absolute;
    top: 30px;
    left: -20px;
    background-color: #2c2c2c;
    color: #fff;
    padding: 5px 20px;
    transform: rotate(-20deg); /* 사선 효과 적용 */
    transform-origin: 0% 50%; /* 회전 중심 설정 */
    z-index: 10;
}
.machine-rotate-container.maintance {
    background-color: #6C757D;
}
.machine-rotate-container.offline {
    background-color: #343A40;
}
.game-title {
    margin-top: 14px;
    background: #fafafa;
    border: 1px solid #eee;
    border-radius: 10px;
    padding: 10px 14px;
}

.game-title .label {
    color: #888;
    font-size: 12px;
    margin: 0 0 4px 0;
}

.title-text {
    font-size: 15px;
    font-weight: 600;
    color: #333;
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-top: 14px;
}

.stat-box {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 10px;
    padding: 8px;
    text-align: left;
}

.stat-box .title {
    font-size: 11px;
    color: #666;
    margin: 0 0 4px 0;
}

.stat-box .value {
    margin: 0;
    color: #111;
    font-size: 12px;
    font-weight: 600;
}

.button-area {
    display: flex;
    justify-content: start;
    margin-top: 14px;
}

.enter-btn {
    background: black;
    color: white;
    border: none;
    border-radius: 20px;
    padding: 8px 20px;
    font-size: 14px;
    cursor: pointer;
    transition: 0.2s;
}
.enter-btn:hover {
    background: #444;
}
.disable-btn {
    background: #999;
    color: white;
    border: none;
    border-radius: 20px;
    padding: 8px 20px;
    font-size: 14px;
    cursor: pointer;
    transition: 0.2s;
}
@media (max-width: 768px) {
    .machine-grid {
        grid-template-columns: 1fr;
    }
    .price-badge {
        right: 120px;
        top: 30px;
    }
}


.rakuen-login-dialog {
    max-width: 460px;
}

.rakuen-login-modal {
    background: transparent;
    border: 0;
    box-shadow: none;
}

.rakuen-login-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

.rakuen-login-card {
    position: relative;
    z-index: 1;
    width: 100%;
    padding: 34px 32px 28px;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(255, 248, 240, .92));
    box-shadow: 0 16px 40px rgba(16, 10, 26, .32);
    backdrop-filter: blur(10px);
}

.rakuen-login-card::before {
    content: "";
    position: absolute;
    inset: -2px;
    z-index: -1;
    border-radius: 26px;
    background: linear-gradient(90deg, #ff2d84, #ff8c00, #ffd60a, #22c55e, #00b4d8, #7b2cbf, #ff2d84);
    background-size: 300% 100%;
    animation: rakuen-login-rainbow 4s linear infinite;
}

.rakuen-login-brand {
    text-align: center;
    margin-bottom: 22px;
}

.rakuen-login-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 96px;
    height: 96px;
    margin-bottom: 12px;
    border-radius: 50%;
    background: linear-gradient(135deg, #ff2d84, #ffd60a);
    color: #fff;
    font-size: 28px;
    font-weight: 800;
    letter-spacing: .08em;
    box-shadow: 0 0 30px rgba(255, 214, 10, .55), 0 8px 20px rgba(255, 45, 132, .35);
}

.rakuen-login-logo-image {
    display: block;
    width: 150px;
    height: 150px;
    margin: 0 auto 8px;
    object-fit: contain;
}

.rakuen-login-title-jp {
    font-size: 42px;
    font-weight: 900;
    line-height: 1;
    letter-spacing: .18em;
    color: #241329;
    padding-left: .18em;
}

.rakuen-login-title-jp span {
    background: linear-gradient(180deg, #ffd60a, #ff8c00);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.rakuen-login-title-en {
    margin-top: 8px;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: .45em;
    color: #7a477d;
    padding-left: .45em;
}

.rakuen-login-welcome {
    margin: 14px 0 0;
    color: #5d5561;
    font-size: 13px;
    line-height: 1.6;
}

.rakuen-login-form {
    margin-bottom: 0;
}

.rakuen-login-field + .rakuen-login-field {
    margin-top: 14px;
}

.rakuen-login-label {
    display: block;
    margin-bottom: 7px;
    color: #8f6210;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .22em;
}

.rakuen-login-input {
    width: 100%;
    min-height: 54px;
    border: 1.5px solid #d8c8d6;
    border-radius: 14px !important;
    background: rgba(255, 255, 255, .86);
    color: #2d2232;
    padding: 14px 16px;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.rakuen-login-input::placeholder {
    color: #a79aa9;
}

.rakuen-login-input:focus {
    border-color: #ff2d84;
    box-shadow: 0 0 0 4px rgba(255, 45, 132, .15);
    background: #fff;
}

.rakuen-login-options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 16px 0 18px;
    color: #5d5561;
    font-size: 13px;
}

.rakuen-login-options .form-check-label {
    color: #5d5561;
}

.rakuen-login-link {
    border: 0;
    background: transparent;
    color: #b32371;
    font-size: 13px;
    font-weight: 600;
    padding: 0;
}

.rakuen-login-submit {
    width: 100%;
    border: 0;
    border-radius: 14px;
    padding: 14px 18px;
    background: linear-gradient(135deg, #22c55e, #159947);
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: .04em;
    box-shadow: 0 10px 22px rgba(21, 153, 71, .35);
    transition: transform .2s ease, box-shadow .2s ease;
}

.rakuen-login-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 26px rgba(21, 153, 71, .42);
}

.rakuen-login-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 20px 0 14px;
    color: #8a7f8f;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .16em;
}

.rakuen-login-divider::before,
.rakuen-login-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(125, 94, 128, .5), transparent);
}

.rakuen-login-footer {
    text-align: center;
    color: #6c6471;
    font-size: 12px;
    line-height: 1.6;
}

.rakuen-login-footer p {
    margin-bottom: 4px;
}

@keyframes rakuen-login-rainbow {
    0% {
        background-position: 0 50%;
    }

    100% {
        background-position: 300% 50%;
    }
}

@media (max-width: 767px) {
    .rakuen-login-wrap {
        padding: 0;
    }

    .rakuen-login-card {
        padding: 28px 20px 22px;
    }

    .rakuen-login-title-jp {
        font-size: 34px;
    }

    .rakuen-login-title-en {
        letter-spacing: .28em;
        padding-left: .28em;
    }

    .rakuen-login-logo-image {
        width: 128px;
        height: 128px;
    }

    .rakuen-login-options {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ---------- RAKUEN full-page login (rakuen_spa_no_gli.html parity) ---------- */
.rakuen-login-page {
    --rakuen-pink: #ff2d84;
    --rakuen-pink-dark: #b32371;
    --rakuen-rose: #ff8fb8;
    --rakuen-gold: #ffb627;
    --rakuen-gold-hot: #ff8c00;
    --ink-0: #2d2232;
    --ink-1: #4a3d4f;
    --ink-2: #5d5561;
    --ink-3: #8a7f8f;
    --ink-gold: #8f6210;
    --border: rgba(125, 94, 128, 0.35);
    --border-deep: #d8c8d6;
    --hibiscus-red: #e63946;
    --tropic-green: #22c55e;
    --tropic-green-dp: #159947;
    min-height: 100vh;
    background: linear-gradient(165deg, #fff9f0 0%, #ffecf2 45%, #fff7df 100%);
    color: var(--ink-0);
}

.rakuen-login-page .login-wrap {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 20px 60px;
    position: relative;
    z-index: 2;
}

.rakuen-login-page .login-bg-decor {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    overflow: hidden;
}

.rakuen-login-page .login-palm {
    position: absolute;
    width: 240px;
    height: 300px;
    opacity: 0.28;
    filter: drop-shadow(0 6px 16px rgba(14, 159, 71, 0.35));
}

.rakuen-login-page .login-palm.l {
    top: -40px;
    left: -40px;
    transform: scaleX(-1);
}

.rakuen-login-page .login-palm.r {
    top: -40px;
    right: -40px;
}

.rakuen-login-page .login-hibiscus {
    position: absolute;
    font-size: 52px;
    opacity: 0.7;
    filter: drop-shadow(0 4px 10px rgba(230, 57, 70, 0.3));
    animation: rakuen-login-sway 6s ease-in-out infinite;
}

.rakuen-login-page .login-bg-decor > .login-hibiscus:nth-child(3) {
    animation-delay: -2s;
}

.rakuen-login-page .login-bg-decor > .login-hibiscus:nth-child(4) {
    animation-delay: -4s;
}

.rakuen-login-page .login-bg-decor > .login-hibiscus:nth-child(5) {
    animation-delay: -1s;
}

@keyframes rakuen-login-sway {
    0%,
    100% {
        transform: rotate(-6deg) translateY(0);
    }

    50% {
        transform: rotate(6deg) translateY(-8px);
    }
}

.rakuen-login-page .login-card {
    width: 440px;
    max-width: 100%;
    padding: 30px 32px 26px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(255, 249, 240, 0.93));
    border-radius: 24px;
    box-shadow: 0 20px 60px rgba(255, 45, 132, 0.25), 0 0 80px rgba(255, 214, 10, 0.25);
    border: 2px solid transparent;
    position: relative;
    z-index: 3;
    backdrop-filter: blur(10px);
}

.rakuen-login-page .login-card::before {
    content: "";
    position: absolute;
    inset: -2px;
    background: linear-gradient(90deg, #ff2d84, #ff8c00, #ffd60a, #22c55e, #00b4d8, #7b2cbf, #ff2d84);
    background-size: 300% 100%;
    border-radius: 24px;
    z-index: -1;
    animation: rakuen-login-rainbow 4s linear infinite;
}

.rakuen-login-page .login-logo-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 4px;
}

.rakuen-login-page .login-logo-circle {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--rakuen-pink), var(--rakuen-gold-hot));
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Zen Old Mincho", "Yu Mincho", "Hiragino Mincho ProN", "MS Mincho", Batang, serif;
    font-weight: 900;
    font-size: 32px;
    color: white;
    letter-spacing: 0.1em;
    box-shadow: 0 0 30px rgba(255, 214, 10, 0.6), 0 4px 12px rgba(255, 45, 132, 0.4);
    animation: rakuen-login-logo-pulse 3s ease-in-out infinite;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);
}

@keyframes rakuen-login-logo-pulse {
    0%,
    100% {
        box-shadow: 0 0 30px rgba(255, 214, 10, 0.6), 0 4px 12px rgba(255, 45, 132, 0.4);
    }

    50% {
        box-shadow: 0 0 50px rgba(255, 214, 10, 0.95), 0 4px 20px rgba(255, 45, 132, 0.65);
    }
}

.rakuen-login-page .login-title-jp {
    font-family: "Zen Old Mincho", "Yu Mincho", "Hiragino Mincho ProN", "MS Mincho", Batang, serif;
    font-weight: 900;
    font-size: 44px;
    letter-spacing: 0.18em;
    text-align: center;
    line-height: 1;
    background: linear-gradient(180deg, #fff, var(--rakuen-rose), var(--rakuen-pink));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: drop-shadow(0 3px 6px rgba(255, 45, 132, 0.35));
    padding-left: 0.18em;
    margin-top: 8px;
}

.rakuen-login-page .login-title-jp em {
    font-style: normal;
    background: linear-gradient(180deg, #ffd60a, var(--rakuen-gold), var(--rakuen-gold-hot));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.rakuen-login-page .login-title-romaji {
    font-family: "Bebas Neue", "Arial Narrow", Impact, sans-serif;
    font-size: 18px;
    letter-spacing: 0.5em;
    color: var(--rakuen-pink-dark);
    text-align: center;
    margin-top: 2px;
    padding-left: 0.5em;
}

.rakuen-login-page .login-welcome {
    text-align: center;
    font-size: 13px;
    color: var(--ink-2);
    margin-top: 12px;
    margin-bottom: 20px;
    line-height: 1.6;
}

.rakuen-login-page .login-welcome b {
    color: var(--rakuen-pink-dark);
    font-weight: 700;
}

.rakuen-login-page .login-field-label {
    font-family: "Bebas Neue", "Arial Narrow", Impact, sans-serif;
    font-size: 11px;
    letter-spacing: 0.2em;
    color: var(--ink-gold);
    margin-bottom: 6px;
    display: block;
}

.rakuen-login-page .login-input {
    width: 100%;
    padding: 13px 16px;
    border: 1.5px solid var(--border-deep);
    border-radius: 11px;
    font-size: 14px;
    background: rgba(255, 255, 255, 0.85);
    color: var(--ink-0);
    font-family: inherit;
    outline: none;
    transition: all 0.2s;
    margin-bottom: 12px;
    box-sizing: border-box;
}

.rakuen-login-page .login-input:focus {
    border-color: var(--rakuen-pink);
    box-shadow: 0 0 0 3px rgba(255, 45, 132, 0.15);
    background: white;
}

.rakuen-login-page .login-options {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 11.5px;
    margin: 4px 0 14px;
}

.rakuen-login-page .login-check {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--ink-2);
    cursor: pointer;
    user-select: none;
}

.rakuen-login-page .login-forgot {
    color: var(--rakuen-pink-dark);
    cursor: pointer;
    font-weight: 500;
}

.rakuen-login-page .login-forgot.as-link {
    border: 0;
    background: transparent;
    padding: 0;
    font: inherit;
}

.rakuen-login-page .login-submit {
    width: 100%;
    padding: 14px;
    background: linear-gradient(135deg, var(--tropic-green), var(--tropic-green-dp));
    color: white;
    border: none;
    border-radius: 12px;
    font-family: "Mochiy Pop One", "Yu Gothic", Meiryo, "Apple SD Gothic Neo", sans-serif;
    font-size: 15px;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(34, 197, 94, 0.35);
    transition: all 0.2s;
    letter-spacing: 0.04em;
}

.rakuen-login-page .login-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(34, 197, 94, 0.5);
}

.rakuen-login-page .login-err {
    background: rgba(230, 57, 70, 0.1);
    border: 1px solid rgba(230, 57, 70, 0.3);
    color: var(--hibiscus-red);
    padding: 8px 12px;
    border-radius: 8px;
    font-size: 12px;
    margin-bottom: 12px;
}

.rakuen-login-page .login-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 20px 0 14px;
    color: var(--ink-3);
    font-size: 11px;
    letter-spacing: 0.1em;
}

.rakuen-login-page .login-divider::before,
.rakuen-login-page .login-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--border), transparent);
}

.rakuen-login-page .login-social {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 8px;
    margin-bottom: 14px;
}

.rakuen-login-page .login-social button {
    padding: 11px 8px;
    border: 1.5px solid var(--border-deep);
    border-radius: 10px;
    background: white;
    cursor: pointer;
    font-size: 12px;
    color: var(--ink-1);
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    font-family: inherit;
    transition: all 0.2s;
}

.rakuen-login-page .login-social button:hover {
    border-color: var(--rakuen-pink);
    transform: translateY(-1px);
}

.rakuen-login-page .login-soc-g {
    color: #4285f4;
    font-weight: 900;
}

.rakuen-login-page .login-soc-k {
    background: #fee500;
    color: #391b1b;
    padding: 1px 5px;
    border-radius: 3px;
    font-weight: 900;
}

.rakuen-login-page .login-soc-l {
    color: #06c755;
    font-weight: 900;
}

.rakuen-login-page .login-guest {
    display: block;
    width: 100%;
    text-align: center;
    padding: 12px;
    font-size: 13px;
    color: var(--rakuen-pink-dark);
    border: 1.5px dashed var(--border-deep);
    border-radius: 10px;
    cursor: pointer;
    font-weight: 500;
    background: transparent;
    font-family: inherit;
    transition: all 0.2s;
    text-decoration: none;
    box-sizing: border-box;
}

.rakuen-login-page button.login-guest {
    appearance: none;
}

.rakuen-login-page .login-guest:hover {
    background: rgba(255, 45, 132, 0.06);
    border-style: solid;
    color: var(--rakuen-pink-dark);
}

.rakuen-login-page .login-footer {
    text-align: center;
    font-size: 12px;
    color: var(--ink-3);
    margin-top: 14px;
    line-height: 1.6;
}

.rakuen-login-page .login-legal {
    text-align: center;
    font-size: 10.5px;
    color: var(--ink-3);
    margin-top: 12px;
}

.rakuen-login-page .login-form {
    margin: 0;
}

@media (max-width: 780px) {
    .rakuen-login-page .login-card {
        padding: 24px 20px 20px;
    }

    .rakuen-login-page .login-title-jp {
        font-size: 36px;
    }
}

/* ---------- RAKUEN rate corner select (rakuen_spa corners view) ---------- */
.rakuen-corners-page {
    min-height: calc(100vh - 72px);
    padding: 0 0 32px;
    position: relative;
    z-index: 2;
}

.rakuen-corners-hero {
    text-align: center;
    padding: 40px 20px 24px;
}

.rakuen-corners-hero__title {
    margin: 0;
    font-family: "Zen Old Mincho", "Yu Mincho", serif;
    font-weight: 900;
    font-size: clamp(28px, 5vw, 48px);
    background: linear-gradient(135deg, #c81a6b, #ff8c00, #ffd60a);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    letter-spacing: 0.15em;
    filter: drop-shadow(0 3px 8px rgba(255, 45, 132, 0.3));
}

.rakuen-corners-hero__sub {
    margin: 8px 0 0;
    color: #8b4a6b;
    font-size: 14px;
}

.rakuen-corners-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    padding: 12px 24px 24px;
    max-width: 1400px;
    margin: 0 auto;
}

.rakuen-corner-card {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 0;
    border: 3px solid transparent;
    border-radius: 18px;
    cursor: pointer;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(26, 11, 26, 0.25);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    text-decoration: none;
    color: inherit;
    background: linear-gradient(180deg, var(--corner-accent), #1a0b1a);
}

.rakuen-corner-card:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: 0 14px 32px rgba(26, 11, 26, 0.35);
}

.rakuen-corner-card__sign {
    padding: 18px 12px 12px;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.25), transparent);
    color: #ffd60a;
    text-align: center;
}

.rakuen-corner-card__yen {
    font-family: "Zen Old Mincho", "Yu Mincho", serif;
    font-weight: 900;
    font-size: 32px;
    letter-spacing: 0.1em;
    line-height: 1;
    color: white;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
}

.rakuen-corner-card__pachi {
    margin-top: 4px;
    font-size: 10px;
    letter-spacing: 0.2em;
    color: rgba(255, 214, 10, 0.85);
    font-weight: 700;
}

.rakuen-corner-card__body {
    flex: 1;
    padding: 14px 16px;
    background: linear-gradient(180deg, rgba(26, 11, 26, 0.5), rgba(26, 11, 26, 0.75));
    color: white;
    min-height: 200px;
    text-align: center;
}

.rakuen-corner-card__label {
    font-family: "Zen Old Mincho", "Yu Mincho", serif;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.rakuen-corner-card__labelkr {
    font-size: 11px;
    color: rgba(255, 198, 221, 0.85);
    margin-bottom: 14px;
}

.rakuen-corner-card__invest {
    padding: 10px 12px;
    background: rgba(255, 214, 10, 0.12);
    border: 1px dashed rgba(255, 214, 10, 0.4);
    border-radius: 8px;
}

.rakuen-corner-card__invest-cap {
    font-size: 10px;
    color: #ffd60a;
    letter-spacing: 0.2em;
    font-weight: 700;
}

.rakuen-corner-card__balls {
    font-family: ui-monospace, "Cascadia Code", "JetBrains Mono", Consolas, monospace;
    font-weight: 900;
    font-size: 22px;
    color: #fff;
    margin-top: 2px;
}

.rakuen-corner-card__balls span {
    font-size: 12px;
    color: #ffd60a;
}

.rakuen-corner-card__approx {
    font-size: 11px;
    color: rgba(255, 198, 221, 0.7);
    margin-top: 2px;
}

.rakuen-corner-card__detail {
    margin-top: 12px;
    font-size: 10px;
    color: rgba(255, 198, 221, 0.65);
    line-height: 1.5;
}

.rakuen-corner-card__enter {
    padding: 10px;
    background: #000;
    color: #ffd60a;
    font-family: "Bebas Neue", Impact, sans-serif;
    font-weight: 900;
    font-size: 14px;
    letter-spacing: 0.2em;
    text-align: center;
}

@media (max-width: 1200px) {
    .rakuen-corners-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 780px) {
    .rakuen-corners-grid {
        grid-template-columns: 1fr;
        max-width: 420px;
    }
}

:root {
    --rakuen-pink: #ff2d84;
    --rakuen-pink-deep: #c81a6b;
    --rakuen-gold: #ffb627;
    --rakuen-gold-hot: #ff8c00;
    --rakuen-gold-light: #ffd60a;
    --rakuen-green: #22c55e;
    --rakuen-green-deep: #0e9f47;
    --rakuen-red: #e63946;
    --rakuen-purple: #4a1765;
    --rakuen-wine: #2b1236;
    --rakuen-ink: #381c36;
    --rakuen-ink-muted: #7b5a74;
    /* rakuen_spa_no_gli.html :root page + bar tokens */
    --rakuen-bg-page-1: #ffe9f3;
    --rakuen-bg-page-2: #fff3d6;
    --rakuen-bg-1: #ffe9f3;
    --rakuen-bg-2: #fff3d6;
    --rakuen-bg-glow-top: rgba(255, 214, 10, 0.32);
    --rakuen-bg-glow-bl: rgba(127, 212, 255, 0.28);
    --rakuen-bg-glow-br: rgba(255, 45, 132, 0.22);
    --rakuen-body-bg-image:
        radial-gradient(ellipse 80% 50% at 50% 0%, var(--rakuen-bg-glow-top), transparent 60%),
        radial-gradient(ellipse 50% 40% at 10% 90%, var(--rakuen-bg-glow-bl), transparent 70%),
        radial-gradient(ellipse 50% 40% at 90% 85%, var(--rakuen-bg-glow-br), transparent 70%),
        linear-gradient(180deg, var(--rakuen-bg-page-1), var(--rakuen-bg-page-2));
    --rakuen-topbar-bg: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 243, 214, 0.78));
    --rakuen-topbar-border: var(--rakuen-border-pink-deep);
    --rakuen-topbar-chip-bg: linear-gradient(135deg, rgba(255, 255, 255, 0.88), rgba(255, 247, 232, 0.92));
    --rakuen-brand-title-color: #d22d78;
    --rakuen-topbar-ink: #d18a17;
    --rakuen-topbar-ink-muted: var(--rakuen-ink-muted);
    --rakuen-border-pink: #ffc6dd;
    --rakuen-border-pink-deep: #ff8fb8;
    --rakuen-card: rgba(255, 255, 255, 0.92);
    --rakuen-border: rgba(255, 117, 171, 0.28);
    --rakuen-shadow: 0 16px 40px rgba(96, 36, 81, 0.14);
    --rakuen-shadow-soft: 0 6px 20px rgba(255, 45, 132, 0.15);
    --rakuen-radius-md: 14px;
    --rakuen-radius-lg: 24px;
    --rakuen-pill: 999px;
    --rakuen-rose: #ff6ba8;
    --ink-1: #5a2748;
    --ink-2: #8b4a6b;
    --ink-gold: #8b5a00;
    --rakuen-rainbow: linear-gradient(
        90deg,
        #ff2d84 0%,
        #ff8c00 18%,
        #ffd60a 36%,
        #22c55e 54%,
        #00b4d8 72%,
        #7b2cbf 90%,
        #ff2d84 100%
    );
    --ink-0: #3d1a3d;
    --ink-3: #b07a92;
    --bg-card: #fff9f0;
    --bg-card-2: #ffecf2;
    --tropic-green-dp: #159947;
    --cab-gold-trim: #d4af37;
    --cab-wine: #1a0b1a;
    --border: #ffc6dd;
    --border-deep: #ff8fb8;
    --hibiscus-red: #e63946;
}

body {
    min-height: 100vh;
    overflow-x: hidden;
    color: var(--rakuen-ink);
}

/* Front SPA parity: page wash + sparkle (sample body / body::before) */
html[data-template="front-page"] body {
    background-color: var(--rakuen-bg-page-1);
    background-image: var(--rakuen-body-bg-image);
    background-attachment: fixed;
}

/* 파트너 브랜딩: 관리자 프리뷰와 동일 135deg 메인→액센트 */
html.partner-branded body::before,
html[data-template="front-page"].partner-branded body::before {
    opacity: 0.2;
}

html.partner-branded .rakuen-login-page {
    background: var(--rakuen-body-bg-image);
    background-attachment: fixed;
}

html.partner-branded .rakuen-topbar-shell,
html.partner-branded nav.layout-navbar.rakuen-topbar-shell {
    background: var(--rakuen-topbar-bg) !important;
    border-bottom-color: var(--rakuen-topbar-border) !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

html.partner-branded .rakuen-brand-medallion {
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.28);
}

html[data-template="front-page"] body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background-image:
        radial-gradient(circle at 15% 25%, rgba(255, 255, 255, 0.85) 0, transparent 2px),
        radial-gradient(circle at 82% 12%, rgba(255, 255, 255, 0.65) 0, transparent 2px),
        radial-gradient(circle at 30% 75%, rgba(255, 255, 255, 0.55) 0, transparent 1.5px),
        radial-gradient(circle at 68% 45%, rgba(255, 255, 255, 0.7) 0, transparent 2px),
        radial-gradient(circle at 92% 78%, rgba(255, 255, 255, 0.55) 0, transparent 1.5px);
    animation: rakuen-page-sparkle 8s ease-in-out infinite;
}

@keyframes rakuen-page-sparkle {
    0%,
    100% {
        opacity: 0.65;
    }

    50% {
        opacity: 1;
    }
}

a {
    color: inherit;
}

.rakuen-topbar-shell {
    position: sticky;
    top: 0;
    z-index: 1030;
    padding: 10px 0;
    background: var(--rakuen-topbar-bg);
    border-bottom: 2px solid var(--rakuen-topbar-border);
    box-shadow: var(--rakuen-shadow-soft);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.rakuen-topbar-container {
    max-width: none;
    width: 100%;
    box-sizing: border-box;
    padding-left: 20px;
    padding-right: 20px;
}

.rakuen-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    min-height: 72px;
    padding: 10px 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
}

.rakuen-topbar .navbar-brand,
.rakuen-topbar .app-brand,
.rakuen-topbar .app-brand.demo,
.rakuen-topbar .app-brand-link {
    margin-bottom: 0;
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
}

.rakuen-brand-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.rakuen-brand-medallion {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--rakuen-pink), var(--rakuen-gold));
    color: #fff;
    font-size: 17px;
    font-weight: 800;
    box-shadow: 0 6px 18px rgba(231, 56, 121, 0.24);
    border: 2px solid rgba(255,255,255,0.86);
}

.rakuen-brand-copy {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.rakuen-brand-title {
    font-size: 28px;
    font-weight: 800;
    color: var(--rakuen-brand-title-color);
    letter-spacing: 0.12em;
}

.rakuen-brand-subtitle {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.2em;
    color: #8c7d7f;
}

.rakuen-hall-selector {
    align-items: center;
    gap: 10px;
    margin: 0 14px 0 18px;
    padding: 8px 14px;
    border-radius: var(--rakuen-pill);
    border: 1px solid rgba(214, 88, 139, 0.28);
    background: rgba(255, 255, 255, 0.82);
    box-shadow: 0 6px 18px rgba(131, 81, 97, 0.08);
    color: #5f5061;
}

.rakuen-hall-selector__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: linear-gradient(135deg, #2dd4bf, #2563eb);
    box-shadow: 0 0 0 3px rgba(45, 212, 191, 0.12);
}

.rakuen-hall-selector__label {
    font-size: 14px;
    font-weight: 700;
}

.rakuen-nav-links {
    display: flex;
    align-items: center;
    gap: 2px;
    margin: 0 0 0 18px;
    padding-left: 0;
}

.rakuen-nav-links .nav-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 8px 12px;
    border-radius: 12px;
    color: var(--rakuen-ink);
    font-weight: 700;
    font-size: 15px;
    line-height: 1;
    white-space: nowrap;
}

.rakuen-nav-links .nav-link:hover,
.rakuen-nav-links .nav-link:focus {
    background: rgba(255, 255, 255, 0.6);
    color: var(--rakuen-pink-deep);
}

.rakuen-topbar-status {
    gap: 0;
    margin-left: 18px;
}

.rakuen-status-pill,
.rakuen-balance-chip {
    display: inline-flex;
    align-items: flex-start;
    gap: 2px;
    padding: 2px 18px;
    border-radius: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.rakuen-status-pill {
    flex-direction: column;
    align-items: flex-start;
    min-width: 140px;
    border-left: 1px solid rgba(126, 100, 111, 0.14);
}

.rakuen-status-label,
.rakuen-balance-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.18em;
    color: var(--rakuen-topbar-ink-muted);
    text-transform: uppercase;
}

.rakuen-toolbar {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 0;
    padding-left: 0;
}

.rakuen-toolbar > li,
.rakuen-nav-links > li {
    display: flex;
    align-items: center;
}

.rakuen-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: var(--rakuen-pill);
    min-height: 44px;
    padding: 0 18px;
    font-weight: 700;
    line-height: 1;
    box-shadow: var(--rakuen-shadow-soft);
}

.rakuen-btn-secondary {
    background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(255,242,247,0.92));
    color: var(--rakuen-pink-deep);
    border: 1px solid var(--rakuen-border);
}

.rakuen-btn-primary {
    background: linear-gradient(135deg, var(--rakuen-pink), #ff6b57);
    color: #fff;
}

.rakuen-btn-success {
    background: linear-gradient(135deg, var(--rakuen-green), var(--rakuen-green-deep));
    color: #fff;
}

.rakuen-lang-toggle,
.rakuen-avatar-link {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 0 10px !important;
    border-radius: var(--rakuen-pill);
}

.rakuen-balance-chip {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    min-width: 190px;
    min-height: 44px;
    padding: 0 16px 0 18px;
    border-left: 1px solid var(--rakuen-topbar-border);
    background: var(--rakuen-topbar-chip-bg);
    border-radius: 999px;
}

.rakuen-balance-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, #ffb627, #ff7a18);
    box-shadow: 0 0 0 4px rgba(255, 182, 39, 0.12);
    flex: 0 0 auto;
}

.rakuen-balance-chip strong {
    font-size: 20px;
    font-weight: 800;
    line-height: 1;
    color: var(--rakuen-topbar-ink);
    letter-spacing: 0.03em;
    white-space: nowrap;
}

.rakuen-balance-currency {
    font-size: 12px;
    vertical-align: middle;
    margin-right: 4px;
    opacity: .85;
}

/* ── 회원 등급 (grade_code) ── */
.rakuen-toolbar-grade {
    display: flex;
    align-items: center;
}

.rakuen-grade-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px 7px 11px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    line-height: 1;
    white-space: nowrap;
    border: 1px solid rgba(255, 255, 255, 0.45);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.14);
    color: #fff;
}

.rakuen-grade-badge__icon {
    font-size: 12px;
    line-height: 1;
    opacity: 0.95;
}

.rakuen-grade-badge--sm {
    padding: 5px 10px 5px 8px;
    font-size: 10px;
    gap: 4px;
}

.rakuen-grade-badge--compact {
    padding: 5px 9px;
    font-size: 9px;
    gap: 4px;
}

.rakuen-grade-badge--lg {
    padding: 10px 18px 10px 14px;
    font-size: 12px;
    gap: 8px;
}

.rakuen-grade-badge--bronze {
    background: linear-gradient(135deg, #6b4423 0%, #cd7f32 55%, #e8b88a 100%);
    border-color: rgba(232, 184, 138, 0.65);
    color: #fff8f0;
}

.rakuen-grade-badge--silver {
    background: linear-gradient(135deg, #5c6b7a 0%, #b8c4ce 45%, #eef2f6 100%);
    border-color: rgba(255, 255, 255, 0.55);
    color: #1a2430;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.35);
}

.rakuen-grade-badge--gold {
    background: linear-gradient(135deg, #9a6b00 0%, #ffd700 42%, #fff1a8 100%);
    border-color: rgba(255, 236, 160, 0.75);
    color: #3d2800;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.25);
}

.rakuen-grade-badge--vip {
    background: linear-gradient(135deg, #5b21b6 0%, #a855f7 50%, #ec4899 100%);
    border-color: rgba(255, 200, 255, 0.5);
    box-shadow: 0 2px 14px rgba(168, 85, 247, 0.35);
}

.rakuen-grade-badge--vvip {
    background: linear-gradient(135deg, #312e81 0%, #7c3aed 35%, #f59e0b 70%, #fef3c7 100%);
    border-color: rgba(255, 230, 150, 0.65);
    box-shadow: 0 3px 18px rgba(124, 58, 237, 0.4);
}

.rakuen-avatar-grade-ring {
    border-radius: 50%;
    padding: 2px;
    background: linear-gradient(135deg, #cd7f32, #cd7f32);
}

.rakuen-avatar-grade-ring--bronze { background: linear-gradient(135deg, #cd7f32, #8b5a2b); }
.rakuen-avatar-grade-ring--silver { background: linear-gradient(135deg, #eef2f6, #7b8a99); }
.rakuen-avatar-grade-ring--gold { background: linear-gradient(135deg, #ffd700, #b8860b); }
.rakuen-avatar-grade-ring--vip { background: linear-gradient(135deg, #ec4899, #7c3aed); }
.rakuen-avatar-grade-ring--vvip { background: linear-gradient(135deg, #fef3c7, #7c3aed, #f59e0b); }

.rakuen-avatar-grade-ring .avatar,
.rakuen-avatar-grade-ring .rounded-circle {
    border: 2px solid rgba(255, 255, 255, 0.92);
}

.rakuen-account-grade-wrap {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 10px;
}

.rakuen-account-user-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

.rakuen-account-user-meta .rakuen-status-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--rakuen-ink-muted);
}

.rakuen-account-balance-line {
    font-size: 22px;
    font-weight: 800;
    color: var(--rakuen-topbar-ink, #d18a17);
}

@media (max-width: 768px) {
    .rakuen-toolbar-grade {
        display: none !important;
    }
}

.rakuen-action-btn {
    min-width: 92px;
    padding: 0 16px;
    font-size: 14px;
    font-weight: 700;
    background: rgba(255,255,255,0.84);
    color: var(--rakuen-ink);
    border: 1px solid rgba(126, 100, 111, 0.14);
    box-shadow: none;
}

.rakuen-action-btn i {
    opacity: .9;
}

.rakuen-action-btn-deposit {
    color: #0f9f56;
}

.rakuen-action-btn-withdraw {
    color: #dd4a6b;
}

.rakuen-action-btn:hover,
.rakuen-action-btn:focus {
    background: rgba(255,255,255,0.96);
    color: var(--rakuen-ink);
    box-shadow: 0 8px 18px rgba(80, 29, 68, 0.08);
}

/* 게임/머신 페이지는 전폭 사용 — 코너·계정 등만 기본 폭 제한 */
.rakuen-content-shell,
.rakuen-account-shell {
    max-width: 1320px;
    margin: 0 auto;
}

.rakuen-home-hero {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 28px;
    align-items: center;
    padding: 26px 16px 10px;
}

.rakuen-home-hero__content,
.rakuen-home-hero__visual,
.rakuen-feature-card,
.rakuen-machine-hero,
.rakuen-machine-status-shell,
.rakuen-account-header,
.rakuen-account-panel,
.rakuen-footer-main {
    border: 1px solid rgba(255,255,255,0.68);
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(255,245,248,0.88));
    box-shadow: var(--rakuen-shadow);
}

.rakuen-home-hero__content {
    padding: 42px;
}

.rakuen-home-kicker {
    display: inline-block;
    margin-bottom: 10px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.28em;
    color: var(--rakuen-pink-deep);
}

.rakuen-home-title {
    margin: 0 0 16px;
    font-size: 52px;
    font-weight: 900;
    line-height: 1.08;
    color: var(--rakuen-ink);
}

.rakuen-home-summary {
    max-width: 620px;
    margin-bottom: 20px;
    font-size: 15px;
    line-height: 1.8;
    color: var(--rakuen-ink-muted);
}

.rakuen-home-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 18px;
}

.rakuen-home-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.rakuen-home-chips span {
    padding: 8px 14px;
    border-radius: var(--rakuen-pill);
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid var(--rakuen-border);
    font-size: 12px;
    font-weight: 700;
}

.rakuen-home-hero__visual {
    padding: 18px;
    min-height: 420px;
}

.rakuen-home-poster-stack {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 14px;
    height: 100%;
}

.rakuen-home-poster-stack img {
    width: 100%;
    height: 100%;
    min-height: 180px;
    object-fit: cover;
    border-radius: 22px;
    box-shadow: var(--rakuen-shadow-soft);
}

.rakuen-home-poster-stack img:first-child {
    grid-row: 1 / span 2;
}

.rakuen-feature-band {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    padding: 0 16px 22px;
}

.rakuen-feature-card {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 24px;
}

.rakuen-feature-badge {
    align-self: flex-start;
    padding: 7px 12px;
    border-radius: var(--rakuen-pill);
    background: linear-gradient(135deg, var(--rakuen-gold-light), var(--rakuen-gold-hot));
    color: #fff;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.14em;
}

.rakuen-feature-card strong {
    font-size: 20px;
}

.rakuen-feature-card small {
    color: var(--rakuen-ink-muted);
    font-size: 13px;
    line-height: 1.6;
}

.c-game-list-container.rakuen-content-shell {
    background: transparent;
}

.c-title {
    align-items: center;
}

.c-title__left {
    color: var(--rakuen-ink);
}

.c-title__more {
    border: 0;
    border-radius: var(--rakuen-pill);
    background: linear-gradient(135deg, var(--rakuen-pink), #ff6b57);
    color: #fff;
    box-shadow: var(--rakuen-shadow-soft);
}

.c-title__more:after {
    filter: brightness(0) invert(1);
}

.c-game {
    border: 1px solid rgba(255,255,255,0.74);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,242,247,0.92));
    box-shadow: var(--rakuen-shadow);
    transition: transform .2s ease, box-shadow .2s ease;
}

.c-game:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 34px rgba(96, 36, 81, 0.18);
}

.c-game__cover {
    border-radius: 14px;
}

.c-game img {
    border-radius: 12px;
}

.c-game__info-item {
    border-color: rgba(115, 91, 120, 0.2);
}

.c-game__title {
    color: var(--rakuen-ink);
}

.rakuen-machine-page {
    padding: 18px 16px 40px;
}

.rakuen-machine-hero {
    padding: 34px;
    margin-bottom: 18px;
}

.rakuen-machine-kicker {
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.24em;
    color: var(--rakuen-pink-deep);
    text-transform: uppercase;
}

.rakuen-machine-headline {
    margin: 10px 0 12px;
    font-size: 36px;
    font-weight: 900;
}

.rakuen-machine-copy {
    max-width: 720px;
    color: var(--rakuen-ink-muted);
    line-height: 1.7;
}

.rakuen-machine-status-shell {
    padding: 24px;
}

.subtitle {
    color: var(--rakuen-ink-muted);
}

.tag {
    border-radius: var(--rakuen-pill);
    box-shadow: var(--rakuen-shadow-soft);
}

.filter-section {
    padding: 18px 20px;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,244,248,0.9));
    border: 1px solid var(--rakuen-border);
}

.filter {
    border-radius: var(--rakuen-pill);
    border: 1px solid var(--rakuen-border);
    background: #fff;
    color: var(--rakuen-ink);
    font-weight: 700;
}

.filter.active,
.filter:hover {
    background: linear-gradient(135deg, var(--rakuen-pink), #ff6b57);
    color: #fff;
}

.display-count {
    color: var(--rakuen-ink-muted);
}

.machine-card {
    border: 1px solid rgba(255,255,255,0.7);
    border-radius: 22px;
    background:
        radial-gradient(circle at top right, rgba(255,214,10,0.18), transparent 26%),
        linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,243,247,0.91));
    box-shadow: var(--rakuen-shadow);
}

.card-header {
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(115, 91, 120, 0.12);
}

.machine-label,
.game-title .label,
.stat-box .title {
    color: var(--rakuen-ink-muted);
}

.machine-number,
.title-text {
    color: var(--rakuen-ink);
}

.price-badge {
    border-radius: 16px;
    background: linear-gradient(135deg, var(--rakuen-gold-light), var(--rakuen-gold-hot));
    box-shadow: var(--rakuen-shadow-soft);
}

.status {
    border-radius: var(--rakuen-pill);
}

.stat-box {
    border: 1px solid rgba(115, 91, 120, 0.14);
    border-radius: 16px;
    background: rgba(255,255,255,0.88);
}

.enter-btn,
.disable-btn,
.processBtn,
.btn-send,
.btn-charge {
    border-radius: var(--rakuen-pill) !important;
    padding: 10px 20px !important;
    box-shadow: var(--rakuen-shadow-soft);
}

.enter-btn,
.btn-charge,
.processBtn.btn-warning {
    background: linear-gradient(135deg, var(--rakuen-green), var(--rakuen-green-deep)) !important;
}

.rakuen-account-page {
    padding: 18px 16px 40px;
}

.rakuen-account-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 28px 30px;
    margin-bottom: 20px;
}

.rakuen-account-title {
    margin: 0;
    font-size: 34px;
    font-weight: 900;
}

.rakuen-account-subtitle {
    margin: 8px 0 0;
    color: var(--rakuen-ink-muted);
}

.rakuen-account-panel {
    padding: 22px;
}

.c-table {
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.74);
    border-radius: 20px;
    background: rgba(255,255,255,0.92);
    box-shadow: var(--rakuen-shadow);
}

.c-table__cell {
    border-color: rgba(115, 91, 120, 0.1);
}

.c-table__cell:nth-child(odd) {
    background: rgba(255, 241, 246, 0.72);
}

.c-menu {
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(255,244,248,0.9));
    box-shadow: var(--rakuen-shadow);
    padding: 14px;
}

.c-menu__item {
    border-radius: 16px;
    background: rgba(255,255,255,0.92);
    box-shadow: inset 0 0 0 1px rgba(255, 117, 171, 0.12);
}

.c-menu__item span {
    color: var(--rakuen-pink-deep);
}

.c-menu__item--active {
    background: linear-gradient(135deg, var(--rakuen-pink), #ff6b57);
}

.history-table,
.table {
    overflow: hidden;
    border-radius: 18px;
}

.history-table thead th,
.table thead th {
    background: rgba(255, 241, 246, 0.84);
    color: var(--rakuen-ink);
    border-bottom-color: rgba(115, 91, 120, 0.12);
}

.history-table tbody tr,
.table tbody tr {
    background: rgba(255,255,255,0.86);
}

.alert {
    border: 0;
    border-radius: 18px;
    box-shadow: var(--rakuen-shadow-soft);
}

.rakuen-footer {
    padding: 18px 16px 30px;
    background: transparent;
}

.rakuen-footer-main {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 28px;
    padding: 32px;
}

.rakuen-footer-brand {
    display: grid;
    gap: 14px;
}

.rakuen-footer-medallion {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--rakuen-pink), var(--rakuen-gold-light));
    color: #fff;
    font-size: 28px;
    font-weight: 800;
}

.rakuen-footer-brand h3 {
    margin: 0;
    font-size: 30px;
    font-weight: 800;
}

.rakuen-footer-tagline,
.rakuen-footer-copy,
.rakuen-footer-column a,
.rakuen-footer-bottom-copy {
    color: var(--rakuen-ink-muted);
}

.rakuen-footer-columns {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.rakuen-footer-column {
    display: grid;
    align-content: start;
    gap: 8px;
}

.rakuen-footer-column h6 {
    margin-bottom: 10px;
    font-size: 14px;
    font-weight: 800;
    color: var(--rakuen-ink);
    letter-spacing: 0.08em;
}

.rakuen-footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 18px 8px 0;
}

.rakuen-footer-social {
    display: flex;
    gap: 10px;
}

.rakuen-footer-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255,255,255,0.88);
    box-shadow: var(--rakuen-shadow-soft);
}

.rakuen-support-modal .modal-content {
    border: 0;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255,255,255,0.97), rgba(255,244,248,0.92));
    box-shadow: var(--rakuen-shadow);
}

.rakuen-title-select-page {
    max-width: none;
    width: 100%;
    box-sizing: border-box;
    padding: 18px 18px 34px;
    min-height: calc(100vh - 88px);
    background: transparent;
}

.rakuen-title-select {
    position: relative;
    overflow: hidden;
    min-height: calc(100vh - 140px);
    font-family: "Noto Sans KR", "Malgun Gothic", "맑은 고딕", -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Segoe UI", sans-serif;
}

.rakuen-title-select::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 15% 12%, rgba(255, 45, 132, 0.08), transparent 24%),
        radial-gradient(circle at 86% 14%, rgba(0, 180, 216, 0.08), transparent 20%);
    pointer-events: none;
}

.rakuen-title-select__toolbar {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    padding: 14px 28px 0;
}

.rakuen-title-back-corners {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background: #fff;
    border: 1.5px solid var(--border-deep);
    border-radius: 8px;
    color: var(--rakuen-pink-deep);
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    font-family: inherit;
    transition: background 0.2s ease, border-color 0.2s ease;
}

.rakuen-title-back-corners:hover {
    background: #fff9fc;
    border-color: var(--rakuen-pink);
    color: var(--rakuen-pink-deep);
}

.rakuen-title-select__hero {
    position: relative;
    z-index: 2;
    text-align: center;
    padding: 22px 28px 10px;
}

.rakuen-title-select__line1 {
    font-family: "Zen Old Mincho", "Yu Mincho", "Hiragino Mincho ProN", "MS Mincho", Batang, serif;
    font-weight: 900;
    font-size: 36px;
    letter-spacing: 0.12em;
    line-height: 1;
    background: linear-gradient(180deg, #fff, var(--rakuen-rose), var(--rakuen-pink));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: drop-shadow(0 3px 8px rgba(255, 45, 132, 0.35));
}

.rakuen-title-select__line2 {
    margin-top: 6px;
    font-family: "Bebas Neue", "Arial Narrow", Impact, sans-serif;
    font-size: 14px;
    letter-spacing: 0.35em;
    color: var(--ink-gold);
}

.rakuen-title-select__line2 .rakuen-title-select__em {
    background: linear-gradient(90deg, var(--rakuen-pink), var(--rakuen-gold));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-weight: 700;
}

.rakuen-title-select__line3 {
    margin-top: 8px;
    font-size: 12px;
    color: var(--ink-2);
}

.rakuen-title-select__rainbow {
    height: 3px;
    max-width: 520px;
    width: 100%;
    margin: 14px auto 0;
    border-radius: 2px;
    background: var(--rakuen-rainbow);
    background-size: 200% 100%;
    animation: rakuen-title-rainbow 5s linear infinite;
}

@keyframes rakuen-title-rainbow {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 200% 50%;
    }
}

.rakuen-title-filterbar {
    position: relative;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    padding: 14px 28px 0;
}

.rakuen-filter-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 14px;
    border: 1.5px solid var(--border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.7);
    color: var(--ink-1);
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.03em;
    cursor: pointer;
    font-family: "Mochiy Pop One", "Yu Gothic", "메이리오", Meiryo, "Apple SD Gothic Neo", sans-serif;
    transition: all 0.2s;
}

.rakuen-filter-chip:hover {
    border-color: var(--rakuen-pink);
}

.rakuen-filter-chip.active {
    background: linear-gradient(135deg, var(--rakuen-pink), var(--rakuen-pink-deep));
    color: #fff;
    border-color: transparent;
    box-shadow: 0 3px 12px rgba(255, 45, 132, 0.4);
}

.rakuen-filter-search {
    margin-left: auto;
    min-width: 0;
    width: 240px;
    max-width: 100%;
    padding: 7px 14px;
    border: 1.5px solid var(--border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--ink-0);
    font-size: 13px;
    font-family: inherit;
    outline: none;
}

.rakuen-filter-search::placeholder {
    color: var(--ink-3);
    font-size: 13px;
}

.rakuen-filter-search:focus {
    border-color: var(--rakuen-pink);
}

.rakuen-title-grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    align-content: start;
    gap: 16px;
    padding: 20px 28px 40px;
}

.rakuen-title-card {
    display: block;
    padding: 10px 10px 12px;
    border-radius: 14px;
    background: linear-gradient(180deg, var(--bg-card) 0%, var(--bg-card-2) 100%);
    border: 1.5px solid var(--border-deep);
    box-shadow: var(--rakuen-shadow-soft);
    transition: all 0.2s;
    position: relative;
    overflow: hidden;
}

.rakuen-title-card:hover {
    transform: translateY(-4px);
    border-color: var(--rakuen-pink);
    box-shadow: 0 10px 30px rgba(255, 45, 132, 0.3);
}

.rakuen-title-card.hot {
    border-color: var(--rakuen-gold-hot);
    box-shadow: 0 0 20px rgba(255, 140, 0, 0.35);
}

.rakuen-title-card--disabled {
    opacity: 0.72;
    cursor: not-allowed;
}

.rakuen-title-card--disabled:hover {
    transform: none;
    border-color: var(--border-deep);
    box-shadow: var(--rakuen-shadow-soft);
}

.rakuen-title-art {
    position: relative;
    overflow: hidden;
    width: 100%;
    border-radius: 10px;
    border: 2px solid var(--cab-gold-trim);
    aspect-ratio: 1;
    background: var(--cab-wine);
    box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.4);
}

.rakuen-title-art img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.rakuen-title-art::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(0, 0, 0, 0.35) 100%);
    pointer-events: none;
}

.rakuen-title-hot-badge {
    position: absolute;
    top: 6px;
    right: 6px;
    z-index: 2;
    padding: 3px 7px;
    border-radius: 4px;
    background: linear-gradient(135deg, var(--rakuen-gold-hot), var(--hibiscus-red));
    color: #fff;
    font-family: "Bebas Neue", "Arial Narrow", Impact, sans-serif;
    font-size: 10px;
    letter-spacing: 0.15em;
    box-shadow: 0 0 12px rgba(255, 140, 0, 0.6);
    animation: rakuen-title-hot-blink 1s infinite;
}

@keyframes rakuen-title-hot-blink {
    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.75;
    }
}

.rakuen-title-meta {
    padding: 10px 2px 0;
}

.rakuen-title-bottomline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-top: 0;
}

.rakuen-title-jp {
    font-family: "Zen Old Mincho", "Yu Mincho", "Hiragino Mincho ProN", "MS Mincho", Batang, serif;
    font-weight: 700;
    font-size: 14px;
    color: var(--ink-0);
    line-height: 1.3;
    margin-bottom: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.rakuen-title-kr {
    font-size: 11px;
    color: var(--ink-2);
    margin-bottom: 8px;
}

.rakuen-title-maker {
    padding: 2px 6px;
    border-radius: 3px;
    background: rgba(255, 182, 39, 0.15);
    color: var(--ink-gold);
    font-family: "Bebas Neue", "Arial Narrow", Impact, sans-serif;
    font-size: 10px;
    letter-spacing: 0.1em;
    white-space: nowrap;
}

.rakuen-title-stats {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 4px;
    font-family: "JetBrains Mono", ui-monospace, Consolas, "SF Mono", "D2Coding", "나눔고딕코딩", monospace;
    font-size: 10px;
    font-weight: 700;
    color: var(--ink-3);
    white-space: nowrap;
}

.rakuen-title-stats .pct {
    color: var(--rakuen-pink-deep);
}

.rakuen-title-stats .rakuen-title-stat-sep {
    color: var(--ink-3);
    font-weight: 400;
}

.rakuen-title-stats .avail {
    color: var(--tropic-green-dp);
}

@media (max-width: 780px) {
    .rakuen-title-select__line1 {
        font-size: 26px;
    }

    .rakuen-title-grid {
        padding: 14px;
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
        gap: 10px;
    }
}

@media (max-width: 1199px) {
    .rakuen-home-hero,
    .rakuen-footer-main {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991px) {
    .rakuen-topbar {
        align-items: flex-start;
        min-height: auto;
        padding: 14px 0;
    }

    .rakuen-hall-selector {
        margin: 8px 0 12px;
    }

    .rakuen-nav-links {
        margin: 16px 0;
        align-items: flex-start;
    }

    .rakuen-home-title {
        font-size: 38px;
    }

    .rakuen-feature-band {
        grid-template-columns: 1fr;
    }

    .rakuen-footer-columns {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 767px) {
    .rakuen-topbar-shell {
        padding: 10px 10px 6px;
    }

    .rakuen-topbar-container,
    .rakuen-home-shell,
    .rakuen-machine-shell,
    .rakuen-account-shell {
        padding-left: 0;
        padding-right: 0;
    }

    .rakuen-home-hero,
    .rakuen-feature-band,
    .rakuen-machine-page,
    .rakuen-account-page,
    .rakuen-footer {
        padding-left: 10px;
        padding-right: 10px;
    }

    .rakuen-home-hero__content,
    .rakuen-machine-hero,
    .rakuen-account-header,
    .rakuen-footer-main {
        padding: 22px;
    }

    .rakuen-home-title {
        font-size: 30px;
    }

    .rakuen-brand-title {
        font-size: 22px;
    }

    .rakuen-topbar-container {
        padding-left: 12px;
        padding-right: 12px;
    }

    .rakuen-title-select-page {
        padding-left: 10px;
        padding-right: 10px;
        min-height: calc(100vh - 76px);
        background: transparent;
    }

    .rakuen-title-select__toolbar {
        padding-left: 14px;
        padding-right: 14px;
    }

    .rakuen-title-select__line1 {
        font-size: 26px;
    }

    .rakuen-title-filterbar {
        padding-left: 14px;
        padding-right: 14px;
    }

    .rakuen-filter-search {
        width: 100%;
        margin-left: 0;
    }

    .rakuen-title-grid {
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
        gap: 10px;
        padding: 0 14px 20px;
    }

    .rakuen-title-select {
        min-height: calc(100vh - 116px);
        overflow: visible;
    }

    .rakuen-footer-columns,
    .rakuen-footer-bottom {
        grid-template-columns: 1fr;
        flex-direction: column;
        align-items: flex-start;
    }
}

/* Machine lobby: default page scroll; wide screens use internal grid scroll */
html[data-template="front-page"]:has(.rakuen-machine-shell.rakuen-machine-skin) body,
html.machine-lobby-html body.machine-lobby-page {
    overflow-x: hidden;
    overflow-y: auto;
}

/* Machine lobby: fill viewport; document scroll off, grid/feed scroll inside (wide screens) */
@media (min-width: 992px) {
    html[data-template="front-page"]:has(.rakuen-machine-shell.rakuen-machine-skin),
    html.machine-lobby-html {
        height: 100%;
    }

    html[data-template="front-page"]:has(.rakuen-machine-shell.rakuen-machine-skin) body,
    html.machine-lobby-html body.machine-lobby-page {
        min-height: 0;
        height: 100vh;
        height: 100dvh;
        max-height: 100vh;
        max-height: 100dvh;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }

    html[data-template="front-page"]:has(.rakuen-machine-shell.rakuen-machine-skin) body > nav.layout-navbar,
    html.machine-lobby-html body.machine-lobby-page > nav.layout-navbar {
        flex-shrink: 0;
    }

    html[data-template="front-page"]:has(.rakuen-machine-shell.rakuen-machine-skin) .rakuen-machine-shell.rakuen-machine-skin,
    html.machine-lobby-html .rakuen-machine-shell.rakuen-machine-skin {
        flex: 1 1 auto;
        min-height: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }

    .rakuen-machine-shell.rakuen-machine-skin .rakuen-machine-page {
        flex: 1 1 auto;
        min-height: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }

    .rakuen-machine-shell.rakuen-machine-skin .mg-header-bar {
        flex-shrink: 0;
    }

    .rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-ticker.ticker {
        flex-shrink: 0;
    }

    .rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-layout {
        flex: 1 1 auto;
        min-height: 0;
        overflow: hidden;
        grid-template-columns: minmax(0, 1fr) 340px;
        grid-template-rows: minmax(0, 1fr);
        align-items: stretch;
    }

    .rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .rakuen-mg-primary,
    .rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby > .rakuen-machine-floor {
        display: flex;
        flex-direction: column;
        min-height: 0;
        min-width: 0;
        overflow: hidden;
    }

    .rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .legend.rakuen-mg-legend {
        flex-shrink: 0;
    }

    .rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .row-wrap {
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: auto;
        overflow-x: hidden;
        margin-bottom: 10px;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }

    .rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .row-wrap::-webkit-scrollbar {
        display: none;
        width: 0;
        height: 0;
    }

    .rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .machine-floor-count {
        flex-shrink: 0;
    }

    .rakuen-machine-shell.rakuen-machine-skin .side.rakuen-mg-side {
        min-height: 0;
        min-width: 0;
        max-height: 100%;
        overflow: hidden;
        align-self: stretch;
        display: flex;
        flex-direction: column;
    }

    .rakuen-machine-shell.rakuen-machine-skin .feed.rakuen-mg-feed {
        flex: 1 1 auto;
        min-height: 0;
    }

    .rakuen-machine-shell.rakuen-machine-skin .feed.rakuen-mg-feed .feed-list {
        max-height: none;
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: auto;
    }
}

/* =============================================================================
   Machine lobby page skin + compact header (rakuen_spa_no_gli.html)
   ============================================================================= */
.rakuen-machine-shell.rakuen-machine-skin {
    --rp-bg-1: #ffe9f3;
    --rp-bg-2: #fff3d6;
    --rp-ink-0: #3d1a3d;
    --rp-ink-1: #5a2748;
    --rp-ink-2: #8b4a6b;
    --rp-ink-3: #b07a92;
    --rp-ink-gold: #8b5a00;
    --rp-border: #ffc6dd;
    --rp-border-deep: #ff8fb8;
    --rp-border-gold: #ffd78a;
    --rp-cab-gold-trim: #d4af37;
    --rp-shadow-soft: 0 6px 20px rgba(255, 45, 132, 0.12);
    --rp-bg-card: #fffefb;
    --rp-bg-card-2: #fff5f8;
    /* Detail actions: parity with _basic/rakuen_spa_no_gli.html .btn / .btn-primary / .btn-gold */
    --tropic-green: #22c55e;
    --tropic-green-dp: #159947;
    --rakuen-pink: #ff2d84;
    --rakuen-pink-dark: #c81a6b;
    --rakuen-gold-lite: #ffd60a;
    --rakuen-gold-hot: #ff8c00;
    max-width: 100%;
    overflow-x: hidden;
    background: linear-gradient(180deg, #fffefb 0%, var(--rp-bg-1) 42%, #fff5f0 100%);
}

.rakuen-machine-shell.rakuen-machine-skin .rakuen-machine-page {
    padding: 14px 10px 12px;
    max-width: 100%;
    box-sizing: border-box;
}

.rakuen-machine-shell.rakuen-machine-skin .c-contain--label {
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
}

.rakuen-machine-shell.rakuen-machine-skin .c-contain__main {
    overflow-x: hidden !important;
    overflow-y: visible !important;
    max-width: 100%;
    min-width: 0;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.rakuen-machine-shell.rakuen-machine-skin .rakuen-machine-status-shell {
    background: rgba(255, 255, 255, 0.4) !important;
    border: 1px dashed var(--rp-border-deep) !important;
    border-radius: 18px;
    box-shadow: 0 6px 20px rgba(255, 45, 132, 0.1);
}

.rakuen-machine-shell.rakuen-machine-skin .mg-header-bar {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    padding: 14px 28px;
    margin: 0 0 0;
    background: rgba(255, 255, 255, 0.4);
    border-bottom: 1px dashed var(--rp-border-deep);
    border-radius: 0;
    position: relative;
    z-index: 2;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-header-main {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
    flex: 1 1 240px;
}

.rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-back-game {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    padding: 7px 14px;
    background: rgba(255, 255, 255, 0.92);
    border: 1.5px solid var(--rp-border-deep);
    border-radius: 10px;
    color: var(--rakuen-pink-dark);
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    letter-spacing: 0.02em;
    box-shadow: 0 2px 8px rgba(255, 45, 132, 0.08);
    transition:
        background 0.18s ease,
        border-color 0.18s ease,
        color 0.18s ease,
        box-shadow 0.18s ease;
}

.rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-back-game:hover {
    background: #fff;
    border-color: var(--rakuen-pink);
    color: var(--rakuen-pink-dark);
    box-shadow: 0 4px 14px rgba(255, 45, 132, 0.15);
}

.rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-back-game:focus-visible {
    outline: 2px solid var(--rakuen-pink);
    outline-offset: 2px;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-title-block {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
    flex: 1 1 auto;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-title-thumb {
    width: 60px;
    height: 60px;
    border-radius: 10px;
    overflow: hidden;
    border: 2px solid var(--rp-cab-gold-trim);
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.2);
    flex-shrink: 0;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-title-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-title-jp {
    font-family: "Yu Mincho", "Hiragino Mincho ProN", "MS Mincho", Batang, serif;
    font-weight: 900;
    font-size: clamp(17px, 2.4vw, 22px);
    color: var(--rp-ink-0);
    line-height: 1.15;
    word-break: break-word;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-title-sub {
    font-size: 12px;
    color: var(--rp-ink-2);
    margin-top: 4px;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-title-sub .maker {
    padding: 1px 6px;
    margin-right: 6px;
    background: rgba(255, 182, 39, 0.18);
    color: var(--rp-ink-gold);
    border-radius: 3px;
    font-family: "Bebas Neue", Impact, "Arial Narrow", sans-serif;
    font-size: 10px;
    letter-spacing: 0.1em;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-stats-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 14px 18px;
    margin-left: auto;
    justify-content: flex-end;
    flex: 0 1 auto;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-stat {
    text-align: center;
    min-width: 52px;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-stat-label {
    font-family: "Bebas Neue", Impact, "Arial Narrow", sans-serif;
    font-size: 10px;
    color: var(--rp-ink-3);
    letter-spacing: 0.16em;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-stat-value {
    font-family: "JetBrains Mono", Consolas, "SF Mono", "D2Coding", "Nanum Gothic Coding", monospace;
    font-weight: 700;
    font-size: clamp(16px, 3vw, 20px);
    color: var(--rp-ink-0);
    margin-top: 2px;
}

.rakuen-machine-shell.rakuen-machine-skin .mg-stat-value.green {
    color: var(--rakuen-green-deep);
}

.rakuen-machine-shell.rakuen-machine-skin .mg-stat-value.red {
    color: var(--rakuen-pink);
}

.rakuen-machine-shell.rakuen-machine-skin .mg-stat-value.gold {
    color: var(--rakuen-gold-hot);
}

.rakuen-machine-shell.rakuen-machine-skin .mg-stat-value.mg-queue {
    color: var(--rp-ink-3);
}

@media (max-width: 767px) {
    .rakuen-machine-shell.rakuen-machine-skin .mg-header-main {
        flex: 1 1 100%;
    }

    .rakuen-machine-shell.rakuen-machine-skin .mg-stats-inline {
        width: 100%;
        margin-left: 0;
        justify-content: space-between;
    }
}

/* Machine lobby: ticker + 2-column main (rakuen_spa_no_gli.html VIEW 2) */
.rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-ticker.ticker {
    overflow: hidden;
    padding: 8px 0;
    background: linear-gradient(
        90deg,
        rgba(255, 214, 10, 0.25) 0%,
        rgba(255, 45, 132, 0.18) 50%,
        rgba(123, 44, 191, 0.2) 100%
    );
    border-top: 1px solid var(--rp-border-gold);
    border-bottom: 1px solid var(--rp-border-deep);
    position: relative;
    z-index: 2;
}

.rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-ticker.ticker::before,
.rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-ticker.ticker::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 60px;
    z-index: 2;
    pointer-events: none;
}

.rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-ticker.ticker::before {
    left: 0;
    background: linear-gradient(90deg, var(--rp-bg-1), transparent);
}

.rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-ticker.ticker::after {
    right: 0;
    background: linear-gradient(270deg, var(--rp-bg-1), transparent);
}

.rakuen-machine-shell.rakuen-machine-skin .ticker-track {
    display: inline-flex;
    gap: 40px;
    white-space: nowrap;
    animation: rakuen-mg-ticker-scroll 55s linear infinite;
    font-size: 13px;
    font-weight: 500;
}

.rakuen-machine-shell.rakuen-machine-skin .ticker-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--rp-ink-1);
}

.rakuen-machine-shell.rakuen-machine-skin .ticker-item.jackpot {
    color: var(--rakuen-gold-hot);
    font-weight: 700;
}

.rakuen-machine-shell.rakuen-machine-skin .ticker-item.big {
    color: var(--rakuen-pink);
    font-weight: 700;
}

.rakuen-machine-shell.rakuen-machine-skin .ticker-item.info {
    color: var(--rp-ink-2);
}

.rakuen-machine-shell.rakuen-machine-skin .ticker-item .label {
    font-family: Orbitron, Impact, "Arial Black", sans-serif;
    font-size: 10px;
    font-weight: 700;
    background: linear-gradient(135deg, var(--rakuen-pink), var(--rakuen-gold));
    color: #fff;
    padding: 2px 7px;
    border-radius: 4px;
    letter-spacing: 0.05em;
}

@keyframes rakuen-mg-ticker-scroll {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

.rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 22px;
    padding: 20px 28px 20px;
    position: relative;
    z-index: 2;
    align-items: stretch;
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .rakuen-machine-floor {
    padding: 0;
    background: transparent;
    border-radius: 0;
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .legend.rakuen-mg-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 16px;
    padding: 10px 14px;
    background: rgba(255, 255, 255, 0.7);
    border: 1.5px solid var(--rp-border);
    border-radius: 12px;
    font-size: 11px;
    box-shadow: var(--rp-shadow-soft);
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--rp-ink-1);
    font-family: "JetBrains Mono", Consolas, "SF Mono", "D2Coding", "Nanum Gothic Coding", monospace;
    font-weight: 500;
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .legend-hint {
    margin-left: auto;
    font-size: 11px;
    color: var(--rp-ink-3);
    font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
    align-self: center;
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .legend-hint strong {
    color: var(--rp-ink-1);
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    flex-shrink: 0;
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .dot.idle {
    background: var(--rakuen-green);
    box-shadow: 0 0 6px var(--rakuen-green);
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .dot.occupied {
    background: var(--rakuen-pink);
    box-shadow: 0 0 6px var(--rakuen-pink);
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .dot.queue {
    background: var(--rakuen-gold);
    box-shadow: 0 0 6px var(--rakuen-gold);
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .dot.hot {
    background: var(--rakuen-gold-hot);
    box-shadow: 0 0 10px var(--rakuen-gold-hot);
    animation: rakuen-mg-dot-pulse 1.2s infinite;
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .dot.vip {
    background: linear-gradient(135deg, var(--rakuen-gold), var(--rakuen-pink));
    box-shadow: 0 0 8px var(--rakuen-gold);
}

@keyframes rakuen-mg-dot-pulse {
    0%,
    100% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0.7;
        transform: scale(1.25);
    }
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .row-wrap {
    margin-bottom: 22px;
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .row-label {
    font-family: "Mochiy Pop One", "Yu Gothic", Meiryo, "Apple SD Gothic Neo", sans-serif;
    font-size: 15px;
    color: var(--rakuen-pink-dark);
    letter-spacing: 0.08em;
    margin-bottom: 10px;
    display: flex;
    align-items: baseline;
    gap: 10px;
}

.rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .row-label span {
    font-family: "JetBrains Mono", Consolas, "SF Mono", "D2Coding", "Nanum Gothic Coding", monospace;
    font-size: 11px;
    color: var(--rp-ink-3);
    font-weight: 400;
}

.rakuen-machine-shell.rakuen-machine-skin .side.rakuen-mg-side {
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-width: 0;
}

.rakuen-machine-shell.rakuen-machine-skin .detail.rakuen-mg-detail {
    background: linear-gradient(180deg, var(--rp-bg-card), var(--rp-bg-card-2));
    border: 1.5px solid var(--rp-border-deep);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: var(--rp-shadow-soft);
    position: relative;
}

.rakuen-machine-shell.rakuen-machine-skin .detail-empty {
    padding: 44px 20px;
    text-align: center;
    color: var(--rp-ink-3);
    font-size: 13px;
}

.rakuen-machine-shell.rakuen-machine-skin .detail-empty-icon {
    font-size: 44px;
    margin-bottom: 12px;
    filter: drop-shadow(0 2px 6px rgba(255, 45, 132, 0.3));
    animation: rakuen-mg-sway 4s infinite;
}

.rakuen-machine-shell.rakuen-machine-skin .detail-empty-title {
    color: var(--rakuen-pink-dark);
    font-weight: 600;
    font-size: 14px;
}

.rakuen-machine-shell.rakuen-machine-skin .detail-empty-sub {
    font-size: 11px;
    color: var(--rp-ink-3);
    margin-top: 8px;
    line-height: 1.45;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled {
    max-height: min(52vh, 620px);
    overflow-y: auto;
    overflow-x: hidden;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled::-webkit-scrollbar {
    width: 6px;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled::-webkit-scrollbar-thumb {
    background: var(--rakuen-rose);
    border-radius: 3px;
}

/* Machine side detail panel (rakuen_spa_no_gli.html) */
.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px dashed var(--rp-border);
    background: linear-gradient(90deg, rgba(255, 182, 39, 0.1), transparent);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-preview {
    width: 64px;
    height: 64px;
    border-radius: 8px;
    overflow: hidden;
    border: 2px solid var(--rp-cab-gold-trim);
    flex-shrink: 0;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.28);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-id-box {
    font-family: Orbitron, Impact, "Arial Black", sans-serif;
    font-weight: 900;
    font-size: 22px;
    color: var(--rp-ink-0);
    padding: 6px 10px;
    background: #fff;
    border-radius: 8px;
    border: 2px solid var(--rp-border-deep);
    box-shadow: inset 0 1px 4px rgba(0, 0, 0, 0.08);
    letter-spacing: 0.06em;
    flex-shrink: 0;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-id-box--hot {
    color: var(--rakuen-gold-hot);
    border-color: var(--rakuen-gold-hot);
    box-shadow: 0 0 10px rgba(255, 140, 0, 0.4);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-id-box--occ {
    color: var(--rakuen-pink);
    border-color: var(--rakuen-pink);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-id-box--queue {
    color: var(--ink-gold);
    border-color: var(--rakuen-gold);
    background: linear-gradient(135deg, #fff, #fff6e0);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-meta {
    flex: 1;
    min-width: 0;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-title {
    font-family: "Yu Mincho", "Hiragino Mincho ProN", "MS Mincho", Batang, serif;
    font-size: 14px;
    font-weight: 700;
    color: var(--rp-ink-0);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-subtitle {
    font-family: "JetBrains Mono", Consolas, "SF Mono", "D2Coding", "Nanum Gothic Coding", monospace;
    font-size: 10px;
    color: var(--rp-ink-3);
    margin-top: 2px;
    word-break: break-all;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-state-wrap {
    padding: 10px 16px;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-state-tag {
    display: inline-block;
    font-family: "Bebas Neue", Impact, "Arial Narrow", sans-serif;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 999px;
    letter-spacing: 0.12em;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-state-tag--idle {
    background: rgba(34, 197, 94, 0.15);
    color: var(--tropic-green-dp);
    border: 1.5px solid var(--tropic-green);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-state-tag--occupied {
    background: rgba(255, 45, 132, 0.15);
    color: var(--rakuen-pink-dark);
    border: 1.5px solid var(--rakuen-pink);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-state-tag--queue {
    background: rgba(255, 182, 39, 0.18);
    color: var(--ink-gold);
    border: 1.5px solid var(--rakuen-gold);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: var(--rp-border);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-cell {
    background: var(--rp-bg-card);
    padding: 11px 13px;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-label {
    font-family: "Bebas Neue", Impact, "Arial Narrow", sans-serif;
    font-size: 10px;
    color: var(--rp-ink-3);
    letter-spacing: 0.18em;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-val {
    font-family: "JetBrains Mono", Consolas, "SF Mono", "D2Coding", "Nanum Gothic Coding", monospace;
    font-weight: 700;
    font-size: 17px;
    margin-top: 3px;
    color: var(--rp-ink-0);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-val--cyan {
    color: #0288d1;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-val--gold {
    color: var(--rakuen-gold-hot);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-val--red {
    color: var(--rakuen-pink);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-val-unit,
.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-mini {
    font-size: 11px;
    font-weight: 600;
    color: var(--rp-ink-3);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-sub {
    font-size: 10px;
    color: var(--rp-ink-3);
    margin-top: 2px;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-actions {
    padding: 14px 16px 16px;
    background: var(--rp-bg-card);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled a.rmd-btn {
    text-decoration: none;
    cursor: pointer;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled a.rmd-btn--primary:visited {
    color: #fff;
}

/* Matches rakuen_spa_no_gli.html .detail-actions .btn */
.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-btn {
    font-family: "Mochiy Pop One", "Yu Gothic", "메이리오", Meiryo, "Apple SD Gothic Neo", sans-serif;
    font-size: 14px;
    padding: 13px 14px;
    border-radius: 10px;
    border: 1.5px solid var(--rp-border-deep);
    background: #fff;
    color: var(--rp-ink-0);
    cursor: pointer;
    letter-spacing: 0.03em;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    transition: all 0.2s;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-btn:hover:not(:disabled):not(.rmd-btn--disabled) {
    border-color: var(--rakuen-pink);
    color: var(--rakuen-pink-dark);
    transform: translateY(-1px);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-btn:disabled,
.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-btn--disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-btn--primary {
    background: linear-gradient(135deg, var(--tropic-green), var(--tropic-green-dp));
    border-color: var(--tropic-green-dp);
    color: #fff;
    box-shadow: 0 4px 14px rgba(34, 197, 94, 0.35);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-btn--primary:hover:not(.rmd-btn--disabled) {
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(34, 197, 94, 0.5);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-btn--queue {
    background: linear-gradient(135deg, var(--rakuen-gold-lite), var(--rakuen-gold-hot));
    border-color: var(--rakuen-gold-hot);
    color: var(--rp-ink-0);
    box-shadow: 0 4px 14px rgba(255, 140, 0, 0.35);
}

.rakuen-machine-shell.rakuen-machine-skin #machine-detail-filled .rmd-btn--queue:hover:not(:disabled) {
    color: var(--rp-ink-0);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255, 140, 0, 0.5);
}

@keyframes rakuen-mg-sway {
    0%,
    100% {
        transform: rotate(-4deg);
    }

    50% {
        transform: rotate(4deg);
    }
}

.rakuen-machine-shell.rakuen-machine-skin .feed.rakuen-mg-feed {
    background: linear-gradient(180deg, var(--rp-bg-card), var(--rp-bg-card-2));
    border: 1.5px solid var(--rp-border-deep);
    border-radius: 14px;
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0;
    box-shadow: var(--rp-shadow-soft);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-head {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    border-bottom: 1px dashed var(--rp-border);
    background: linear-gradient(90deg, rgba(255, 45, 132, 0.08), transparent);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-title {
    font-family: "Mochiy Pop One", "Yu Gothic", Meiryo, "Apple SD Gothic Neo", sans-serif;
    font-size: 14px;
    color: var(--rakuen-pink-dark);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-live {
    display: flex;
    align-items: center;
    gap: 5px;
    font-family: "Bebas Neue", Impact, "Arial Narrow", sans-serif;
    font-size: 10px;
    color: var(--hibiscus-red);
    margin-left: auto;
    letter-spacing: 0.2em;
    font-weight: 700;
}

.rakuen-machine-shell.rakuen-machine-skin .feed-live::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--hibiscus-red);
    box-shadow: 0 0 6px var(--hibiscus-red);
    animation: rakuen-mg-pulse-tag 1.2s infinite;
}

@keyframes rakuen-mg-pulse-tag {
    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.7;
    }
}

.rakuen-machine-shell.rakuen-machine-skin .feed-list {
    padding: 6px 0;
    overflow-y: auto;
    max-height: 320px;
    flex: 0 1 auto;
    min-height: 0;
}

.rakuen-machine-shell.rakuen-machine-skin .feed-list::-webkit-scrollbar {
    width: 6px;
}

.rakuen-machine-shell.rakuen-machine-skin .feed-list::-webkit-scrollbar-thumb {
    background: var(--rakuen-rose);
    border-radius: 3px;
}

.rakuen-machine-shell.rakuen-machine-skin .feed-item {
    display: flex;
    align-items: baseline;
    gap: 10px;
    padding: 7px 16px;
    font-size: 12px;
    border-left: 3px solid transparent;
}

.rakuen-machine-shell.rakuen-machine-skin .feed-item.jackpot {
    border-left-color: var(--rakuen-gold-hot);
    background: rgba(255, 182, 39, 0.08);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-item.hot {
    border-left-color: var(--hibiscus-red);
    background: rgba(230, 57, 70, 0.06);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-item.sit {
    border-left-color: var(--rakuen-green);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-item.stand {
    border-left-color: var(--rp-ink-3);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-item.queue {
    border-left-color: var(--rakuen-gold);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-time {
    font-family: "JetBrains Mono", Consolas, "SF Mono", "D2Coding", "Nanum Gothic Coding", monospace;
    font-size: 10px;
    color: var(--rp-ink-3);
    min-width: 34px;
    flex-shrink: 0;
}

.rakuen-machine-shell.rakuen-machine-skin .feed-content {
    color: var(--rp-ink-1);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-content b {
    color: var(--rp-ink-0);
    font-family: Orbitron, Impact, "Arial Black", sans-serif;
    font-weight: 700;
    letter-spacing: 0.03em;
}

.rakuen-machine-shell.rakuen-machine-skin .feed-item.jackpot .feed-content b {
    color: var(--rakuen-gold-hot);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-item.hot .feed-content b {
    color: var(--hibiscus-red);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-item.sit .feed-content b {
    color: var(--rakuen-green-deep);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-content .cab-id.idle {
    color: var(--rakuen-green-deep);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-content .cab-id.queue {
    color: #c28800;
}

.rakuen-machine-shell.rakuen-machine-skin .feed-content .cab-id.occ {
    color: var(--rakuen-pink);
}

.rakuen-machine-shell.rakuen-machine-skin .feed-content .cab-id.hot {
    color: var(--rakuen-gold-hot);
}

@media (max-width: 991px) {
    .rakuen-machine-shell.rakuen-machine-skin .rakuen-mg-layout {
        grid-template-columns: 1fr;
        padding: 16px 14px 32px;
        gap: 18px;
    }

    .rakuen-machine-shell.rakuen-machine-skin #rakuen-machine-lobby .legend-hint {
        margin-left: 0;
        width: 100%;
    }
}

/* =============================================================================
   Machine floor (cabinet grid) — rakuen_spa_no_gli.html cabinet-box pattern
   ============================================================================= */
.rakuen-machine-floor {
    background: linear-gradient(165deg, rgba(255, 249, 240, 0.45) 0%, rgba(255, 236, 242, 0.25) 50%, transparent 100%);
    border-radius: 14px;
    padding: 12px 10px 16px;
    --mf-pink: #ff2d84;
    --mf-pink-dark: #c81a6b;
    --mf-gold: #ffb627;
    --mf-gold-hot: #ff8c00;
    --mf-gold-lite: #ffd60a;
    --mf-rose: #ff6ba8;
    --mf-green: #22c55e;
    --mf-green-dp: #0e9f47;
    --mf-hibiscus: #e63946;
    --mf-cab-wine: #1a0b1a;
    --mf-cab-wine-2: #2a1530;
    --mf-cab-gold-trim: #d4af37;
    --mf-ink-1: #5a2748;
    --mf-ink-3: #b07a92;
    --mf-border: #ffc6dd;
    --mf-shadow-soft: 0 6px 20px rgba(255, 45, 132, 0.15);
    --mf-shadow-cabinet: 0 12px 30px rgba(26, 11, 26, 0.4);
}

.machine-floor-hint {
    font-size: 12px;
    color: var(--rakuen-ink-muted);
}

.machine-floor-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 14px 16px;
    margin-bottom: 16px;
    padding: 10px 14px;
    background: rgba(255, 255, 255, 0.72);
    border: 1.5px solid var(--mf-border);
    border-radius: 12px;
    font-size: 11px;
    box-shadow: var(--mf-shadow-soft);
}

.machine-floor-legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--mf-ink-1);
    font-family: "JetBrains Mono", Consolas, "SF Mono", "D2Coding", "Nanum Gothic Coding", monospace;
    font-weight: 500;
}

.machine-floor-legend-muted {
    margin-left: auto;
    color: var(--mf-pink-dark);
    font-family: system-ui, sans-serif;
}

.machine-floor-dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    flex-shrink: 0;
}

.machine-floor-dot.idle {
    background: var(--mf-green);
    box-shadow: 0 0 6px var(--mf-green);
}

.machine-floor-dot.occupied {
    background: var(--mf-pink);
    box-shadow: 0 0 6px var(--mf-pink);
}

.machine-floor-dot.queue {
    background: var(--mf-gold);
    box-shadow: 0 0 6px var(--mf-gold);
}

.machine-floor-dot.hot {
    background: var(--mf-gold-hot);
    box-shadow: 0 0 10px var(--mf-gold-hot);
    animation: mf-pulse 1.2s infinite;
}

.machine-floor-dot.vip {
    background: linear-gradient(135deg, var(--mf-gold), var(--mf-pink));
    box-shadow: 0 0 8px var(--mf-gold);
}

@keyframes mf-pulse {
    0%,
    100% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0.7;
        transform: scale(1.25);
    }
}

.machine-floor-row-label {
    font-family: "Mochiy Pop One", "Yu Gothic", Meiryo, "Apple SD Gothic Neo", sans-serif;
    font-size: 15px;
    color: var(--mf-pink-dark);
    letter-spacing: 0.08em;
    margin-bottom: 10px;
    display: flex;
    align-items: baseline;
    gap: 10px;
}

.machine-floor-row-label span {
    font-family: "JetBrains Mono", Consolas, "SF Mono", "D2Coding", "Nanum Gothic Coding", monospace;
    font-size: 11px;
    color: var(--mf-ink-3);
    font-weight: 400;
}

.machine-floor-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 14px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.rakuen-machine-shell.rakuen-machine-skin .machine-floor-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(115px, 100%), 1fr));
}

.machine-floor-count {
    font-size: 14px;
    color: var(--rakuen-ink-muted);
}

.machine-floor-count strong {
    font-weight: 700;
}

.rakuen-machine-floor .cabinet-box {
    container-type: inline-size;
    container-name: mf-cab;
    aspect-ratio: 5 / 7;
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, var(--mf-cab-wine-2) 0%, var(--mf-cab-wine) 100%);
    border-radius: 8px 8px 12px 12px;
    padding: 3px;
    cursor: default;
    transition: transform 0.15s, box-shadow 0.2s;
    position: relative;
    box-shadow: var(--mf-shadow-cabinet);
    overflow: hidden;
    border: 2px solid var(--mf-cab-gold-trim);
}

.rakuen-machine-floor .cabinet-box::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: 6px 6px 10px 10px;
    background: linear-gradient(180deg, rgba(255, 214, 10, 0.08), transparent 30%);
    pointer-events: none;
    z-index: 1;
}

.rakuen-machine-floor .cabinet-box--playable {
    cursor: pointer;
}

.rakuen-machine-floor .cabinet-box--playable:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(255, 45, 132, 0.35), 0 0 0 2px var(--mf-pink);
}

.rakuen-machine-floor .cabinet-box--vip-locked {
    cursor: not-allowed;
}

.rakuen-machine-floor .cabinet-box--vip-locked .cab-top img {
    filter: blur(4px) brightness(0.62) saturate(0.75);
    transform: scale(1.02);
}

.rakuen-machine-floor .cabinet-box--vip-locked.cabinet-box--playable:hover {
    transform: none;
    box-shadow: var(--mf-shadow-cabinet);
}

.rakuen-machine-floor .cab-lock-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(26, 10, 30, 0.42);
    z-index: 4;
    pointer-events: none;
}

.rakuen-machine-floor .cab-lock-icon {
    font-size: clamp(18px, 5cqi, 28px);
    line-height: 1;
    filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.45));
}

.rakuen-machine-floor .cabinet-box.selected {
    box-shadow:
        0 0 0 3px var(--mf-gold-lite),
        0 0 24px rgba(255, 182, 39, 0.55),
        var(--mf-shadow-cabinet);
    transform: translateY(-2px);
}

.rakuen-machine-floor .cab-top {
    flex: 1.3;
    position: relative;
    overflow: hidden;
    border-radius: 5px 5px 0 0;
    background: #000;
    margin: 0;
    border-bottom: 2px solid var(--mf-cab-gold-trim);
}

.rakuen-machine-floor .cab-top img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s;
}

.rakuen-machine-floor .cabinet-box--playable:hover .cab-top img {
    transform: scale(1.05);
}

.rakuen-machine-floor .cab-game-caption {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 6px 8px 28px;
    font-size: 9px;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.85);
    line-height: 1.25;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    z-index: 2;
    pointer-events: none;
}

.rakuen-machine-floor .cab-top-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    padding: 4px 6px;
    background: linear-gradient(
        180deg,
        rgba(0, 0, 0, 0.28) 0%,
        transparent 38%,
        transparent 55%,
        rgba(0, 0, 0, 0.55) 100%
    );
    pointer-events: none;
    z-index: 3;
}

.rakuen-machine-floor .cab-overlay-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 3px;
    min-height: 16px;
    max-width: 72%;
}

.rakuen-machine-floor .cab-min-grade-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    min-width: 18px;
    padding: 0;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.45);
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.28);
    color: #fff;
    pointer-events: auto;
    flex-shrink: 0;
}

.rakuen-machine-floor .cab-min-grade-mark__letter {
    font-family: "Bebas Neue", Impact, "Arial Narrow", sans-serif;
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
}

.rakuen-machine-floor .cab-min-grade-mark.rakuen-grade-badge--silver .cab-min-grade-mark__letter {
    color: #1a2430;
}

.rakuen-machine-floor .cab-min-grade-mark.rakuen-grade-badge--gold .cab-min-grade-mark__letter {
    color: #3d2800;
}

.rakuen-machine-floor .cab-overlay-spacer {
    flex: 1;
}

.rakuen-machine-floor .cab-state-dot-wrap {
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    padding-bottom: 2px;
}

.rakuen-machine-floor .cab-state-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.45);
}

.rakuen-machine-floor .cabinet-box.state-idle .cab-state-dot {
    background: var(--mf-green);
    box-shadow: 0 0 6px var(--mf-green);
}

.rakuen-machine-floor .cabinet-box.state-occupied .cab-state-dot {
    background: var(--mf-pink);
    box-shadow: 0 0 6px var(--mf-pink);
}

.rakuen-machine-floor .cabinet-box.state-queue .cab-state-dot {
    background: var(--mf-gold);
    box-shadow: 0 0 6px var(--mf-gold);
}

.rakuen-machine-floor .cabinet-box.state-maint .cab-state-dot,
.rakuen-machine-floor .cabinet-box.state-offline .cab-state-dot {
    background: #888;
    box-shadow: none;
}

.rakuen-machine-floor .cab-badge {
    font-family: "Bebas Neue", Impact, "Arial Narrow", sans-serif;
    font-size: 9px;
    letter-spacing: 0.15em;
    padding: 2px 5px;
    border-radius: 3px;
    color: white;
    line-height: 1;
}

.rakuen-machine-floor .cab-badge.hot {
    background: linear-gradient(135deg, var(--mf-gold-hot), var(--mf-hibiscus));
    animation: mf-badge-blink 1s infinite;
    box-shadow: 0 0 8px rgba(255, 140, 0, 0.55);
}

@keyframes mf-badge-blink {
    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.65;
    }
}

.rakuen-machine-floor .cab-led {
    height: 24px;
    min-height: 24px;
    flex-shrink: 0;
    background: radial-gradient(ellipse at center, #0a0008, #000);
    border-top: 1px solid var(--mf-cab-gold-trim);
    border-bottom: 1px solid var(--mf-cab-gold-trim);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    box-sizing: border-box;
    padding: 0 4px;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    line-height: 1;
    color: var(--mf-gold-lite);
    text-shadow: 0 0 6px var(--mf-gold-hot), 0 0 12px var(--mf-gold-hot);
    position: relative;
    z-index: 2;
}

.rakuen-machine-floor .cab-led .cab-led-id {
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    font-family: Orbitron, "JetBrains Mono", Impact, "Arial Black", sans-serif;
    font-weight: 800;
    font-size: 9px;
    letter-spacing: 0.02em;
    line-height: 1;
    white-space: nowrap;
    word-break: keep-all;
    overflow-wrap: normal;
    hyphens: none;
    text-overflow: clip;
}

@supports (width: 1cqw) {
    .rakuen-machine-floor .cab-led .cab-led-id {
        font-size: clamp(7px, 13cqw, 10px);
    }
}

.machine-grid.machine-floor-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(115px, 100%), 1fr));
}

.rakuen-machine-floor .cabinet-box.state-occupied .cab-led {
    color: var(--mf-rose);
    text-shadow: 0 0 8px var(--mf-pink), 0 0 16px var(--mf-pink);
}

.rakuen-machine-floor .cabinet-box.state-idle .cab-led {
    color: var(--mf-green);
    text-shadow: 0 0 8px var(--mf-green), 0 0 14px var(--mf-green-dp);
}

.rakuen-machine-floor .cabinet-box.state-queue .cab-led {
    color: var(--mf-gold-lite);
    text-shadow: 0 0 8px var(--mf-gold), 0 0 14px var(--mf-gold-hot);
}

.rakuen-machine-floor .cabinet-box.is-hot .cab-led {
    animation: mf-led-flicker 0.45s infinite;
}

@keyframes mf-led-flicker {
    0%,
    100% {
        filter: brightness(1);
    }

    50% {
        filter: brightness(1.28);
    }
}

.rakuen-machine-floor .cab-lamps {
    display: flex;
    gap: 4px;
    padding: 5px 6px 2px;
    justify-content: center;
    background: linear-gradient(180deg, #1a0b1a, #0a0008);
    position: relative;
    z-index: 2;
}

.rakuen-machine-floor .cab-lamp {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 214, 10, 0.2);
}

.rakuen-machine-floor .cab-lamp.on {
    background: radial-gradient(circle at 35% 35%, var(--mf-gold-lite), var(--mf-gold-hot));
    box-shadow: 0 0 4px var(--mf-gold-hot);
}

.rakuen-machine-floor .cab-stats {
    padding: 5px 8px 5px;
    background: linear-gradient(180deg, #0a0008, #000);
    display: flex;
    flex-direction: column;
    gap: 1px;
    position: relative;
    z-index: 2;
    border-radius: 0 0 8px 8px;
}

.rakuen-machine-floor .cab-stat-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-family: "JetBrains Mono", Consolas, "SF Mono", "D2Coding", "Nanum Gothic Coding", monospace;
    font-size: 9px;
    color: rgba(255, 214, 10, 0.55);
}

.rakuen-machine-floor .cab-stat-row .v {
    color: var(--mf-gold-lite);
    font-weight: 700;
}

.rakuen-machine-floor .cabinet-box.state-occupied .cab-stat-row .v {
    color: var(--mf-rose);
}

.rakuen-machine-floor .cabinet-box.state-idle .cab-stat-row .v {
    color: var(--mf-green);
}

.rakuen-machine-floor .cabinet-box.state-queue .cab-stat-row .v {
    color: var(--mf-gold-lite);
}

.rakuen-machine-floor .cabinet-box.is-hot .cab-stat-row .v {
    color: var(--mf-gold-hot);
}

.rakuen-machine-floor .cabinet-box.is-hot {
    animation: mf-hot-rainbow 2s linear infinite;
    box-shadow: 0 0 22px rgba(255, 140, 0, 0.45), var(--mf-shadow-cabinet);
}

@keyframes mf-hot-rainbow {
    0% {
        border-color: var(--mf-pink);
    }

    25% {
        border-color: var(--mf-gold-hot);
    }

    50% {
        border-color: var(--mf-gold-lite);
    }

    75% {
        border-color: var(--mf-pink-dark);
    }

    100% {
        border-color: var(--mf-pink);
    }
}

.rakuen-machine-floor .cabinet-box.state-maint {
    opacity: 0.42;
    filter: grayscale(0.75);
    cursor: not-allowed;
}

.rakuen-machine-floor .cabinet-box.state-offline {
    opacity: 0.48;
    filter: grayscale(1);
    cursor: not-allowed;
}

.rakuen-machine-floor .cabinet-box.state-offline .cab-stats,
.rakuen-machine-floor .cabinet-box.state-maint .cab-stats {
    background: linear-gradient(180deg, #4a4a4a, #2c2c2c);
}

.rakuen-machine-floor .cabinet-box.state-offline .cab-stat-row .v,
.rakuen-machine-floor .cabinet-box.state-maint .cab-stat-row .v {
    color: rgba(255, 255, 255, 0.72);
}

.rakuen-machine-floor .cabinet-box.state-offline .cab-led,
.rakuen-machine-floor .cabinet-box.state-maint .cab-led {
    color: #c8c8c8;
    text-shadow: none;
}

@media (max-width: 767px) {
    .machine-floor-legend-muted {
        margin-left: 0;
        width: 100%;
    }

    .machine-floor-grid {
        grid-template-columns: repeat(auto-fill, minmax(min(95px, 100%), 1fr));
        gap: 10px;
    }
}
