/* ============================================================
   Palapa Shortcode Frontend — shortcode.css
   Estética: tropical móvil-first, limpio y funcional
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=DM+Sans:wght@400;500;600&display=swap');

.psc-wrap {
    font-family: 'DM Sans', sans-serif;
    max-width: 540px;
    margin: 0 auto;
    color: #1a1a1a;
}

/* ---- LOGIN ---- */
.psc-login {
    display: flex;
    justify-content: center;
    padding: 40px 16px;
}
.psc-login__box {
    background: #fffdf9;
    border: 1px solid #ddd5c8;
    border-radius: 18px;
    padding: 44px 36px;
    text-align: center;
    width: 100%;
    box-shadow: 0 8px 40px rgba(0,0,0,.10);
}
.psc-login__icon {
    font-size: 52px;
    margin-bottom: 12px;
}
.psc-login__title {
    font-family: 'DM Serif Display', serif;
    font-size: 24px;
    font-weight: 400;
    margin: 0 0 6px;
    color: #2d5a27;
}
.psc-login__sub {
    font-size: 13px;
    color: #6b7280;
    margin: 0 0 28px;
}
.psc-login__field {
    display: flex;
    gap: 8px;
}
.psc-login__field input {
    flex: 1;
    padding: 12px 16px;
    border: 2px solid #ddd5c8;
    border-radius: 10px;
    font-size: 15px;
    font-family: 'DM Sans', sans-serif;
    outline: none;
    transition: border-color .2s;
}
.psc-login__field input:focus {
    border-color: #2d5a27;
}
.psc-login__field button {
    padding: 12px 22px;
    background: #2d5a27;
    color: #fff;
    border: none;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s;
    font-family: 'DM Sans', sans-serif;
}
.psc-login__field button:hover { background: #3d7a35; }
.psc-login__error {
    margin: 12px 0 0;
    font-size: 13px;
    color: #c0392b;
    min-height: 18px;
}

/* ---- TOPBAR ---- */
.psc-topbar {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #2d5a27;
    color: #fff;
    border-radius: 14px 14px 0 0;
    padding: 16px 22px;
}
.psc-topbar__logo {
    font-family: 'DM Serif Display', serif;
    font-size: 16px;
    flex: 1;
}
.psc-topbar__clock {
    font-size: 13px;
    opacity: .8;
    font-variant-numeric: tabular-nums;
}
.psc-badge {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .05em;
    padding: 5px 12px;
    border-radius: 999px;
}
.psc-badge--abierto { background: #e8a020; color: #fff; }
.psc-badge--cerrado { background: rgba(255,255,255,.15); color: rgba(255,255,255,.7); }

/* ---- NOTICE ---- */
.psc-notice {
    padding: 12px 18px;
    font-size: 13px;
    font-weight: 600;
    border-radius: 0;
    background: #e8f5e9;
    color: #2d5a27;
    border-left: 4px solid #2d5a27;
}
.psc-notice--error {
    background: #fdecea;
    color: #c0392b;
    border-color: #c0392b;
}

/* ---- PANEL ---- */
.psc-panel {
    border: 1px solid #ddd5c8;
    border-top: none;
    border-radius: 0 0 14px 14px;
    overflow: hidden;
    background: #fffdf9;
}

/* ---- CARDS ---- */
.psc-card {
    padding: 22px 22px 18px;
    border-bottom: 1px solid #ede8e0;
}
.psc-card:last-child { border-bottom: none; }
.psc-card__title {
    font-family: 'DM Serif Display', serif;
    font-size: 16px;
    font-weight: 400;
    color: #2d5a27;
    margin: 0 0 14px;
}

/* ---- RADIOS ---- */
.psc-radios {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.psc-radio {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 10px 16px;
    border: 2px solid #ddd5c8;
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    transition: all .2s;
    background: #fff;
    user-select: none;
}
.psc-radio:hover  { border-color: #3d7a35; background: #f0f7ee; }
.psc-radio--on    { border-color: #2d5a27; background: #e8f5e0; color: #2d5a27; font-weight: 600; }
.psc-radio input  { display: none; }

/* ---- DÍAS ---- */
.psc-dias {
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
}
.psc-dia {
    padding: 9px 14px;
    border: 2px solid #ddd5c8;
    border-radius: 8px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    transition: all .2s;
    background: #fff;
    user-select: none;
}
.psc-dia:hover { border-color: #e74c3c; background: #fdf0ee; }
.psc-dia--on   { border-color: #c0392b; background: #fdecea; color: #c0392b; }
.psc-dia input { display: none; }

/* ---- RANGE ---- */
.psc-range-row {
    display: flex;
    align-items: center;
    gap: 16px;
}
.psc-range-row input[type="range"] {
    -webkit-appearance: none;
    flex: 1;
    height: 5px;
    border-radius: 999px;
    background: linear-gradient(to right, #2d5a27 0%, #2d5a27 50%, #ddd5c8 50%);
    outline: none;
    cursor: pointer;
}
.psc-range-row input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 20px; height: 20px;
    border-radius: 50%;
    background: #2d5a27;
    border: 3px solid #fff;
    box-shadow: 0 2px 6px rgba(0,0,0,.2);
    cursor: pointer;
}
.psc-range-val {
    font-family: 'DM Serif Display', serif;
    font-size: 20px;
    color: #2d5a27;
    min-width: 65px;
    white-space: nowrap;
}

/* ---- TURNOS ---- */
.psc-turnos {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
@media (max-width: 480px) { .psc-turnos { grid-template-columns: 1fr; } }
.psc-turno {
    background: #f5f0e8;
    border: 1px solid #ddd5c8;
    border-radius: 10px;
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.psc-turno--d { border-left: 3px solid #e8a020; }
.psc-turno--c { border-left: 3px solid #1a6b8a; }
.psc-turno__label {
    font-family: 'DM Serif Display', serif;
    font-size: 14px;
    color: #1a1a1a;
}
.psc-turno label {
    display: flex;
    flex-direction: column;
    font-size: 11px;
    font-weight: 600;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: .04em;
    gap: 4px;
}
.psc-turno input[type="time"] {
    font-family: 'DM Sans', sans-serif;
    font-size: 16px;
    padding: 7px 10px;
    border: 2px solid #ddd5c8;
    border-radius: 7px;
    background: #fff;
    outline: none;
    transition: border-color .2s;
}
.psc-turno input[type="time"]:focus { border-color: #2d5a27; }

/* ---- FOOTER / BOTÓN ---- */
.psc-footer {
    padding: 20px 22px;
    background: #f5f0e8;
}
.psc-btn {
    width: 100%;
    padding: 15px;
    background: #2d5a27;
    color: #fff;
    border: none;
    border-radius: 10px;
    font-family: 'DM Sans', sans-serif;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s, transform .15s;
    box-shadow: 0 4px 14px rgba(45,90,39,.3);
}
.psc-btn:hover   { background: #3d7a35; transform: translateY(-1px); }
.psc-btn:active  { transform: translateY(0); }
.psc-btn:disabled { opacity: .6; cursor: not-allowed; }

/* ---- CARD BOTONES DE SECCIÓN ---- */
.psc-card--btns {
    border-bottom: 2px solid #ede8e0;
    background: #f9f6f0;
}
.psc-card__subdesc {
    font-size: 12px;
    color: #6b7280;
    margin: -8px 0 16px;
    line-height: 1.5;
}

/* ---- FILA DE SECCIÓN ---- */
.psc-seccion-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid #ede8e0;
    flex-wrap: wrap;
}
.psc-seccion-row:last-child { border-bottom: none; }

.psc-seccion-label {
    font-size: 13px;
    font-weight: 600;
    color: #1a1a1a;
    flex: 1;
    min-width: 140px;
}

.psc-seccion-btns {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

/* ---- BOTONES SHOW / HIDE ---- */
.psc-sec-btn {
    padding: 8px 16px;
    border-radius: 8px;
    border: 2px solid transparent;
    font-size: 12px;
    font-weight: 700;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    transition: all .18s;
    letter-spacing: .02em;
}
.psc-sec-btn:disabled { opacity: .5; cursor: not-allowed; }

/* Show button */
.psc-sec-btn--show {
    background: #f0f7ee;
    border-color: #b8d9b3;
    color: #2d5a27;
}
.psc-sec-btn--show:hover:not(:disabled) {
    background: #e0f0dc;
    border-color: #2d5a27;
}
.psc-sec-btn--show.psc-sec-btn--active {
    background: #2d5a27;
    border-color: #2d5a27;
    color: #fff;
    box-shadow: 0 2px 8px rgba(45,90,39,.3);
}

/* Hide button */
.psc-sec-btn--hide {
    background: #fdecea;
    border-color: #f5b8b3;
    color: #c0392b;
}
.psc-sec-btn--hide:hover:not(:disabled) {
    background: #fad9d6;
    border-color: #c0392b;
}
.psc-sec-btn--hide.psc-sec-btn--active {
    background: #c0392b;
    border-color: #c0392b;
    color: #fff;
    box-shadow: 0 2px 8px rgba(192,57,43,.3);
}

/* ---- Pre-apertura turno ---- */
.psc-turno--pre {
    border-left: 3px solid #8b5cf6;
}

/* ---- 3 columnas en turnos cuando hay 3 ---- */
.psc-turnos--3 {
    grid-template-columns: 1fr 1fr 1fr;
}
@media (max-width: 600px) {
    .psc-turnos--3 { grid-template-columns: 1fr; }
    .psc-seccion-row { flex-direction: column; align-items: flex-start; }
}

/* ---- Card Quick control ---- */
.psc-card--quick {
    background: #f0f7ee;
    border-left: 4px solid #2d5a27;
}
.psc-quick-save {
    margin-top: 14px;
}
.psc-btn--sm {
    padding: 10px 28px;
    font-size: 13px;
    width: auto;
    box-shadow: none;
}

/* ---- Sección info (emoji + label + id) ---- */
.psc-seccion-info {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
}
.psc-seccion-emoji { font-size: 18px; flex-shrink: 0; }
.psc-seccion-label { font-size: 13px; font-weight: 600; }
.psc-seccion-id {
    font-size: 10px;
    background: rgba(0,0,0,.07);
    padding: 2px 6px;
    border-radius: 4px;
    color: #6b7280;
    flex-shrink: 0;
}

/* ---- Toggle wrap ---- */
.psc-toggle-wrap {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

/* re-estilo rows para nueva estructura */
.psc-seccion-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid #ede8e0;
    flex-wrap: wrap;
}
.psc-seccion-row:last-child { border-bottom: none; }

/* ================================================================
   STICKY BAR — guardado flotante
   ================================================================ */
.psc-sticky-bar {
    position: fixed;
    bottom: -80px;
    left: 0; right: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 20px;
    background: #1a1a1a;
    color: #fff;
    box-shadow: 0 -4px 20px rgba(0,0,0,.35);
    transition: bottom .3s cubic-bezier(.4,0,.2,1);
    max-width: 600px;
    margin: 0 auto;
    border-radius: 14px 14px 0 0;
}
/* Sólo visible dentro de .psc-wrap ancho máximo */
.psc-sticky-bar {
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 540px;
}
.psc-sticky-bar--visible {
    bottom: 0;
}
.psc-sticky-bar--quick {
    bottom: 0;
    max-width: 540px;
    position: fixed;
    left: 50%; transform: translateX(-50%);
}
.psc-sticky-bar__msg {
    font-size: 13px;
    font-weight: 600;
    color: #f4c060;
}
.psc-btn--sticky {
    width: auto;
    padding: 10px 24px;
    font-size: 14px;
    background: #2d5a27;
    box-shadow: none;
    flex-shrink: 0;
}
.psc-btn--sticky:hover { background: #3d7a35; transform: none; }

/* ================================================================
   OVERRIDE INDICATOR — fila con override manual
   ================================================================ */
.psc-row--override .psc-seccion-label::after {
    content: ' 🔒';
    font-size: 11px;
    opacity: .7;
}
.psc-row--override {
    background: #fffbea;
    border-radius: 6px;
    padding-left: 6px;
}

/* ---- Botón reset overrides ---- */
#psc-btn-reset-overrides {
    display: none;
    width: 100%;
    margin: 8px 0 0;
    padding: 9px;
    background: transparent;
    border: 2px dashed #c0392b;
    border-radius: 8px;
    color: #c0392b;
    font-size: 12px;
    font-weight: 700;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    transition: all .2s;
}
#psc-btn-reset-overrides:hover {
    background: #fdecea;
}

/* ================================================================
   FESTIVOS EN SHORTCODE
   ================================================================ */
.psc-festivos-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    margin-bottom: 8px;
}
@media (max-width: 420px) { .psc-festivos-grid { grid-template-columns: 1fr; } }

.psc-festivo-row {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 7px 10px;
    border: 2px solid #ddd5c8;
    border-radius: 7px;
    background: #fff;
    cursor: pointer;
    transition: all .18s;
    user-select: none;
}
.psc-festivo-row input[type="checkbox"] {
    width: 14px; height: 14px;
    accent-color: #c0392b;
    flex-shrink: 0;
    cursor: pointer;
}
.psc-festivo-row--on {
    border-color: #c0392b;
    background: #fdecea;
}
.psc-festivo-fecha {
    font-family: monospace;
    font-size: 11px;
    font-weight: 700;
    color: #c0392b;
    flex-shrink: 0;
}
.psc-festivo-nombre {
    font-size: 11px;
    color: #1a1a1a;
    line-height: 1.3;
}

/* ---- Textarea en shortcode ---- */
.psc-textarea {
    width: 100%;
    padding: 8px 12px;
    border: 2px solid #ddd5c8;
    border-radius: 8px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    line-height: 1.5;
    resize: vertical;
    outline: none;
    transition: border-color .2s;
    background: #fff;
}
.psc-textarea:focus { border-color: #2d5a27; }

/* ---- code tag en shortcode ---- */
.psc-card code {
    font-size: 10px;
    background: rgba(0,0,0,.07);
    padding: 1px 5px;
    border-radius: 3px;
}

/* ================================================================
   BOTÓN GUARDAR SIEMPRE VISIBLE — TOP DEL PANEL
   ================================================================ */
.psc-save-top {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: #1a1a1a;
    position: sticky;
    top: 0;
    z-index: 100;
    border-radius: 0;
}
.psc-btn--save-top {
    width: auto;
    padding: 12px 28px;
    font-size: 15px;
    font-weight: 700;
    background: #2d5a27;
    box-shadow: 0 2px 8px rgba(45,90,39,.4);
    flex-shrink: 0;
}
.psc-btn--save-top:hover { background: #3d7a35; transform: none; }
.psc-save-top__status {
    font-size: 13px;
    font-weight: 600;
    color: #f4c060;
}

/* ============================================================
   v4.0.2 fixes: cleaner shortcode layout + bilingual fields
   ============================================================ */
.psc-panel {
    border-top: 1px solid #ddd5c8;
    border-radius: 14px;
}
.psc-topbar {
    border-radius: 14px 14px 0 0;
}
.psc-save-top {
    position: static;
    top: auto;
    z-index: auto;
    background: #fffdf9;
    border-bottom: 1px solid #ede8e0;
    padding: 14px 22px;
    border-radius: 0;
    flex-wrap: wrap;
}
.psc-btn--save-top {
    background: #2d5a27;
    color: #fff;
    box-shadow: none;
    border-radius: 10px;
}
.psc-save-top__status {
    color: #2d5a27;
}
.psc-field-label {
    display: block;
    font-size: 12px;
    font-weight: 700;
    color: #2d5a27;
    margin: 12px 0 6px;
}
.psc-textarea {
    width: 100%;
}
@media (max-width: 540px) {
    .psc-save-top,
    .psc-topbar,
    .psc-card {
        padding-left: 16px;
        padding-right: 16px;
    }
    .psc-topbar {
        gap: 8px;
        flex-wrap: wrap;
    }
    .psc-badge {
        margin-left: auto;
    }
}


/* === Fix v4.0.2: shortcode controls readable and mobile-safe === */
.psc-toggle-wrap a.psc-sec-btn {
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.psc-card--btns .psc-seccion-row {
    gap: 12px;
}
.psc-turnos.psc-turnos--3 {
    grid-template-columns: 1fr;
    gap: 14px;
}
.psc-turno label {
    width: 100%;
}
.psc-turno input[type="time"] {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}
.psc-festivo-row {
    display: grid;
    grid-template-columns: 90px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
}
.psc-festivo-check {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    cursor: pointer;
}
.psc-festivo-nombre-input,
.psc-festivo-fecha-input {
    width: 100%;
    box-sizing: border-box;
    padding: 10px 12px;
    border: 1px solid #ddd5c8;
    border-radius: 8px;
    background: #fff;
    font-family: 'DM Sans', sans-serif;
}
.psc-festivo-nuevo {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid #ede8e0;
}
.psc-festivo-nuevo h4 {
    margin: 0 0 10px;
    font-size: 13px;
    color: #2d5a27;
}
.psc-festivo-nuevo-row {
    display: grid;
    grid-template-columns: 95px minmax(0, 1fr);
    gap: 10px;
}
@media (max-width: 520px) {
    .psc-festivo-row,
    .psc-festivo-nuevo-row {
        grid-template-columns: 1fr;
    }
    .psc-seccion-row {
        align-items: stretch;
    }
    .psc-toggle-wrap {
        width: 100%;
    }
    .psc-toggle-wrap .psc-sec-btn {
        flex: 1;
    }
}

/* Palapa shortcode quick save: keep save button reachable */
.psc-save-top {
    position: sticky;
    top: 0;
    z-index: 9999;
    background: #fffdf9;
    border-bottom: 1px solid #ddd5c8;
    padding: 12px 16px;
}
.psc-toggle-wrap a.psc-sec-btn {
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* ================================================================
   v4.0.5 final: botón Save siempre visible en shortcode
   ================================================================ */
.psc-save-top {
    position: sticky !important;
    top: 0 !important;
    z-index: 99999 !important;
    background: #fffdf9 !important;
    border-bottom: 1px solid #ede8e0 !important;
    box-shadow: 0 4px 14px rgba(0,0,0,.08) !important;
}
.psc-sec-btn--active {
    pointer-events: none;
}


/* v4.0.6 — Estado real desde JSON y aviso visual de cambios sin guardar */
.psc-sec-saved {
    display: inline-flex;
    width: fit-content;
    margin-top: 6px;
    padding: 4px 9px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
}
.psc-sec-saved--visible { background:#e8f5e0; color:#2d5a27; border:1px solid #2d5a27; }
.psc-sec-saved--hidden { background:#fdecea; color:#c0392b; border:1px solid #c0392b; }
.psc-btn--dirty {
    background:#c0392b !important;
    box-shadow:0 0 0 4px rgba(192,57,43,.18), 0 8px 24px rgba(0,0,0,.20) !important;
}

/* ================================================================
   v4.0.8 — Section visibility: ordered layout for shortcode
   Makes the saved state readable and separates section, state and actions.
   ================================================================ */
#psc-section-visibility .psc-seccion-row {
    display: grid !important;
    grid-template-columns: minmax(220px, 1fr) minmax(130px, 160px) minmax(190px, auto) !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 18px 0 !important;
    border-bottom: 1px solid #ede8e0 !important;
}

#psc-section-visibility .psc-seccion-info {
    display: grid !important;
    grid-template-columns: 28px 1fr !important;
    grid-template-areas:
        "emoji label"
        "emoji id" !important;
    align-items: center !important;
    gap: 4px 10px !important;
    min-width: 0 !important;
}

#psc-section-visibility .psc-seccion-emoji {
    grid-area: emoji !important;
    font-size: 22px !important;
    line-height: 1 !important;
    text-align: center !important;
}

#psc-section-visibility .psc-seccion-label {
    grid-area: label !important;
    font-size: 15px !important;
    line-height: 1.25 !important;
    font-weight: 700 !important;
    color: #1a1a1a !important;
    min-width: 0 !important;
}

#psc-section-visibility .psc-seccion-id {
    grid-area: id !important;
    justify-self: start !important;
    display: inline-flex !important;
    margin-top: 2px !important;
    padding: 5px 8px !important;
    border-radius: 7px !important;
    background: #f0ede7 !important;
    color: #6b7280 !important;
    font-size: 11px !important;
    font-weight: 700 !important;
}

#psc-section-visibility .psc-sec-state {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    min-height: 54px !important;
    padding: 8px 12px !important;
    border-radius: 12px !important;
    border: 1px solid transparent !important;
    white-space: normal !important;
    text-align: left !important;
}

#psc-section-visibility .psc-sec-state__label {
    display: block !important;
    margin-bottom: 2px !important;
    font-size: 10px !important;
    line-height: 1.1 !important;
    letter-spacing: .05em !important;
    text-transform: uppercase !important;
    font-weight: 800 !important;
    opacity: .75 !important;
}

#psc-section-visibility .psc-sec-state__value {
    display: block !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
}

#psc-section-visibility .psc-sec-state--visible {
    background: #e8f5e0 !important;
    color: #2d5a27 !important;
    border-color: #8fbd87 !important;
}

#psc-section-visibility .psc-sec-state--hidden {
    background: #fdecea !important;
    color: #c0392b !important;
    border-color: #efaaa3 !important;
}

#psc-section-visibility .psc-toggle-wrap {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    justify-self: end !important;
    min-width: 190px !important;
}

#psc-section-visibility .psc-toggle-wrap .psc-sec-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 48px !important;
    padding: 11px 14px !important;
    border-radius: 10px !important;
    text-decoration: none !important;
    font-size: 13px !important;
    font-weight: 800 !important;
}

/* Hide the old compact badge if a cached template still prints it */
#psc-section-visibility .psc-sec-saved {
    display: none !important;
}

@media (max-width: 720px) {
    #psc-section-visibility .psc-seccion-row {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
        padding: 18px 0 !important;
    }
    #psc-section-visibility .psc-sec-state {
        width: 100% !important;
        min-height: auto !important;
    }
    #psc-section-visibility .psc-toggle-wrap {
        width: 100% !important;
        min-width: 0 !important;
        justify-self: stretch !important;
    }
    #psc-section-visibility .psc-toggle-wrap .psc-sec-btn {
        width: 100% !important;
    }
}

