  :root {
    --navy: #1a1f3a;
    --navy-deep: #0f1329;
    --navy-light: #2a3055;
    --lavender: #b8a9d4;
    --lavender-soft: #d9cfe8;
    --lavender-dark: #8a7aa8;
    --silver: #d4d8de;
    --cloud: #f5f3f8;
    --cream: #fdfbff;
    --ink: #13172b;
    --accent: #b8a9d4;
  }
  * { -webkit-font-smoothing: antialiased; }
  html { scroll-behavior: smooth; }
  body {
    font-family: 'Inter', system-ui, sans-serif;
    color: var(--ink);
    background: var(--cream);
  }
  .font-display { font-family: 'Oswald', sans-serif; letter-spacing: 0.02em; }
  .font-heavy { font-family: 'Bowlby One SC', 'Oswald', sans-serif; letter-spacing: 0.01em; }

  .bg-navy { background-color: var(--navy); }
  .bg-navy-deep { background-color: var(--navy-deep); }
  .bg-navy-light { background-color: var(--navy-light); }
  .bg-lavender { background-color: var(--lavender); }
  .bg-lavender-soft { background-color: var(--lavender-soft); }
  .bg-cloud { background-color: var(--cloud); }
  .bg-cream { background-color: var(--cream); }
  .text-navy { color: var(--navy); }
  .text-lavender { color: var(--lavender); }
  .text-lavender-soft { color: var(--lavender-soft); }
  .text-lavender-dark { color: var(--lavender-dark); }
  .border-navy { border-color: var(--navy); }
  .border-lavender { border-color: var(--lavender); }

  /* Storm hero */
  .storm-bg {
    background:
      radial-gradient(ellipse 80% 50% at 30% 10%, rgba(184,169,212,0.35) 0%, transparent 60%),
      radial-gradient(ellipse 60% 40% at 80% 20%, rgba(217,207,232,0.25) 0%, transparent 55%),
      radial-gradient(ellipse 100% 70% at 50% 100%, rgba(26,31,58,0.4) 0%, transparent 70%),
      linear-gradient(180deg, #1a1f3a 0%, #0f1329 100%);
    position: relative;
    overflow: hidden;
  }
  .storm-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.72 0 0 0 0 0.66 0 0 0 0 0.83 0 0 0 0.08 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
    opacity: 0.4;
    pointer-events: none;
  }

  /* Lightning flash layers */
  .lightning-layer {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    mix-blend-mode: screen;
  }
  .lightning-1 {
    background: radial-gradient(ellipse 40% 60% at 25% 30%, rgba(217,207,232,0.8) 0%, transparent 55%);
    animation: flash1 11s ease-in infinite;
  }
  .lightning-2 {
    background: radial-gradient(ellipse 35% 50% at 75% 20%, rgba(184,169,212,0.7) 0%, transparent 50%);
    animation: flash2 17s ease-in infinite;
  }
  .lightning-3 {
    background: radial-gradient(ellipse 25% 40% at 50% 60%, rgba(255,255,255,0.4) 0%, transparent 45%);
    animation: flash3 23s ease-in infinite;
  }
  @keyframes flash1 {
    0%, 92%, 100% { opacity: 0; }
    93% { opacity: 0.6; }
    94% { opacity: 0.15; }
    95% { opacity: 0.8; }
    96%, 99% { opacity: 0; }
  }
  @keyframes flash2 {
    0%, 40%, 100% { opacity: 0; }
    41% { opacity: 0.7; }
    42% { opacity: 0.2; }
    43% { opacity: 0.5; }
    44%, 99% { opacity: 0; }
  }
  @keyframes flash3 {
    0%, 65%, 100% { opacity: 0; }
    66% { opacity: 0.4; }
    67% { opacity: 0.1; }
    68% { opacity: 0.6; }
    69%, 99% { opacity: 0; }
  }

  /* Drifting cloud atmosphere */
  .cloud-drift {
    position: absolute;
    pointer-events: none;
    border-radius: 50%;
    filter: blur(40px);
    opacity: 0.4;
  }
  .cloud-drift-1 {
    width: 50vw;
    height: 20vh;
    top: 15%;
    left: -20vw;
    background: radial-gradient(ellipse, rgba(184,169,212,0.5) 0%, transparent 70%);
    animation: drift1 45s linear infinite;
  }
  .cloud-drift-2 {
    width: 40vw;
    height: 18vh;
    top: 45%;
    right: -15vw;
    background: radial-gradient(ellipse, rgba(217,207,232,0.4) 0%, transparent 70%);
    animation: drift2 60s linear infinite;
  }
  @keyframes drift1 {
    0% { transform: translateX(0); }
    100% { transform: translateX(130vw); }
  }
  @keyframes drift2 {
    0% { transform: translateX(0); }
    100% { transform: translateX(-130vw); }
  }

  /* Giant bolt watermark */
  .bolt-watermark {
    position: absolute;
    right: 2%;
    top: 50%;
    transform: translateY(-50%) rotate(8deg);
    height: 94%;
    width: auto;
    color: var(--lavender);
    opacity: 0.05;
    pointer-events: none;
    z-index: 1;
  }
  @media (min-width: 1024px) {
    .bolt-watermark { height: 96%; opacity: 0.07; }
  }

  /* Nav link underline */
  .nav-link {
    position: relative;
    transition: color 0.15s ease;
  }
  .nav-link::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--lavender);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 0.2s ease;
  }
  .nav-link:hover::after { transform: scaleX(1); }
  .nav-link.active::after { transform: scaleX(1); }

  /* Buttons */
  .btn-primary {
    background: var(--lavender);
    color: var(--navy);
    transition: all 0.15s ease;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 600;
  }
  .btn-primary:hover {
    background: white;
    transform: translateY(-2px);
    box-shadow: 0 10px 30px rgba(184,169,212,0.4);
  }
  .btn-outline {
    background: transparent;
    color: white;
    border: 2px solid var(--lavender);
    transition: all 0.15s ease;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 600;
  }
  .btn-outline:hover {
    background: var(--lavender);
    color: var(--navy);
  }
  .btn-navy {
    background: var(--navy);
    color: white;
    transition: all 0.15s ease;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 600;
  }
  .btn-navy:hover {
    background: var(--navy-deep);
    transform: translateY(-1px);
  }

  /* Animated entrance */
  @keyframes riseIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
  }
  .rise-in { animation: riseIn 0.8s cubic-bezier(0.2,0.8,0.2,1) backwards; }
  .delay-1 { animation-delay: 0.1s; }
  .delay-2 { animation-delay: 0.25s; }
  .delay-3 { animation-delay: 0.4s; }
  .delay-4 { animation-delay: 0.55s; }

  /* Lightning flicker (legacy) */
  @keyframes flicker {
    0%, 100% { opacity: 0.95; }
    50% { opacity: 0.7; }
    52% { opacity: 1; }
  }
  .lightning-flicker { animation: flicker 4s ease-in-out infinite; }

  /* Respect reduced-motion preferences */
  @media (prefers-reduced-motion: reduce) {
    .lightning-layer, .cloud-drift, .lightning-flicker {
      animation: none !important;
    }
    .lightning-layer { display: none; }
  }

  /* Event card */
  .event-card {
    background: white;
    border: 1px solid var(--silver);
    transition: all 0.2s ease;
    position: relative;
    overflow: hidden;
  }
  .event-card::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--lavender);
    transform: scaleY(0);
    transition: transform 0.2s ease;
    transform-origin: top;
  }
  .event-card:hover {
    border-color: var(--lavender);
    transform: translateX(4px);
    box-shadow: 0 10px 30px rgba(26,31,58,0.08);
  }
  .event-card:hover::before { transform: scaleY(1); }

  /* Day chip */
  .day-chip {
    background: var(--navy);
    color: white;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    font-size: 0.7rem;
    padding: 0.25rem 0.6rem;
    border-radius: 0.25rem;
    font-weight: 600;
  }

  /* Feature tile */
  .feature-tile {
    background: white;
    border: 1px solid var(--silver);
    transition: all 0.2s ease;
    position: relative;
  }
  .feature-tile:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px rgba(26,31,58,0.1);
    border-color: var(--lavender);
  }

  /* Marquee-style section divider */
  .marquee-divider {
    background: var(--navy);
    padding: 1.5rem 0;
    overflow: hidden;
    position: relative;
  }
  .marquee-content {
    display: flex;
    /* CRITICAL: size to content, not parent. translateX(-50%) is 50% of
       this element's own width, so it must equal exactly one span-box
       worth (which is half of two identical, padded spans) for the loop
       to be seamless. Without this, the element is page-width and -50%
       lands mid-content — the cause of the visible "WARH" snap. */
    width: max-content;
    white-space: nowrap;
    animation: marquee 55s linear infinite;
    font-family: 'Bowlby One SC', sans-serif;
    font-size: 1.75rem;
    color: var(--lavender);
    letter-spacing: 0.1em;
  }
  @keyframes marquee {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
  }
  /* Spacing between the two duplicated copies lives on each span as
     padding-right (not as parent gap). With a parent gap, -50% lands
     mid-gap and the loop snaps visibly. With per-span padding, each
     copy is the same width including its trailer, so -50% is exactly
     one cycle and the seam is invisible. */
  .marquee-content span {
    display: inline-flex;
    align-items: center;
    padding-right: 3rem;
  }
  @media (max-width: 640px) {
    .marquee-divider { padding: 1rem 0; }
    .marquee-content {
      animation-duration: 45s;
      font-size: 1.25rem;
    }
    .marquee-content span { padding-right: 2rem; }
  }

  /* Hours grid */
  .hours-row {
    display: flex;
    justify-content: space-between;
    padding: 0.75rem 0;
    border-bottom: 1px solid rgba(184,169,212,0.3);
  }
  .hours-row:last-child { border-bottom: none; }
  .hours-row.today {
    background: linear-gradient(90deg, rgba(184,169,212,0.2), transparent);
    padding-left: 0.75rem;
    margin-left: -0.75rem;
    border-radius: 0.25rem;
  }

  /* Hover underline for links */
  .link-arrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 0.875rem;
    transition: gap 0.2s ease;
  }
  .link-arrow:hover { gap: 0.85rem; }

  /* Sell card CTA */
  .sell-cta {
    background:
      radial-gradient(ellipse at top right, rgba(184,169,212,0.3), transparent 60%),
      linear-gradient(135deg, var(--navy) 0%, var(--navy-deep) 100%);
    position: relative;
    overflow: hidden;
  }
  .sell-cta::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 35%;
    height: 100%;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 60 145' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M33 0 L8 84 L30 84 L28 140 L53 56 L30 56 Z' fill='%23b8a9d4' opacity='0.15'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    pointer-events: none;
  }

  /* Cloud section background */
  .cloud-section {
    background:
      radial-gradient(ellipse at 20% 0%, rgba(217,207,232,0.4) 0%, transparent 40%),
      radial-gradient(ellipse at 80% 100%, rgba(217,207,232,0.3) 0%, transparent 40%),
      var(--cream);
  }

  /* Scroll offset for sticky nav — logo h-14 (3.5rem) + padding 1rem = 4.5rem, 5rem gives breathing room */
  #events, #store, #sell, #about, #contact { scroll-margin-top: 5rem; }

  /* HEADER / NAV */
  .site-header {
    background: white;
    border-bottom: 1px solid var(--silver);
    position: sticky;
    top: 0;
    z-index: 40;
  }
  .site-header-inner {
    max-width: 80rem;
    margin: 0 auto;
    padding: 0.5rem 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
  }
  .site-nav {
    display: none;
    align-items: center;
    gap: 2rem;
    font-family: 'Oswald', sans-serif;
    font-size: 0.875rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--navy);
  }
  .site-header-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
  }
  .header-phone {
    display: none;
    align-items: center;
    gap: 0.5rem;
    color: var(--navy);
    font-family: 'Oswald', sans-serif;
    font-weight: 600;
    font-size: 0.875rem;
  }
  .hamburger-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--navy);
    background: transparent;
    border: none;
    padding: 0.5rem;
    cursor: pointer;
  }

  /* Mobile menu */
  .mobile-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: white;
    border-bottom: 1px solid var(--silver);
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    transform: translateY(-10px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: transform 0.25s ease, opacity 0.2s ease, visibility 0s linear 0.25s;
  }
  .mobile-menu.open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: transform 0.25s ease, opacity 0.2s ease, visibility 0s linear 0s;
  }
  .mobile-menu nav {
    display: flex;
    flex-direction: column;
    padding: 1.5rem;
    gap: 1rem;
    font-family: 'Oswald', sans-serif;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--navy);
  }
  .mobile-menu nav a {
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(212, 216, 222, 0.5);
  }
  .mobile-menu nav a:last-child { border-bottom: none; }
  .mobile-menu-call {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
    margin-top: 0.35rem;
    padding: 0.6rem 0.85rem !important;
    background: var(--lavender-soft);
    border: 1px solid var(--lavender);
    border-radius: 0.5rem;
  }
  .mobile-menu-call + .mobile-menu-call { margin-top: 0.25rem; }
  .mobile-menu-call-label {
    font-size: 0.65rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--lavender-dark);
    font-weight: 600;
  }
  .mobile-menu-call-num {
    font-size: 1rem;
    font-weight: 700;
    color: var(--navy);
    letter-spacing: 0.02em;
  }

  /* Header primary CTA (Sell Cards / Start Your Estimate / Our Hotlist) is
     redundant on mobile because the same link lives in the hamburger
     menu — and at narrow widths the button crowds out the logo. Hide it
     until the hamburger goes away at the desktop breakpoint. */
  .site-header-actions > .btn-primary { display: none; }

  @media (min-width: 1024px) {
    .site-nav { display: flex; }
    .hamburger-btn { display: none; }
    .mobile-menu { display: none; }
    .site-header-actions > .btn-primary { display: inline-flex; }
  }
  @media (min-width: 768px) {
    .header-phone { display: inline-flex; }
  }

  /* Code of Conduct prose display */
  .pscoc-prose p  { margin-bottom: 0.75rem; line-height: 1.75; color: var(--navy); }
  .pscoc-prose ul { list-style: disc;    padding-left: 1.5rem; margin: 0.25rem 0 0.85rem; }
  .pscoc-prose ol { list-style: decimal; padding-left: 1.5rem; margin: 0.25rem 0 0.85rem; }
  .pscoc-prose li { margin-bottom: 0.35rem; line-height: 1.65; color: var(--navy); }
  .pscoc-prose h3 { font-family: 'Oswald', sans-serif; font-weight: 700; font-size: 1.05rem;
                    letter-spacing: 0.06em; color: var(--navy); margin-bottom: 0.4rem; }
  .pscoc-prose strong { font-weight: 700; }
  .pscoc-prose em { font-style: italic; }

  /* Code of Conduct rich-text toolbar */
  .pscoc-toolbar {
    display: flex; flex-wrap: wrap; gap: 0.3rem;
    padding: 0.5rem 0.6rem;
    background: var(--cloud);
    border: 1.5px solid var(--silver);
    border-bottom: none;
    border-radius: 0.5rem 0.5rem 0 0;
  }
  .pscoc-toolbar button, .pscoc-toolbar select {
    padding: 0.28rem 0.65rem;
    border: 1px solid var(--silver);
    border-radius: 0.25rem;
    background: white;
    color: var(--navy);
    font-family: Inter, sans-serif;
    font-size: 0.8rem;
    cursor: pointer;
    line-height: 1.4;
    transition: background 0.15s;
  }
  .pscoc-toolbar button:hover { background: var(--lavender-soft); }
  .pscoc-toolbar .tb-sep { width: 1px; background: var(--silver); align-self: stretch; margin: 0 0.1rem; }

  /* Code of Conduct contenteditable editor */
  .pscoc-editor {
    min-height: 220px; max-height: 52vh; overflow-y: auto;
    padding: 0.85rem 1rem;
    border: 1.5px solid var(--silver);
    border-radius: 0 0 0.5rem 0.5rem;
    outline: none;
    font-family: Inter, sans-serif;
    font-size: 0.9rem;
    color: var(--navy);
    line-height: 1.7;
  }
  .pscoc-editor:focus { border-color: var(--navy); }
  .pscoc-editor p  { margin-bottom: 0.5rem; }
  .pscoc-editor ul { list-style: disc;    padding-left: 1.5rem; margin: 0.25rem 0 0.6rem; }
  .pscoc-editor ol { list-style: decimal; padding-left: 1.5rem; margin: 0.25rem 0 0.6rem; }
  .pscoc-editor li { margin-bottom: 0.25rem; }

  /* Phone location picker dropdown */
  .phone-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: white;
    border: 1px solid var(--silver);
    border-radius: 0.75rem;
    box-shadow: 0 10px 30px rgba(26,31,58,0.15);
    min-width: 220px;
    z-index: 50;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s linear 0.18s;
  }
  .phone-dropdown.open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s linear 0s;
  }
  .phone-dropdown a {
    display: block;
    padding: 0.75rem 1rem;
    color: var(--navy);
    transition: background 0.15s;
    text-decoration: none;
  }
  .phone-dropdown a:hover { background: var(--lavender-soft); }
  .phone-dropdown a + a { border-top: 1px solid var(--silver); }
  .phone-dropdown-label {
    font-family: 'Oswald', sans-serif;
    font-size: 0.65rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--lavender-dark);
    margin-bottom: 0.1rem;
  }
  .phone-dropdown-num {
    font-family: 'Oswald', sans-serif;
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--navy);
  }

  /* Testimonial */
  .quote-mark {
    font-family: 'Bowlby One SC', serif;
    font-size: 5rem;
    line-height: 0.5;
    color: var(--lavender);
    opacity: 0.3;
  }

  /* ADMIN SYSTEM */
  .ps-btn-admin {
    background: var(--navy);
    color: var(--lavender);
    border: 1px solid var(--lavender);
    font-family: 'Oswald', sans-serif;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-size: 0.7rem;
    font-weight: 600;
    border-radius: 0.35rem;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    line-height: 1;
  }
  /* Hover keeps the dark family (navy → navy-light) and brightens the text
     to cream. The previous lavender-bg/navy-text inversion had OK contrast
     numerically but read as washed-out on small uppercase Oswald and on
     mid-range monitors. Cream-on-navy-light reads at WCAG AAA. */
  .ps-btn-admin:hover { background: var(--navy-light); color: var(--cream); }
  .ps-btn-admin:focus-visible {
    outline: 2px solid var(--lavender);
    outline-offset: 2px;
  }
  .ps-admin-only { display: none !important; }
  body.ps-admin-active .ps-admin-only { display: inline-block !important; }
  body.ps-admin-active .ps-admin-flex { display: flex !important; }
  body.ps-admin-active .site-header,
  body.admin-bar-offset .site-header { top: 38px; }

  /* Hide the static footer LOGIN trigger (#ps-admin-trigger on scx.html /
     hotlist.html / index.html) once the admin chrome bar is up — the
     chrome already exposes Sign Out, so the footer link reads as a
     misleading duplicate. ps-admin-active covers the legacy main-site
     admin chrome (admin.js); admin-bar-offset covers the SCX / Hotlist
     React-rendered chrome. */
  body.ps-admin-active #ps-admin-trigger,
  body.admin-bar-offset #ps-admin-trigger { display: none !important; }

  /* Special events cards on dark background */
  .event-card-dark {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(184,169,212,0.3);
    transition: all 0.2s ease;
    position: relative;
    overflow: hidden;
  }
  .event-card-dark::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 4px;
    background: var(--lavender);
    transform: scaleY(0);
    transition: transform 0.2s ease;
    transform-origin: top;
  }
  .event-card-dark:hover { border-color: var(--lavender); transform: translateX(4px); }
  .event-card-dark:hover::before { transform: scaleY(1); }

  /* Modal overlay */
  #ps-modal-overlay {
    display: none;
    position: fixed; inset: 0; z-index: 200;
    background: rgba(15,19,41,0.85);
    overflow-y: auto; padding: 1rem;
  }
  #ps-modal-box {
    background: var(--cream);
    border-radius: 1rem;
    max-width: min(640px, calc(100vw - 2rem));
    width: 100%;
    margin: 2rem auto;
    position: relative;
  }
  #ps-modal-header {
    padding: 1.5rem 1.5rem 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  #ps-modal-body { padding: 1.25rem 1.5rem; }
  #ps-modal-footer {
    padding: 0 1.5rem 1.5rem;
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
  }
  #ps-modal-close {
    background: none; border: none; cursor: pointer;
    color: var(--navy); opacity: 0.4; font-size: 1.5rem;
    line-height: 1; padding: 0; transition: opacity 0.15s;
  }
  #ps-modal-close:hover { opacity: 1; }

  /* Art carousel banner on event cards */
  .art-carousel {
    position: relative; width: 100%; height: 210px; overflow: hidden;
    border-radius: 0.75rem 0.75rem 0 0;
  }
  .art-carousel img:not(.mtg-badge) {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: cover; object-position: top; opacity: 0;
    transition: opacity 1.5s ease-in-out;
  }
  .art-carousel img.active { opacity: 1; }
  .art-carousel::after {
    content: '';
    position: absolute; bottom: 0; left: 0; right: 0;
    height: 56px;
    background: linear-gradient(to bottom, transparent, rgba(15,19,41,0.92));
    pointer-events: none; z-index: 1;
  }
  .mtg-badge {
    position: absolute; top: 0.6rem; left: 0.6rem;
    height: 72px; width: auto;
    z-index: 2;
    pointer-events: none;
    filter: drop-shadow(0 1px 4px rgba(0,0,0,0.6));
  }

  /* Game logo banner for non-MTG events with a known image */
  .game-logo-banner {
    width: 100%; height: 210px;
    display: flex; align-items: center; justify-content: center;
    background: #ffffff;
    border-radius: 0.75rem 0.75rem 0 0;
    padding: 1.75rem 2.5rem;
    box-sizing: border-box;
  }
  .game-logo-banner img {
    max-width: 100%; max-height: 100%;
    object-fit: contain;
  }
  .game-logo-banner--large {
    padding: 0;
  }
  .game-logo-banner--xlarge {
    padding: 0;
    overflow: hidden;
  }
  .game-logo-banner--xlarge img {
    transform: scale(var(--logo-scale, 2));
  }

  /* Gallery card carousel */
  .ps-gallery-card {
    position: relative;
    width: 100%;
    height: 480px;
    border-radius: 1rem;
    overflow: hidden;
    background: var(--navy-deep);
    box-shadow: 0 10px 40px -20px rgba(15,19,41,0.45);
  }
  .ps-gallery-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 1.2s ease-in-out;
  }
  .ps-gallery-slide.active { opacity: 1; }
  .ps-gallery-backdrop {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    /* slight overscale hides the blur's soft edge from bleeding in */
    transform: scale(1.15);
    filter: blur(36px) saturate(1.05) brightness(0.92);
    z-index: 0;
  }
  .ps-gallery-foreground {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-position: center;
    z-index: 1;
  }
  .ps-gallery-slide.fit-fit .ps-gallery-foreground  { object-fit: contain; }
  .ps-gallery-slide.fit-fill .ps-gallery-foreground { object-fit: cover; }
  .ps-gallery-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: 2rem;
    text-align: center;
    color: var(--lavender-soft);
    font-family: 'Oswald', sans-serif;
    font-size: 0.9rem;
    letter-spacing: 0.08em;
    opacity: 0.8;
  }

  /* Styled placeholder for non-MTG games */
  .game-placeholder {
    width: 100%; height: 210px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--navy-deep), var(--navy-light));
    border-radius: 0.75rem 0.75rem 0 0;
    font-family: 'Oswald', sans-serif; font-size: 1rem;
    letter-spacing: 0.15em; text-transform: uppercase;
    color: var(--lavender); opacity: 0.85;
  }

  /* Set search autocomplete */
  .psc-set-wrap { position: relative; }
  .psc-set-autocomplete {
    position: absolute; top: 100%; left: 0; right: 0;
    background: white; border: 1.5px solid var(--silver);
    border-top: none; border-radius: 0 0 0.5rem 0.5rem;
    max-height: 180px; overflow-y: auto; z-index: 100;
    display: none;
  }
  .psc-set-autocomplete div {
    padding: 0.5rem 0.75rem; cursor: pointer; font-size: 0.85rem;
    color: var(--navy); transition: background 0.1s;
  }
  .psc-set-autocomplete div:hover { background: var(--lavender-soft); }
  .psc-set-code-tag {
    font-family: 'Oswald', sans-serif; font-size: 0.65rem;
    letter-spacing: 0.12em; color: var(--lavender-dark); margin-left: 0.5rem;
  }

  /* Admin bar */
  #ps-admin-bar {
    display: none;
    position: fixed; top: 0; left: 0; right: 0; z-index: 150;
    background: var(--navy-deep);
    border-bottom: 1px solid rgba(184,169,212,0.3);
    padding: 0.45rem 1.25rem;
    align-items: center;
    gap: 1.25rem;
    height: 38px;
    box-sizing: border-box;
  }
  .ps-admin-bar-btn {
    background: none; border: none; cursor: pointer;
    color: #c7bed9; font-family: 'Oswald', sans-serif;
    font-size: 0.65rem; letter-spacing: 0.12em;
    text-transform: uppercase; font-weight: 600;
    padding: 0; transition: color 0.15s;
    /* Inline-flex centers text + badge children on the cross axis so a
       button with a chip ("Testimonials 0", "Users 1") sits on the same
       baseline as a chipless one ("Code of Conduct"). Without this the
       badge's taller line-box pushes the button text up a hair. */
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
  }
  .ps-admin-bar-btn:hover { color: var(--lavender); }
  /* Added by PSAdmin._applyPerms() to elements whose data-perm the current
     user doesn't have. Wins over `.ps-admin-only`'s !important show rule. */
  .ps-perm-denied { display: none !important; }
  .ps-admin-bar-apps {
    display: flex; align-items: center; gap: 1rem;
  }
  .ps-admin-bar-app-link {
    color: #9a90ad; font-family: 'Oswald', sans-serif;
    font-size: 0.65rem; letter-spacing: 0.12em;
    text-transform: uppercase; font-weight: 600;
    text-decoration: none;
    padding: 0.15rem 0;
    border-bottom: 2px solid transparent;
    transition: color 0.15s, border-color 0.15s;
  }
  .ps-admin-bar-app-link:hover { color: var(--lavender); }
  .ps-admin-bar-app-link.active {
    color: #f5c518;
    border-bottom-color: #f5c518;
  }
  .ps-admin-bar-divider {
    width: 1px; height: 20px;
    background: rgba(184, 169, 212, 0.2);
    flex-shrink: 0;
  }
  .ps-pending-badge {
    display: inline-block;
    padding: 0.05rem 0.45rem;
    border-radius: 0.75rem;
    background: #f5c518;
    color: #2d2540;
    font-size: 0.6rem;
    letter-spacing: 0.08em;
    font-weight: 700;
    line-height: 1;
    /* Spacing comes from the parent button's flex `gap` now (see
       .ps-admin-bar-btn). vertical-align is moot under flex centering
       but kept harmless for any non-flex parent that ever reuses this
       chip — e.g. the bare <span> appears alongside text in modals. */
    vertical-align: middle;
  }

  /* Shrink the Hours editor's row grid so Open/Close/Closed fit at 375px.
     The rows are rendered with inline grid-template-columns, so we need to
     override with a specific selector + !important. */
  @media (max-width: 640px) {
    [data-ps-hours-row] {
      grid-template-columns: 4.5rem minmax(0, 1fr) minmax(0, 1fr) auto !important;
      gap: 0.35rem !important;
      padding-left: 0 !important;
      padding-right: 0 !important;
    }
    [data-ps-hours-row] > div:nth-child(3) { display: none !important; }
  }

  /* Admin is a desktop-only experience. Hide every entry point and undo the
     admin-bar body offset below 768px so a session that's still live (e.g.
     a localStorage carryover from a desktop visit) doesn't leak broken
     chrome or a 38px gap onto the public site. */
  @media (max-width: 767px) {
    #ps-admin-bar,
    #ps-admin-trigger,
    .ps-admin-only { display: none !important; }
    body.ps-admin-active,
    body.admin-bar-offset { padding-top: 0 !important; }
    body.ps-admin-active .site-header,
    body.admin-bar-offset .site-header { top: 0 !important; }
  }

