/* NOR / _web-qr — peste Bootstrap 5. Fundal + card; variabile pentru temele rest_N. */

.tap-qr-page {
    --tap-bg: #1a1d21;
    --tap-text: #f8f9fa;
    --tap-muted: rgba(255, 255, 255, 0.65);
    --tap-accent: #2dd4bf;
    --tap-accent-hover: #5eead4;
    --tap-accent-bg: rgba(45, 212, 191, 0.15);
    /* Culoare „solidă” a cardului; transparența e aplicată în .tap-qr-card (color-mix + blur). */
    --tap-card: rgb(28, 32, 44);
    --tap-border: rgba(255, 255, 255, 0.12);
    --tap-star-idle: rgba(255, 255, 255, 0.35);
    --tap-btn-text: #0f172a;
    --bs-font-sans-serif: Helvetica, Arial, sans-serif;
    --bs-body-font-family: var(--bs-font-sans-serif);
    --bs-body-font-weight: 300;
    font-family: var(--bs-body-font-family);
    font-weight: var(--bs-body-font-weight);
    margin: 0;
    min-height: 100vh;
    color: var(--tap-text);
}

.tap-qr-bg {
    position: fixed;
    inset: 0;
    z-index: 0;
    background-image: var(--tap-bg-image);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #1a0a2e;
}

.tap-qr-overlay {
    position: fixed;
    inset: 0;
    z-index: 1;
    background: rgba(8, 6, 20, 0.58);
    pointer-events: none;
}

.tap-qr-shell {
    z-index: 2;
}

/* Sigla e în card; păstrăm safe-area + spațiu deasupra cardului */
.tap-qr-main {
    padding-top: max(1.25rem, env(safe-area-inset-top, 0px));
}

@media (min-width: 768px) {
    .tap-qr-main {
        padding-top: max(1.5rem, env(safe-area-inset-top, 0px));
    }
}

@media (max-width: 767.98px) {
    .tap-qr-main {
        padding-top: max(1rem, calc(env(safe-area-inset-top, 0px) + 0.75rem));
        padding-bottom: max(2.5rem, env(safe-area-inset-bottom, 0px)) !important;
    }
}

.tap-qr-logo {
    max-height: 48px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.45));
}

@media (min-width: 576px) {
    .tap-qr-logo {
        max-height: 64px;
    }
}

@media (min-width: 992px) {
    .tap-qr-logo {
        max-height: 72px;
    }
}

.tap-qr-container {
    max-width: 900px;
}

@media (min-width: 1200px) {
    .tap-qr-container {
        max-width: 960px;
    }
}

.tap-qr-card {
    /* Fundal vizibil prin card, dar suficient contrast pentru text — ajustează procentul dacă e nevoie. */
    background: color-mix(in srgb, var(--tap-card) 32%, transparent) !important;
    backdrop-filter: blur(4px) saturate(1.08);
    -webkit-backdrop-filter: blur(4px) saturate(1.08);
    border: 1px solid color-mix(in srgb, var(--tap-border) 55%, transparent) !important;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.28);
}

.tap-qr-loading.tap-qr-card {
    background: color-mix(in srgb, var(--tap-card) 32%, transparent) !important;
}

/* Lizibilitate pe text pe fundal foto */
.tap-qr-card .tap-qr-title,
.tap-qr-card .tap-form-title,
.tap-qr-card .tap-aspect-name {
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
    font-weight: 500;
}

.tap-qr-card .tap-qr-hint,
.tap-qr-card .tap-qr-intro,
.tap-qr-card .text-white-50 {
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
}

/* Linie subțire sub subtitluri — doar cât lățimea textului, centrată */
.tap-qr-card .tap-qr-intro:not(:empty),
.tap-qr-card .tap-qr-hint,
.tap-qr-card .tap-form-title,
.tap-qr-card .tap-aspect-name {
    display: block;
    width: fit-content;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 0.2rem;
    border-bottom: 1px solid color-mix(in srgb, rgba(255, 255, 255, 0.35) 45%, transparent);
}

/* Stele principale */
.tap-star-btn {
    min-height: 2.75rem;
    font-size: 1.5rem;
    line-height: 1;
    border: 1px solid color-mix(in srgb, var(--tap-border) 70%, transparent);
    background: rgba(255, 255, 255, 0.1);
    color: var(--tap-star-idle);
    cursor: pointer;
    padding: 0;
    transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.1s;
}

@media (min-width: 768px) {
    .tap-star-btn {
        min-height: 3.25rem;
        font-size: 1.85rem;
    }
}

.tap-star-btn:hover,
.tap-star-btn:focus {
    color: var(--tap-accent);
    border-color: var(--tap-accent);
    background: var(--tap-accent-bg);
    outline: none;
}

.tap-star-btn.is-selected,
.tap-star-btn.is-active {
    color: var(--tap-accent);
    background: var(--tap-accent-bg);
    border-color: var(--tap-accent);
}

.tap-qr-title {
    line-height: 1.25;
}

.tap-qr-card .tap-textarea,
.tap-qr-card .form-control.tap-textarea {
    background: rgba(255, 255, 255, 0.08);
    border-color: var(--tap-border);
    color: var(--tap-text);
}

.tap-qr-card .tap-textarea::placeholder,
.tap-qr-card .form-control.tap-textarea::placeholder {
    color: var(--tap-muted);
}