/* ================================================================
   v4.0.9 — Section visibility: no clipping inside shortcode panel
   The shortcode panel is narrow even on desktop, so the section rows
   must stack instead of using 3 columns. This keeps Show/Hide visible.
   ================================================================ */
#psc-section-visibility {
    overflow: visible !important;
}

#psc-section-visibility .psc-seccion-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    align-items: stretch !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 20px 0 !important;
    overflow: visible !important;
}

#psc-section-visibility .psc-seccion-info {
    display: grid !important;
    grid-template-columns: 34px 1fr !important;
    grid-template-areas:
        "emoji label"
        "emoji id" !important;
    width: 100% !important;
}

#psc-section-visibility .psc-sec-state {
    width: 100% !important;
    max-width: 100% !important;
    min-height: auto !important;
    box-sizing: border-box !important;
}

#psc-section-visibility .psc-toggle-wrap {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    justify-self: stretch !important;
    box-sizing: border-box !important;
}

#psc-section-visibility .psc-toggle-wrap .psc-sec-btn {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    white-space: nowrap !important;
}

#psc-section-visibility .psc-sec-btn--hide {
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
}

@media (min-width: 680px) {
    #psc-section-visibility .psc-seccion-row {
        grid-template-columns: minmax(0, 1fr) 190px !important;
        grid-template-areas:
            "info state"
            "buttons buttons" !important;
        gap: 12px 16px !important;
    }
    #psc-section-visibility .psc-seccion-info { grid-area: info !important; }
    #psc-section-visibility .psc-sec-state { grid-area: state !important; }
    #psc-section-visibility .psc-toggle-wrap { grid-area: buttons !important; }
}


