/* Teddy Cookie Policy — frontend banner & preferences modal.
   Tokens are driven by CSS custom properties injected from PHP (TCP_Frontend::inline_vars).
   Design source: cookie-policy mockup + Selenium element design process. */

/* The HTML [hidden] attribute is overridden by our explicit display rules below;
   restore the spec behaviour with !important so JS can hide via el.hidden = true. */
.tcp-banner[hidden],
.tcp-modal[hidden] { display: none !important; }

.tcp-banner {
    position: fixed;
    z-index: 9000;
    width: calc(100% - calc(var(--tcp-inset) * 2));
    max-width: var(--tcp-max-width, 360px);
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;

    background: var(--tcp-bg, rgba(34, 56, 73, 0.9));
    -webkit-backdrop-filter: blur(24px);
    backdrop-filter: blur(24px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--tcp-radius, 16px);
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.45);

    color: var(--tcp-text, rgba(255, 255, 255, 0.8));
    font-family: "Inter", ui-sans-serif, system-ui, sans-serif;
    line-height: 1.5;

    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.35s ease, transform 0.35s ease;
}

.tcp-banner--show {
    opacity: 1;
    transform: translateY(0);
}

.tcp-banner--bottom-right  { bottom: var(--tcp-inset); right: var(--tcp-inset); }
.tcp-banner--bottom-left   { bottom: var(--tcp-inset); left:  var(--tcp-inset); }
.tcp-banner--bottom-center { bottom: var(--tcp-inset); left: 50%; transform: translateX(-50%) translateY(12px); }
.tcp-banner--bottom-center.tcp-banner--show { transform: translateX(-50%) translateY(0); }

.tcp-banner__row {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.tcp-banner__icon {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.75rem;
    background: var(--tcp-accent-soft, rgba(48, 127, 144, 0.1));
    color: var(--tcp-accent, #6DD5E1);
    display: flex;
    align-items: center;
    justify-content: center;
}

.tcp-banner__copy {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.tcp-banner__heading {
    margin: 0;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--tcp-accent, #6DD5E1);
}

.tcp-banner__body {
    margin: 0;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.55;
    color: var(--tcp-text, rgba(255, 255, 255, 0.8));
}

.tcp-banner__link {
    margin-left: 0.25rem;
    color: var(--tcp-link, #fff);
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    transition: border-color 0.2s ease;
    text-decoration: none;
}
.tcp-banner__link:hover {
    border-bottom-color: rgba(255, 255, 255, 1);
}

.tcp-banner__actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-top: 0.25rem;
}

.tcp-banner__btn {
    flex: 1 1 0;
    padding: 0.5rem 1rem;
    font-family: inherit;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border-radius: 0.5rem;
    border: 0;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.15s ease;
}

.tcp-banner__btn--ghost {
    color: var(--tcp-custom-fg, rgba(255, 255, 255, 0.5));
    background: var(--tcp-custom-bg, rgba(255, 255, 255, 0.05));
}
.tcp-banner__btn--ghost:hover {
    color: var(--tcp-text-strong, #fff);
    background: rgba(255, 255, 255, 0.1);
}

.tcp-banner__btn--accept {
    color: var(--tcp-accept-fg, #223849);
    background: var(--tcp-accept-bg, #6DD5E1);
    box-shadow: 0 10px 15px -3px var(--tcp-accent-glow, rgba(109, 213, 225, 0.15));
}
.tcp-banner__btn--accept:hover {
    background: #ffffff;
}

.tcp-banner__btn:active {
    transform: scale(0.98);
}

/* Preferences modal */

.tcp-modal {
    position: fixed;
    inset: 0;
    z-index: 9100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}

.tcp-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 25, 35, 0.6);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.tcp-modal__panel {
    position: relative;
    width: 100%;
    max-width: 480px;
    max-height: calc(100vh - 3rem);
    overflow-y: auto;
    background: var(--tcp-bg, rgba(34, 56, 73, 0.95));
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--tcp-radius, 16px);
    padding: 1.5rem;
    color: var(--tcp-text, rgba(255, 255, 255, 0.8));
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.6);
}

.tcp-modal__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.5rem;
}

.tcp-modal__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 900;
    color: var(--tcp-text-strong, #fff);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.tcp-modal__close {
    background: transparent;
    border: 0;
    color: var(--tcp-text, rgba(255, 255, 255, 0.7));
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    padding: 0.25rem 0.5rem;
}
.tcp-modal__close:hover { color: #fff; }

.tcp-modal__intro {
    margin: 0 0 1rem;
    font-size: 12px;
    line-height: 1.6;
}

.tcp-modal__list {
    list-style: none;
    margin: 0 0 1.25rem;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.tcp-modal__item {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 0.75rem;
    padding: 0.75rem 1rem;
}

.tcp-modal__label {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
}

.tcp-modal__checkbox {
    margin-top: 0.25rem;
    width: 1rem;
    height: 1rem;
    accent-color: var(--tcp-accent, #6DD5E1);
}

.tcp-modal__cat {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    flex: 1;
}

.tcp-modal__cat-name {
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--tcp-text-strong, #fff);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.tcp-modal__pill {
    font-size: 9px;
    font-weight: 900;
    color: var(--tcp-accept-fg, #223849);
    background: var(--tcp-accent, #6DD5E1);
    padding: 0.15rem 0.5rem;
    border-radius: 9999px;
    letter-spacing: 0.1em;
}

.tcp-modal__cat-desc {
    font-size: 11px;
    color: var(--tcp-text, rgba(255, 255, 255, 0.7));
    line-height: 1.5;
}

.tcp-modal__foot {
    display: flex;
    gap: 0.5rem;
}

@media (max-width: 480px) {
    .tcp-banner {
        left: var(--tcp-inset);
        right: var(--tcp-inset);
        width: auto;
        max-width: none;
    }
    .tcp-banner--bottom-right,
    .tcp-banner--bottom-left { left: var(--tcp-inset); right: var(--tcp-inset); }
}
