/* Snap & Stem Language Switcher */

#ssls-overlay {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0,0,0,0.75);
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    box-sizing: border-box;
    animation: ssls-fade-in 0.3s ease;
}

@keyframes ssls-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

#ssls-modal {
    background: #1a1a1a;
    border-radius: 16px;
    width: 100%;
    max-width: 420px;
    overflow: hidden;
    font-family: 'Poppins', -apple-system, sans-serif;
    animation: ssls-slide-up 0.35s ease;
}

@keyframes ssls-slide-up {
    from { transform: translateY(30px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}

#ssls-header {
    background: #899D8C;
    padding: 28px 28px 22px;
    text-align: center;
}

.ssls-flower { font-size: 32px; display: block; margin-bottom: 8px; }

.ssls-brand {
    margin: 0;
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.5px;
}

.ssls-location {
    margin: 4px 0 0;
    font-size: 11px;
    color: rgba(255,255,255,0.7);
    letter-spacing: 1px;
    text-transform: uppercase;
}

.ssls-welcome {
    margin: 14px 0 0;
    font-size: 18px;
    font-weight: 600;
    color: #fff;
}

.ssls-prompt {
    margin: 4px 0 0;
    font-size: 12px;
    color: rgba(255,255,255,0.6);
}

#ssls-detected {
    background: rgba(137,157,140,0.2);
    border-bottom: 1px solid rgba(137,157,140,0.3);
    padding: 10px 24px;
    display: flex;
    align-items: center;
    gap: 10px;
}

#ssls-detected span { font-size: 16px; flex-shrink: 0; }

#ssls-detected-msg {
    margin: 0;
    font-size: 12px;
    color: #899D8C;
    font-weight: 500;
}

#ssls-body {
    padding: 28px;
    text-align: center;
}

#ssls-toggle-row {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 28px;
    height: 60px;
}

.ssls-lang-label {
    position: absolute;
    font-size: 12px;
    font-weight: 700;
    color: rgba(255,255,255,0.3);
    letter-spacing: 1px;
    text-transform: uppercase;
    transition: color 0.3s;
    cursor: pointer;
    line-height: 1;
    display: flex;
    align-items: center;
    gap: 5px;
    white-space: nowrap;
}

#ssls-label-en { right: calc(50% + 60px); }
#ssls-label-fr { left: calc(50% + 60px); }

.ssls-lang-label.active { color: #fff; }.ssls-lang-label.active .ssls-fr-flag { opacity: 1 !important; }

.ssls-ca-flag, .ssls-fr-flag {
    opacity: 0.35;
    transition: opacity 0.3s;
    border-radius: 2px;
    flex-shrink: 0;
}

.ssls-switch-wrap {
    flex-shrink: 0;
}

.ssls-switch {
    display: inline-block;
    flex-shrink: 0;
}

/* 3D Toggle */
.ssls-switch {
    font-size: 17px;
    position: relative;
    display: inline-block;
    width: 5em;
    height: 2.5em;
    user-select: none;
    cursor: pointer;
}

.ssls-switch .ssls-cb {
    opacity: 0;
    width: 0;
    height: 0;
}

.ssls-tog {
    position: absolute;
    cursor: pointer;
    width: 100%;
    height: 100%;
    background-color: #899D8C;
    border-radius: 0.1em;
    transition: 0.4s;
    text-transform: uppercase;
    font-weight: 700;
    overflow: hidden;
    box-shadow:
        -0.3em 0 0 0 #899D8C,
        -0.3em 0.3em 0 0 #899D8C,
        0.3em 0 0 0 #899D8C,
        0.3em 0.3em 0 0 #899D8C,
        0 0.3em 0 0 #899D8C;
}

.ssls-tog > .ssls-tog-left {
    position: absolute;
    display: flex;
    width: 50%;
    height: 88%;
    background-color: #f3f3f3;
    color: #333;
    left: 0;
    bottom: 0;
    align-items: center;
    justify-content: center;
    transform-origin: right;
    transform: rotateX(10deg);
    transform-style: preserve-3d;
    transition: all 150ms;
    font-size: 12px;
}

.ssls-tog-left::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background-color: rgb(206,206,206);
    transform-origin: center left;
    transform: rotateY(90deg);
}

.ssls-tog-left::after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background-color: rgb(112,112,112);
    transform-origin: center bottom;
    transform: rotateX(90deg);
}

.ssls-tog > .ssls-tog-right {
    position: absolute;
    display: flex;
    width: 50%;
    height: 88%;
    background-color: #f3f3f3;
    color: rgb(206,206,206);
    right: 1px;
    bottom: 0;
    align-items: center;
    justify-content: center;
    transform-origin: left;
    transform: rotateX(10deg) rotateY(-45deg);
    transform-style: preserve-3d;
    transition: all 150ms;
    font-size: 12px;
}

.ssls-tog-right::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background-color: rgb(206,206,206);
    transform-origin: center right;
    transform: rotateY(-90deg);
}

.ssls-tog-right::after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background-color: rgb(112,112,112);
    transform-origin: center bottom;
    transform: rotateX(90deg);
}

.ssls-switch input:checked + .ssls-tog > .ssls-tog-left {
    transform: rotateX(10deg) rotateY(45deg);
    color: rgb(206,206,206);
}

.ssls-switch input:checked + .ssls-tog > .ssls-tog-right {
    transform: rotateX(10deg) rotateY(0deg);
    color: #899D8C;
}

#ssls-card {
    background: #242424;
    border-radius: 12px;
    padding: 18px 24px;
    border: 1px solid rgba(255,255,255,0.08);
    margin-bottom: 20px;
    transition: all 0.3s;
}

#ssls-card-flag { margin: 0 0 8px; font-size: 28px; }

#ssls-card-greeting {
    margin: 0 0 4px;
    font-size: 15px;
    font-weight: 600;
    color: #fff;
}

#ssls-card-sub {
    margin: 0;
    font-size: 12px;
    color: rgba(255,255,255,0.4);
}

#ssls-confirm {
    background: #899D8C;
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 12px 36px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    font-family: 'Poppins', sans-serif;
    letter-spacing: 0.5px;
    transition: background 0.2s, transform 0.1s;
    width: 100%;
    max-width: 240px;
}

#ssls-confirm:hover { background: #7a8e7d; }
#ssls-confirm:active { transform: scale(0.98); }
#ssls-confirm:disabled { background: #4a7a5a; cursor: default; }

#ssls-persist-note {
    margin: 12px 0 0;
    font-size: 11px;
    color: rgba(255,255,255,0.2);
}

@media (max-width: 480px) {
    #ssls-modal { border-radius: 12px; }
    #ssls-header { padding: 20px 20px 16px; }
    #ssls-body { padding: 20px; }
}

/* Mobile */
@media (max-width: 480px) {
    #ssls-modal { border-radius: 12px; }
    #ssls-header { padding: 20px 16px 16px; }
    .ssls-brand { font-size: 18px; }
    .ssls-welcome { font-size: 16px; }
    #ssls-body { padding: 20px 16px; }
    #ssls-label-en { right: calc(50% + 54px); font-size: 11px; }
    #ssls-label-fr { left: calc(50% + 54px); font-size: 11px; }
    .ssls-switch { font-size: 15px; }
    #ssls-card { padding: 14px 16px; }
    #ssls-confirm { padding: 11px 28px; font-size: 13px; }
}