/* ============================================================
   FINAL OVERRIDE — Holidays / Días festivos en shortcode
   Mantiene una sola columna, textos completos y campos editables.
   ============================================================ */
.psc-wrap .psc-festivos-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    margin-top: 16px !important;
    margin-bottom: 18px !important;
    width: 100% !important;
}

.psc-wrap .psc-festivo-row {
    display: grid !important;
    grid-template-columns: 92px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 12px !important;
    width: 100% !important;
    padding: 14px 16px !important;
    border: 2px solid #ddd5c8 !important;
    border-radius: 12px !important;
    background: #fffdf9 !important;
    box-sizing: border-box !important;
    overflow: visible !important;
}

.psc-wrap .psc-festivo-row--on {
    border-color: #c0392b !important;
    background: #fdecea !important;
}

.psc-wrap .psc-festivo-check {
    display: flex !important;
    align-items: center !important;
    gap: 9px !important;
    min-width: 0 !important;
    cursor: pointer !important;
}

.psc-wrap .psc-festivo-check input[type="checkbox"] {
    display: inline-block !important;
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    accent-color: #c0392b !important;
}

.psc-wrap .psc-festivo-fecha {
    display: inline-block !important;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    color: #9f2e24 !important;
    white-space: nowrap !important;
}

.psc-wrap .psc-festivo-nombre-input {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 48px !important;
    padding: 12px 14px !important;
    border: 2px solid #ede8e0 !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    color: #1a1a1a !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    line-height: 1.35 !important;
    box-sizing: border-box !important;
    text-overflow: clip !important;
}

