/* Pinocchio shop — common UI (badges, modal, glass cards, login) */

/* Header shop slot — cart + account icons */
.pn-icon-btn {
  position: relative;
  background: transparent;
  border: 0;
  cursor: pointer;
  width: 38px; height: 38px;
  display: inline-flex;
  align-items: center; justify-content: center;
  color: var(--creme);
  border-radius: 6px;
  transition: background .2s;
  text-decoration: none;
}
.pn-icon-btn:hover { background: rgba(255, 248, 231, 0.12); }
.header.is-scrolled .pn-icon-btn { color: var(--brun); }
.header.is-scrolled .pn-icon-btn:hover { background: rgba(43, 26, 14, 0.06); }
.pn-badge {
  position: absolute; top: 2px; right: 2px;
  min-width: 18px; height: 18px;
  background: var(--rouge); color: var(--creme);
  border-radius: 999px; padding: 0 5px;
  font-size: 11px; font-weight: 700; line-height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: 'Crimson Pro', serif;
}

/* Login modal */
#pn-login {
  position: fixed; inset: 0; z-index: 300;
  visibility: hidden;
}
#pn-login.is-open { visibility: visible; }
.pn-modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(43, 26, 14, 0.5);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  opacity: 0; transition: opacity .25s ease;
}
#pn-login.is-open .pn-modal-backdrop { opacity: 1; }
.pn-modal {
  position: absolute;
  top: 50%; left: 50%; transform: translate(-50%, -45%);
  background: rgba(255, 248, 231, 0.96);
  backdrop-filter: blur(20px) saturate(150%);
  -webkit-backdrop-filter: blur(20px) saturate(150%);
  border: 1px solid rgba(255, 248, 231, 0.6);
  border-radius: 12px; padding: 36px 32px 28px;
  width: 92%; max-width: 420px;
  box-shadow: 0 30px 80px rgba(43, 26, 14, 0.3);
  opacity: 0; transition: all .3s ease;
}
#pn-login.is-open .pn-modal { opacity: 1; transform: translate(-50%, -50%); }
.pn-modal-eyebrow {
  font-family: 'Crimson Pro', serif; font-style: italic; font-weight: 600;
  letter-spacing: 3px; text-transform: uppercase; font-size: 13px;
  color: var(--rouge); text-align: center; margin-bottom: 8px;
}
.pn-modal h3 {
  font-family: 'Playfair Display', serif; font-style: italic; font-weight: 400;
  font-size: 32px; color: var(--brun); text-align: center; margin: 0 0 6px;
}
.pn-modal-sub {
  text-align: center; color: var(--gris); font-style: italic;
  font-size: 14px; margin: 0 0 24px;
}
.pn-modal label {
  display: block; font-family: 'Crimson Pro', serif; font-style: italic; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase; font-size: 13px;
  color: var(--rouge); margin: 14px 0 6px;
}
.pn-modal input {
  width: 100%; padding: 11px 14px;
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid rgba(43, 26, 14, 0.15);
  border-radius: 5px; font-family: inherit; font-size: 15px; color: var(--brun);
}
.pn-modal input:focus { outline: 2px solid var(--rouge); outline-offset: 2px; }
.pn-modal-submit {
  width: 100%; margin-top: 22px;
  padding: 13px 18px; background: var(--rouge); color: var(--creme);
  border: 0; border-radius: 5px; font-family: 'Crimson Pro', serif;
  font-size: 14px; letter-spacing: 1.5px; text-transform: uppercase;
  cursor: pointer; transition: background .2s; font-weight: 500;
}
.pn-modal-submit:hover { background: var(--rouge-dark); }
.pn-modal-foot {
  text-align: center; font-size: 12px; color: var(--gris);
  font-style: italic; margin-top: 14px;
}
.pn-modal-close {
  position: absolute; top: 12px; right: 14px;
  background: transparent; border: 0; cursor: pointer;
  width: 32px; height: 32px; font-size: 26px;
  color: var(--brun); opacity: .6;
}
.pn-modal-close:hover { opacity: 1; }

/* Glass card utility */
.pn-glass {
  background: rgba(255, 248, 231, 0.55);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(255, 248, 231, 0.7);
  border-radius: 10px;
  box-shadow: 0 8px 30px -8px rgba(43, 26, 14, 0.18);
}
.pn-glass-dark {
  background: rgba(43, 26, 14, 0.55);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(255, 248, 231, 0.1);
  border-radius: 10px;
  color: var(--creme);
  box-shadow: 0 8px 30px -8px rgba(0, 0, 0, 0.4);
}

/* Add-to-cart button on menu page */
.dish-add {
  margin-left: 8px;
  background: transparent; border: 1.5px solid var(--rouge);
  color: var(--rouge); cursor: pointer; padding: 4px 10px;
  border-radius: 999px; font-family: 'Crimson Pro', serif;
  font-size: 12px; letter-spacing: 1px; text-transform: uppercase;
  transition: all .2s; font-weight: 500; flex-shrink: 0;
}
.dish-add:hover { background: var(--rouge); color: var(--creme); transform: scale(1.05); }
.dish-add::before { content: "+ "; font-weight: 700; }
.dish-add:active { transform: scale(.95); }