.tap-qr-card .tap-textarea:focus,
.tap-qr-card .form-control.tap-textarea:focus {
    background: rgba(255, 255, 255, 0.1);
    border-color: var(--tap-accent);
    color: var(--tap-text);
    box-shadow: 0 0 0 0.2rem rgba(45, 212, 191, 0.25);
}

.tap-qr-card .tap-tel-input {
    width: 100%;
    max-width: 16rem;
    margin-left: auto;
    margin-right: auto;
}

.tap-qr-card .tap-contact-row .tap-contact-input {
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
}

.tap-btn-primary {
    background: var(--tap-accent) !important;
    border: none !important;
    color: var(--tap-btn-text) !important;
}

.tap-btn-primary:hover,
.tap-btn-primary:focus {
    background: var(--tap-accent-hover) !important;
    color: var(--tap-btn-text) !important;
}

.tap-btn-primary:disabled {
    opacity: 0.55;
}

.tap-aspect-name {
    font-size: 1.125rem;
}

/* Stele pe aspecte: doar în formular (mini-carduri ca .tap-star-btn) */
.tap-aspect-row .tap-mini-stars {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.22rem;
    flex-wrap: nowrap;
    width: 100%;
}

.tap-aspect-row .tap-mini-stars button {
    flex: 0 0 auto;
    box-sizing: border-box;
    width: 2.35rem;
    min-height: 2.95rem;
    font-size: 1.45rem;
    padding: 0.22rem 0;
    line-height: 1;
    border: 1px solid color-mix(in srgb, var(--tap-border) 70%, transparent);
    background: rgba(255, 255, 255, 0.1);
    border-radius: 0.55rem;
    color: var(--tap-star-idle);
    transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.1s;
}

@media (min-width: 768px) {
    .tap-aspect-row .tap-mini-stars {
        gap: 0.28rem;
    }

    .tap-aspect-row .tap-mini-stars button {
        width: 2.72rem;
        min-height: 3.35rem;
        font-size: 1.68rem;
        border-radius: 0.62rem;
    }
}

.tap-aspect-row .tap-mini-stars button:hover,
.tap-aspect-row .tap-mini-stars button:focus {
    color: var(--tap-accent);
    border-color: var(--tap-accent);
    background: var(--tap-accent-bg);
    outline: none;
}

.tap-aspect-row .tap-mini-stars button.is-on {
    color: var(--tap-accent);
    background: var(--tap-accent-bg);
    border-color: var(--tap-accent);
}

/* Servicii: puțin mai mari decât mâncare/băuturi/atmosferă; sub stelele principale (.tap-star-btn) */
.tap-aspect-row .tap-mini-stars[data-aspect="servicii"] button {
    width: 2.65rem;
    min-height: 3.25rem;
    font-size: 1.58rem;
    padding: 0.18rem 0;
    border-radius: 0.58rem;
}

@media (min-width: 768px) {
    .tap-aspect-row .tap-mini-stars[data-aspect="servicii"] button {
        width: calc(2.72rem * 1.08);
        min-height: calc(3.35rem * 1.08);
        font-size: calc(1.68rem * 1.08);
        border-radius: 0.68rem;
    }
}

/* display=2: două aspecte pe rând — stele mai mici ca să încapă în jumătate de card */
.tap-qr-display-2 .tap-aspect-pair .tap-aspect-name {
    font-size: 0.95rem;
    padding-bottom: 0.1rem;
}

.tap-qr-display-2 .tap-aspect-pair .tap-mini-stars {
    gap: 0.1rem;
}

.tap-qr-display-2 .tap-aspect-pair .tap-mini-stars button {
    width: 1.72rem;
    min-height: 2.35rem;
    font-size: 1.08rem;
    border-radius: 0.42rem;
}

.tap-qr-display-2 .tap-aspect-pair .tap-mini-stars[data-aspect="servicii"] button {
    width: 1.95rem;
    min-height: 2.62rem;
    font-size: 1.22rem;
    border-radius: 0.48rem;
}

@media (min-width: 400px) {
    .tap-qr-display-2 .tap-aspect-pair .tap-mini-stars button {
        width: 1.92rem;
        min-height: 2.52rem;
        font-size: 1.18rem;
    }

    .tap-qr-display-2 .tap-aspect-pair .tap-mini-stars[data-aspect="servicii"] button {
        width: 2.12rem;
        min-height: 2.78rem;
        font-size: 1.32rem;
    }
}

@media (min-width: 768px) {
    .tap-qr-display-2 .tap-aspect-pair .tap-aspect-name {
        font-size: 1.05rem;
    }

    .tap-qr-display-2 .tap-aspect-pair .tap-mini-stars {
        gap: 0.14rem;
    }

    .tap-qr-display-2 .tap-aspect-pair .tap-mini-stars button {
        width: 2.18rem;
        min-height: 2.85rem;
        font-size: 1.32rem;
    }

    .tap-qr-display-2 .tap-aspect-pair .tap-mini-stars[data-aspect="servicii"] button {
        width: calc(2.18rem * 1.1);
        min-height: calc(2.85rem * 1.1);
        font-size: calc(1.32rem * 1.08);
        border-radius: 0.58rem;
    }
}

/* Alert compatibil cu JS care setează text — Bootstrap afișează cu .d-none; folosim hidden nativ */
#tap-qr-error[hidden] {
    display: none !important;
}

#tap-qr-error:not([hidden]) {
    display: block !important;
}