.psc-wrap .psc-festivo-nombre-input:focus,
.psc-wrap .psc-festivo-fecha-input:focus {
    outline: none !important;
    border-color: #2d5a27 !important;
    box-shadow: 0 0 0 3px rgba(45, 90, 39, .12) !important;
}

.psc-wrap .psc-festivo-nuevo {
    margin-top: 18px !important;
    padding: 18px !important;
    border: 2px dashed #ddd5c8 !important;
    border-radius: 12px !important;
    background: #f5f0e8 !important;
}

.psc-wrap .psc-festivo-nuevo h4 {
    margin: 0 0 12px !important;
    font-size: 15px !important;
    color: #2d5a27 !important;
}

.psc-wrap .psc-festivo-nuevo-row {
    display: grid !important;
    grid-template-columns: 110px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: center !important;
}

.psc-wrap .psc-festivo-fecha-input,
.psc-wrap .psc-festivo-nuevo .psc-festivo-nombre-input {
    min-height: 48px !important;
    padding: 12px 14px !important;
    font-size: 15px !important;
    border: 2px solid #ede8e0 !important;
    border-radius: 10px !important;
    background: #fff !important;
    color: #1a1a1a !important;
    box-sizing: border-box !important;
}

@media (max-width: 640px) {
    .psc-wrap .psc-festivo-row {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
        padding: 14px !important;
    }
    .psc-wrap .psc-festivo-check {
        justify-content: flex-start !important;
    }
    .psc-wrap .psc-festivo-nuevo-row {
        grid-template-columns: 1fr !important;
    }
}