/* ── Finish chips (foil/etched) ─────────────────────────────────────────────
   Painted on both the customer hotlist (next to set/promo chips) and the
   admin HotListAdmin row (line 2 of the card-name cell). Same pill geometry
   as .hotlist-promo so the two stack cleanly. */
.hotlist-finish {
  padding: .1rem .45rem;
  border-radius: 999px;
  font-size: .6rem;
  letter-spacing: .12em;
  font-weight: 700;
  text-transform: uppercase;
  display: inline-block;
  line-height: 1.4;
}
.hotlist-finish-foil { background: linear-gradient(90deg, #f0abfc, #7dd3fc); color: var(--navy); }
.hotlist-finish-etched { background: #fde68a; color: #78350f; }

/* ── Promo-type chips (Scryfall promo_types) ────────────────────────────────
   Used in the customer hotlist (hotlist.js renderCard / renderVersionRow) and
   in the admin HotListAdmin row (estimate-tool.js). Lives here so both pages
   can share the same gradients without duplicating CSS — hotlist.css is only
   loaded on /hotlist.html, but main.css ships everywhere.

   Each chip's gradient evokes the actual physical foil treatment so
   collectors can pick the variant out at a glance. Add a new tag by
   extending PROMO_CHIP_LABELS in hotlist.js + estimate-tool.js and adding
   a .hotlist-promo-<tag> rule below. */
.hotlist-promo {
  padding: .1rem .45rem;
  border-radius: 999px;
  font-size: .6rem;
  letter-spacing: .1em;
  font-weight: 700;
  text-transform: uppercase;
  white-space: nowrap;
  color: var(--navy);
  display: inline-block;
  line-height: 1.4;
}
.hotlist-promo-surgefoil       { background: linear-gradient(135deg, #fda4af 0%, #fde68a 50%, #93c5fd 100%); }
.hotlist-promo-gilded          { background: linear-gradient(135deg, #fde68a, #d97706); color: #fff; }
.hotlist-promo-textured        { background: linear-gradient(135deg, #cbd5e1, #475569); color: #fff; }
.hotlist-promo-serialized      { background: #1e293b; color: #fde68a; }
.hotlist-promo-oilslick        { background: linear-gradient(120deg, #6366f1, #ec4899, #14b8a6, #6366f1); color: #fff; }
.hotlist-promo-halofoil        { background: linear-gradient(135deg, #c4b5fd, #fef3c7, #c4b5fd); }
.hotlist-promo-confetti        { background: linear-gradient(135deg, #fbbf24, #f472b6, #34d399, #60a5fa); color: #fff; }
.hotlist-promo-stepandcompleat { background: linear-gradient(135deg, #064e3b, #84cc16); color: #fff; }
.hotlist-promo-neonink         { background: linear-gradient(135deg, #ec4899, #f472b6); color: #fff; }
.hotlist-promo-raised          { background: linear-gradient(135deg, #f5d0a9, #b45309); color: #fff; }
.hotlist-promo-galaxyfoil      { background: linear-gradient(135deg, #1e1b4b, #7c3aed, #ec4899); color: #fff; }
.hotlist-promo-silverfoil      { background: linear-gradient(135deg, #e5e7eb, #94a3b8); color: var(--navy); }
.hotlist-promo-rainbowfoil     { background: linear-gradient(90deg, #ef4444, #f59e0b, #84cc16, #06b6d4, #6366f1, #d946ef); color: #fff; }
.hotlist-promo-invisibleink    { background: #f3f4f6; color: #374151; border: 1px dashed #9ca3af; }
.hotlist-promo-doublerainbow   { background: linear-gradient(180deg, #ef4444, #f59e0b, #84cc16, #06b6d4, #6366f1, #d946ef); color: #fff; }
.hotlist-promo-dragonscalefoil { background: linear-gradient(135deg, #064e3b, #10b981, #064e3b); color: #fff; }
.hotlist-promo-fracturefoil    { background: linear-gradient(135deg, #f1f5f9 0%, #cbd5e1 35%, #f1f5f9 50%, #94a3b8 65%, #f1f5f9 100%); color: var(--navy); }
.hotlist-promo-manafoil        { background: linear-gradient(135deg, #1e3a8a, #7c3aed); color: #fff; }
.hotlist-promo-ripplefoil      { background: linear-gradient(135deg, #0ea5e9, #67e8f9, #0ea5e9); color: #fff; }
.hotlist-promo-showcase        { background: linear-gradient(135deg, #fde68a, #fbbf24, #d97706); color: var(--navy); }
.hotlist-promo-borderless      { background: #0f172a; color: #f1f5f9; }
.hotlist-promo-extendedart     { background: linear-gradient(135deg, #1e3a8a, #3b82f6); color: #fff; }
.hotlist-promo-fullart         { background: linear-gradient(135deg, #166534, #84cc16, #fef3c7); color: var(--navy); }
.hotlist-promo-shatteredglass  { background: linear-gradient(125deg, #f8fafc 0%, #cbd5e1 25%, #f8fafc 35%, #94a3b8 55%, #e2e8f0 70%, #64748b 90%); color: var(--navy); }