/* ============================================================
   v4.1.2 — Holidays edit/delete usability
   ============================================================ */
.psc-wrap .psc-festivo-row {
    grid-template-columns: 118px minmax(0, 1fr) 132px !important;
    align-items: center !important;
}
.psc-wrap .psc-festivo-check {
    min-height: 48px !important;
    padding: 8px 10px !important;
    border-radius: 10px !important;
    background: rgba(255,255,255,.55) !important;
}
.psc-wrap .psc-festivo-check input[type="checkbox"] {
    width: 26px !important;
    height: 26px !important;
    min-width: 26px !important;
    cursor: pointer !important;
}
.psc-wrap .psc-festivo-delete {
    width: 100% !important;
    min-height: 46px !important;
    padding: 10px 12px !important;
    border: 2px solid #c0392b !important;
    border-radius: 10px !important;
    background: #fff !important;
    color: #c0392b !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    font-family: 'DM Sans', sans-serif !important;
    cursor: pointer !important;
    white-space: nowrap !important;
}
.psc-wrap .psc-festivo-delete:hover {
    background: #fdecea !important;
}
.psc-wrap .psc-festivo-row--deleted {
    display: none !important;
}
@media (max-width: 720px) {
    .psc-wrap .psc-festivo-row {
        grid-template-columns: 1fr !important;
    }
    .psc-wrap .psc-festivo-delete {
        width: 100% !important;
    }
}

/* --- Added: closed-menu mode and forced checkout control --- */
.psc-mode-box {
    margin-top: 16px;
    padding: 14px;
    background: #fffdf9;
    border: 1px solid #ddd5c8;
    border-radius: 12px;
    display: grid;
    gap: 12px;
}
.psc-select {
    width: 100%;
    padding: 12px 14px;
    border: 2px solid #ddd5c8;
    border-radius: 10px;
    background: #fff;
    font-size: 14px;
    font-family: 'DM Sans', sans-serif;
}
.psc-force-buy {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px;
    border: 1px solid #ddd5c8;
    border-radius: 10px;
    background: #f5f0e8;
    font-size: 13px;
    line-height: 1.35;
    cursor: pointer;
}
.psc-force-buy input { margin-top: 2px; }

/* Shift switch inside schedule card */
.psc-mini-check {
    display: flex !important;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border: 1px solid #ddd5c8;
    border-radius: 10px;
    background: #fff;
    font-weight: 700;
    color: #2d5a27;
}
.psc-mini-check input {
    width: 18px;
    height: 18px;
    accent-color: #2d5a27;
}

/* Modo cerrado único: menú visible, checkout bloqueado */
.psc-mode-fixed{
    margin:10px 0 14px;
    padding:12px 14px;
    border:1px solid #2d5a27;
    background:#e8f5e0;
    color:#2d5a27;
    border-radius:10px;
    font-weight:700;
    line-height:1.35;
}

/* Menú público por shortcode: ligero y mobile friendly */
.palapa-public-menu{max-width:1180px;margin:0 auto;padding:14px 14px 42px;color:#102018}
.palapa-public-note{text-align:center;margin:0 0 12px;color:#293b35;font-size:17px}
.palapa-public-lang{text-align:center;margin:16px 0 20px}
.palapa-public-lang a{display:inline-block;padding:11px 20px;background:#03281b;color:#fff!important;text-decoration:none;border-radius:8px;font-weight:700;box-shadow:0 3px 10px rgba(0,0,0,.18)}
.palapa-public-nav{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:20px auto 32px}
.palapa-public-nav button{color:#fff;border:0;border-radius:7px;padding:12px 16px;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 2px 7px rgba(0,0,0,.12)}
.palapa-public-nav .breakfast-btn{background:#ffb74d}.palapa-public-nav .lunch-btn{background:#4caf50}.palapa-public-nav .pizza-btn{background:#d70035}.palapa-public-nav .drinks-btn{background:#2196f3}.palapa-public-nav .beer-btn{background:#ff5722}.palapa-public-nav .cocktails-btn{background:#9c27b0}
.palapa-menu-section{margin:38px auto}.palapa-menu-title{font-size:34px;line-height:1.15;margin:0 0 6px;color:#0d171b}.palapa-menu-time{margin:0 0 24px;color:#5a6862}.palapa-menu-group{margin:24px auto 36px}.palapa-menu-group-head{border-bottom:2px solid #03281b;margin-bottom:18px;padding-bottom:10px}.palapa-menu-group h3{font-size:24px;margin:0 0 6px;color:#102018}.palapa-menu-group .tag-title{font-size:17px;color:#315247;margin:0;font-weight:500}.palapa-menu-products .woocommerce ul.products{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;margin:0!important;padding:0!important}.palapa-menu-products .woocommerce ul.products li.product{margin:0!important;text-align:center}.palapa-menu-products img{height:auto!important;object-fit:contain}
@media(max-width:768px){.palapa-public-menu{padding:10px 13px 32px}.palapa-public-nav{display:grid;grid-template-columns:1fr 1fr;gap:9px}.palapa-public-nav button{width:100%;font-size:14px;padding:12px 9px}.palapa-menu-title{font-size:29px}.palapa-menu-group h3{font-size:22px}.palapa-menu-products .woocommerce ul.products{gap:16px}}
@media(max-width:480px){.palapa-public-nav{grid-template-columns:1fr}.palapa-public-lang a{width:100%;max-width:330px}.palapa-menu-section{margin:30px auto}.palapa-menu-products .woocommerce ul.products li.product{width:100%!important}}

/* ============================================================
   Public menu nav buttons — mobile comfort fix v4.2.3
   ============================================================ */
.palapa-public-nav{
    gap: 16px !important;
    margin: 24px auto 36px !important;
    padding: 0 12px !important;
}
.palapa-public-nav button{
    min-height: 52px !important;
    padding: 15px 24px !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    line-height: 1.15 !important;
    letter-spacing: .01em !important;
    white-space: normal !important;
    text-align: center !important;
    box-shadow: 0 6px 16px rgba(0,0,0,.14) !important;
    transform: translateZ(0);
}
.palapa-public-nav button:active,
.palapa-public-nav button.palapa-nav-active{
    transform: scale(.97) !important;
    filter: brightness(.96) !important;
}
@media (max-width: 768px){
    .palapa-public-nav{
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 14px !important;
        max-width: 620px !important;
    }
    .palapa-public-nav button{
        width: 100% !important;
        max-width: none !important;
        padding: 16px 12px !important;
        font-size: 15.5px !important;
    }
}
@media (max-width: 420px){
    .palapa-public-nav{
        grid-template-columns: 1fr !important;
        max-width: 320px !important;
        gap: 13px !important;
    }
    .palapa-public-nav button{
        min-height: 54px !important;
        font-size: 16px !important;
    }
}

@media (max-width: 640px){
    .palapa-public-nav{
        grid-template-columns: 1fr !important;
        max-width: 360px !important;
        gap: 12px !important;
    }
    .palapa-public-nav button{
        min-height: 56px !important;
        padding: 14px 12px !important;
        font-size: 15.5px !important;
    }
}
