/* ═══════════════════════════════════════════════════════════════
   Joinery Default UI Kit  ·  custom.css  ·  v2.2.0
   Pure Slate design. Themeable values live in --jy-* tokens on
   :root so branded themes can override them without understanding
   internals. Component rules are scoped under .jy-ui to prevent
   collisions with any active branded theme's stylesheets.
   ═══════════════════════════════════════════════════════════════ */

/* ─── Design Tokens ─────────────────────────────────────────── */
:root {
  /* Neutrals */
  --jy-color-bg:            #ffffff;
  --jy-color-surface:       #f7f8fa;
  --jy-color-surface-alt:   #eff1f5;
  --jy-color-border:        #e1e4ea;
  --jy-color-border-strong: #c8ccd4;
  --jy-color-text:          #1a1d23;
  --jy-color-text-muted:    #5a6170;
  --jy-color-text-subtle:   #8990a0;

  /* Accent */
  --jy-color-primary:       #5b7a99;
  --jy-color-primary-hover: #4a6886;
  --jy-color-primary-text:  #ffffff;
  --jy-color-link:          #4a6886;

  /* Semantic */
  --jy-color-success:       #2f7d4f;
  --jy-color-success-bg:    #e6f4ec;
  --jy-color-warning:       #b87914;
  --jy-color-warning-bg:    #fbf1de;
  --jy-color-danger:        #b3261e;
  --jy-color-danger-bg:     #fbeae9;
  --jy-color-info:          #2d6a9e;
  --jy-color-info-bg:       #e6f0f9;

  /* Typography */
  --jy-font-sans:    'Inter', system-ui, -apple-system, sans-serif;
  --jy-font-display: 'Inter', system-ui, -apple-system, sans-serif;
  --jy-font-mono:    ui-monospace, 'SF Mono', Menlo, monospace;
  --jy-text-xs:    12px;
  --jy-text-sm:    14px;
  --jy-text-base:  16px;
  --jy-text-lg:    18px;
  --jy-text-xl:    22px;
  --jy-text-2xl:   28px;
  --jy-text-3xl:   36px;
  --jy-text-4xl:   48px;
  --jy-leading-tight:  1.25;
  --jy-leading-base:   1.6;
  --jy-tracking-tight: -0.01em;

  /* Space scale */
  --jy-space-1:  4px;
  --jy-space-2:  8px;
  --jy-space-3:  12px;
  --jy-space-4:  16px;
  --jy-space-5:  24px;
  --jy-space-6:  32px;
  --jy-space-8:  48px;
  --jy-space-10: 64px;

  /* Radius */
  --jy-radius-sm:   4px;
  --jy-radius-md:   6px;
  --jy-radius-lg:   10px;
  --jy-radius-full: 999px;

  /* Shadow */
  --jy-shadow-sm: 0 1px 2px rgba(20,25,35,0.04);
  --jy-shadow-md: 0 2px 8px rgba(20,25,35,0.06);
  --jy-shadow-lg: 0 6px 24px rgba(20,25,35,0.08);

  /* Control heights */
  --jy-control-h-sm: 32px;
  --jy-control-h-md: 40px;
  --jy-control-h-lg: 48px;
}

/* ─── Baseline (default theme only) ─────────────────────────
   Scoped to body.jy-default so these rules only fire when the
   default theme is active. Branded themes are unaffected even
   though base.css/custom.css load on every page.
   ─────────────────────────────────────────────────────────── */

body.jy-default {
  font-family: var(--jy-font-sans);
  font-size: var(--jy-text-base);
  line-height: var(--jy-leading-base);
  color: var(--jy-color-text);
  background: var(--jy-color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.jy-default h1, body.jy-default h2, body.jy-default h3,
body.jy-default h4, body.jy-default h5, body.jy-default h6 {
  font-family: var(--jy-font-display);
  font-weight: 600;
  line-height: var(--jy-leading-tight);
  letter-spacing: var(--jy-tracking-tight);
  color: var(--jy-color-text);
  margin-bottom: var(--jy-space-3);
}
body.jy-default h1 { font-size: var(--jy-text-4xl); font-weight: 700; }
body.jy-default h2 { font-size: var(--jy-text-3xl); }
body.jy-default h3 { font-size: var(--jy-text-2xl); }
body.jy-default h4 { font-size: var(--jy-text-xl); }
body.jy-default h5 { font-size: var(--jy-text-lg); }
body.jy-default h6 { font-size: var(--jy-text-base); }

body.jy-default p { margin-bottom: var(--jy-space-4); }
body.jy-default p:last-child { margin-bottom: 0; }
body.jy-default a { color: var(--jy-color-link); text-decoration: none; }
body.jy-default a:hover { text-decoration: underline; }
body.jy-default small { font-size: var(--jy-text-sm); }

body.jy-default code {
  font-family: var(--jy-font-mono);
  font-size: 0.9em;
  background: var(--jy-color-surface-alt);
  padding: 0.1em 0.35em;
  border-radius: var(--jy-radius-sm);
}

body.jy-default blockquote {
  border-left: 3px solid var(--jy-color-border-strong);
  padding: var(--jy-space-2) var(--jy-space-5);
  color: var(--jy-color-text-muted);
  font-style: italic;
  margin: var(--jy-space-5) 0;
}

/* ─── Default Theme Nav ──────────────────────────────────────
   Styles for HTML generated by includes/PublicPage.php.
   Unscoped because the nav sits outside .jy-ui.
   When a branded theme is active it provides its own nav;
   these rules are unused in that context.
   ─────────────────────────────────────────────────────────── */

.jy-site-header {
  background: var(--jy-color-bg);
  border-bottom: 1px solid var(--jy-color-border);
  position: sticky;
  top: 0;
  z-index: 100;
}

.jy-header-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--jy-space-5);
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--jy-space-5);
}

.jy-logo {
  display: flex;
  align-items: center;
  gap: var(--jy-space-2);
  text-decoration: none;
  color: var(--jy-color-text);
  font-family: var(--jy-font-display);
  font-size: var(--jy-text-xl);
  font-weight: 700;
  letter-spacing: var(--jy-tracking-tight);
  flex-shrink: 0;
}
.jy-logo:hover { text-decoration: none; color: var(--jy-color-text); }
.jy-logo-img { height: 32px; width: auto; display: block; }
.jy-logo-text { white-space: nowrap; }

.jy-header-right {
  display: flex;
  align-items: center;
  gap: var(--jy-space-4);
  flex: 1;
  justify-content: flex-end;
}

.jy-nav-links {
  display: flex;
  align-items: center;
  gap: var(--jy-space-1);
}
.jy-nav-links a {
  display: block;
  padding: var(--jy-space-2) var(--jy-space-3);
  color: var(--jy-color-text);
  font-size: var(--jy-text-sm);
  font-weight: 500;
  border-radius: var(--jy-radius-md);
  transition: background 0.15s, color 0.15s;
  text-decoration: none;
}
.jy-nav-links a:hover,
.jy-nav-links a.active {
  background: var(--jy-color-surface);
  color: var(--jy-color-primary);
  text-decoration: none;
}

.jy-nav-dropdown { position: relative; }
.jy-nav-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 180px;
  background: var(--jy-color-bg);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-md);
  box-shadow: var(--jy-shadow-md);
  padding: var(--jy-space-2) 0;
  z-index: 200;
}
.jy-nav-dropdown:hover .jy-nav-dropdown-menu { display: block; }
.jy-nav-dropdown-menu a {
  display: block;
  padding: var(--jy-space-2) var(--jy-space-4);
  font-size: var(--jy-text-sm);
  color: var(--jy-color-text);
  white-space: nowrap;
}
.jy-nav-dropdown-menu a:hover {
  background: var(--jy-color-surface);
  color: var(--jy-color-primary);
  text-decoration: none;
}

.jy-header-icons {
  display: flex;
  align-items: center;
  gap: var(--jy-space-2);
}

.jy-header-cart-link {
  display: inline-flex;
  align-items: center;
  gap: var(--jy-space-1);
  color: var(--jy-color-text);
  padding: var(--jy-space-2);
  border-radius: var(--jy-radius-md);
  transition: background 0.15s;
  text-decoration: none;
  position: relative;
}
.jy-header-cart-link:hover { background: var(--jy-color-surface); text-decoration: none; }
.jy-cart-count {
  position: absolute;
  top: 0;
  right: 0;
  background: var(--jy-color-primary);
  color: var(--jy-color-primary-text);
  font-size: 10px;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: var(--jy-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
}

.jy-header-icon-link {
  display: inline-flex;
  align-items: center;
  color: var(--jy-color-text);
  padding: var(--jy-space-2);
  border-radius: var(--jy-radius-md);
  transition: background 0.15s;
  text-decoration: none;
  position: relative;
}
.jy-header-icon-link:hover { background: var(--jy-color-surface); text-decoration: none; }
.jy-icon-badge {
  position: absolute;
  top: 0;
  right: 0;
  background: var(--jy-color-danger);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: var(--jy-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
}

/* User dropdown uses <details>/<summary> */
.jy-user-dropdown { position: relative; }
.jy-user-dropdown-toggle {
  display: flex;
  align-items: center;
  gap: var(--jy-space-2);
  padding: var(--jy-space-2) var(--jy-space-3);
  border-radius: var(--jy-radius-md);
  cursor: pointer;
  list-style: none;
  font-size: var(--jy-text-sm);
  font-weight: 500;
  color: var(--jy-color-text);
  transition: background 0.15s;
}
.jy-user-dropdown-toggle::-webkit-details-marker { display: none; }
.jy-user-dropdown-toggle:hover { background: var(--jy-color-surface); }
.jy-user-name { white-space: nowrap; }

.jy-user-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  min-width: 180px;
  background: var(--jy-color-bg);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-md);
  box-shadow: var(--jy-shadow-md);
  padding: var(--jy-space-2) 0;
  z-index: 200;
}
.jy-user-dropdown[open] .jy-user-dropdown-menu { display: block; }
.jy-user-dropdown-menu a {
  display: block;
  padding: var(--jy-space-2) var(--jy-space-4);
  font-size: var(--jy-text-sm);
  color: var(--jy-color-text);
  white-space: nowrap;
}
.jy-user-dropdown-menu a:hover {
  background: var(--jy-color-surface);
  color: var(--jy-color-primary);
  text-decoration: none;
}

.jy-menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  padding: 6px;
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-md);
  background: none;
  cursor: pointer;
  flex-shrink: 0;
}
.jy-menu-toggle span {
  display: block;
  height: 2px;
  background: var(--jy-color-text);
  border-radius: 2px;
}

@media (max-width: 768px) {
  .jy-menu-toggle { display: flex; }
  .jy-header-right { gap: var(--jy-space-2); }
  .jy-nav-links {
    display: none;
    position: absolute;
    top: 60px;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: flex-start;
    background: var(--jy-color-bg);
    border-bottom: 1px solid var(--jy-color-border);
    padding: var(--jy-space-3) var(--jy-space-5);
    gap: var(--jy-space-1);
    box-shadow: var(--jy-shadow-md);
    z-index: 99;
  }
  .jy-nav-links.open { display: flex; }
  .jy-site-header { position: relative; }
}

.jy-main-content {
  min-height: calc(100vh - 60px - 80px);
}

.jy-site-footer {
  background: var(--jy-color-surface);
  border-top: 1px solid var(--jy-color-border);
  margin-top: var(--jy-space-8);
}
.jy-site-footer .jy-container { max-width: 1200px; margin: 0 auto; padding: 0 var(--jy-space-5); }
.jy-footer-bottom {
  padding: var(--jy-space-5) 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.jy-copyright { font-size: var(--jy-text-sm); color: var(--jy-color-text-muted); margin: 0; }

/* Page structure helpers */
.jy-container { max-width: 1200px; margin: 0 auto; padding: 0 var(--jy-space-5); }
.page-content { max-width: 1200px; margin: 0 auto; padding: var(--jy-space-8) var(--jy-space-5); }
.jy-page-header { margin-bottom: var(--jy-space-6); }
.jy-page-header h1 { margin-bottom: var(--jy-space-2); }
.page-subtitle { color: var(--jy-color-text-muted); font-size: var(--jy-text-lg); margin-top: var(--jy-space-2); }
.jy-page-header-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--jy-space-4);
  flex-wrap: wrap;
  margin-bottom: var(--jy-space-5);
}
.jy-page-header-bar h2 { margin-bottom: 0; }
.jy-page-header-action { flex-shrink: 0; }
.jy-panel {
  background: var(--jy-color-bg);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-lg);
  padding: var(--jy-space-5);
  box-shadow: var(--jy-shadow-sm);
  margin-bottom: var(--jy-space-5);
}

/* Section layout helpers (used by base views like views/index.php) */
.jy-content-section { padding: 64px 0; }
.section-muted   { background: var(--jy-color-surface); }
.jy-section-dark    {
  background: var(--jy-color-text);
  color: rgba(255,255,255,0.9);
}
.jy-section-dark h1, .jy-section-dark h2, .jy-section-dark h3,
.jy-section-dark h4, .jy-section-dark h5 { color: #fff; }

/* Breadcrumbs from BeginPageNoCard */
.jy-breadcrumbs { font-size: var(--jy-text-sm); color: var(--jy-color-text-muted); }
.jy-breadcrumbs ol {
  display: flex;
  align-items: center;
  gap: var(--jy-space-2);
  list-style: none;
  flex-wrap: wrap;
  margin-bottom: var(--jy-space-3);
}
.jy-breadcrumbs li { display: flex; align-items: center; gap: var(--jy-space-2); }
.jy-breadcrumbs li::before { content: '›'; color: var(--jy-color-text-subtle); }
.jy-breadcrumbs li:first-child::before { display: none; }
.jy-breadcrumbs a { color: var(--jy-color-text-muted); }
.jy-breadcrumbs a:hover { color: var(--jy-color-primary); }
.jy-breadcrumbs li.active { color: var(--jy-color-text); font-weight: 500; }


/* ═══════════════════════════════════════════════════════════════
   JY-UI SCOPED COMPONENT KIT
   All rules below require .jy-ui as ancestor.
   Safe to load in any theme context — no class-name collisions.
   ═══════════════════════════════════════════════════════════════ */

/* ─── Typography inside scope ────────────────────────────────── */
.jy-ui {
  color: var(--jy-color-text);
  font-family: var(--jy-font-sans);
  font-size: var(--jy-text-base);
  line-height: var(--jy-leading-base);
}
.jy-ui h1, .jy-ui h2, .jy-ui h3,
.jy-ui h4, .jy-ui h5, .jy-ui h6 {
  font-family: var(--jy-font-display);
  font-weight: 600;
  line-height: var(--jy-leading-tight);
  letter-spacing: var(--jy-tracking-tight);
  color: var(--jy-color-text);
}
.jy-ui p { margin-bottom: var(--jy-space-4); }
.jy-ui p:last-child { margin-bottom: 0; }
.jy-ui a { color: var(--jy-color-link); }
.jy-ui small { font-size: var(--jy-text-sm); color: var(--jy-color-text-muted); }
.jy-ui code {
  font-family: var(--jy-font-mono);
  font-size: 0.9em;
  background: var(--jy-color-surface-alt);
  padding: 0.1em 0.35em;
  border-radius: var(--jy-radius-sm);
}

.jy-ui .text-muted  { color: var(--jy-color-text-muted) !important; }
.jy-ui .text-subtle { color: var(--jy-color-text-subtle) !important; }
.jy-ui .text-center { text-align: center; }
.jy-ui .text-sm     { font-size: var(--jy-text-sm); }
.jy-ui .muted       { color: var(--jy-color-text-muted); }

/* ─── Buttons ─────────────────────────────────────────────────── */
.jy-ui .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--jy-space-2);
  height: var(--jy-control-h-md);
  padding: 0 var(--jy-space-4);
  border-radius: var(--jy-radius-md);
  font-family: var(--jy-font-sans);
  font-size: var(--jy-text-sm);
  font-weight: 600;
  line-height: 1;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s;
  text-decoration: none;
  white-space: nowrap;
}
.jy-ui .btn:hover { text-decoration: none; }
.jy-ui .btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--jy-color-primary) 25%, transparent);
}
.jy-ui .btn svg { width: 16px; height: 16px; flex-shrink: 0; }

.jy-ui .btn-primary {
  background: var(--jy-color-primary);
  color: var(--jy-color-primary-text);
  border-color: var(--jy-color-primary);
}
.jy-ui .btn-primary:hover {
  background: var(--jy-color-primary-hover);
  border-color: var(--jy-color-primary-hover);
  color: var(--jy-color-primary-text);
}
.jy-ui .btn-primary:disabled,
.jy-ui .btn-primary.disabled {
  background: var(--jy-color-border-strong);
  border-color: var(--jy-color-border-strong);
  color: var(--jy-color-bg);
  cursor: not-allowed;
}

.jy-ui .btn-secondary {
  background: var(--jy-color-surface);
  color: var(--jy-color-text);
  border-color: var(--jy-color-border);
}
.jy-ui .btn-secondary:hover {
  background: var(--jy-color-surface-alt);
  border-color: var(--jy-color-border-strong);
}

.jy-ui .btn-outline {
  background: transparent;
  color: var(--jy-color-primary);
  border-color: var(--jy-color-primary);
}
.jy-ui .btn-outline:hover {
  background: var(--jy-color-primary);
  color: var(--jy-color-primary-text);
}

.jy-ui .btn-ghost {
  background: transparent;
  color: var(--jy-color-text);
  border-color: transparent;
}
.jy-ui .btn-ghost:hover { background: var(--jy-color-surface-alt); }

.jy-ui .btn-destructive,
.jy-ui .btn-danger {
  background: var(--jy-color-danger);
  color: #ffffff;
  border-color: var(--jy-color-danger);
}
.jy-ui .btn-destructive:hover,
.jy-ui .btn-danger:hover {
  background: color-mix(in srgb, var(--jy-color-danger) 85%, black);
}

.jy-ui .btn-sm {
  height: var(--jy-control-h-sm);
  padding: 0 var(--jy-space-3);
  font-size: var(--jy-text-xs);
}
.jy-ui .btn-lg {
  height: var(--jy-control-h-lg);
  padding: 0 var(--jy-space-5);
  font-size: var(--jy-text-base);
}
.jy-ui .btn-block { width: 100%; }

/* ─── Forms (FormWriterV2HTML5 class names) ───────────────────── */
.jy-ui .form-group { margin-bottom: var(--jy-space-4); }

.jy-ui .form-label {
  display: block;
  font-size: var(--jy-text-sm);
  font-weight: 600;
  color: var(--jy-color-text);
  margin-bottom: var(--jy-space-2);
}
.jy-ui .form-label span[aria-label="required"] {
  color: var(--jy-color-danger);
  margin-left: 2px;
}

.jy-ui .form-control {
  display: block;
  width: 100%;
  height: var(--jy-control-h-md);
  padding: 0 var(--jy-space-3);
  font-family: var(--jy-font-sans);
  font-size: var(--jy-text-sm);
  color: var(--jy-color-text);
  background: var(--jy-color-bg);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-md);
  transition: border-color 0.15s, box-shadow 0.15s;
  appearance: none;
}
.jy-ui textarea.form-control {
  height: auto;
  min-height: calc(var(--jy-control-h-md) * 2.5);
  padding: var(--jy-space-3);
  line-height: var(--jy-leading-base);
  resize: vertical;
}
.jy-ui select.form-control {
  background-image:
    linear-gradient(45deg, transparent 50%, var(--jy-color-text-muted) 50%),
    linear-gradient(135deg, var(--jy-color-text-muted) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: var(--jy-space-8);
  cursor: pointer;
}
.jy-ui .form-control::placeholder { color: var(--jy-color-text-subtle); }
.jy-ui .form-control:focus {
  outline: none;
  border-color: var(--jy-color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--jy-color-primary) 18%, transparent);
}
.jy-ui .form-control.is-invalid { border-color: var(--jy-color-danger); }
.jy-ui .form-control.is-invalid:focus {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--jy-color-danger) 20%, transparent);
}

.jy-ui .form-error {
  margin-top: var(--jy-space-1);
  font-size: var(--jy-text-xs);
  color: var(--jy-color-danger);
}
.jy-ui .error-list { list-style: none; padding: 0; margin: 0; }

.jy-ui .form-help {
  display: block;
  margin-top: var(--jy-space-1);
  font-size: var(--jy-text-xs);
  color: var(--jy-color-text-muted);
}

.jy-ui .form-check {
  display: flex;
  align-items: center;
  gap: var(--jy-space-2);
  padding-left: 0;
  margin-bottom: var(--jy-space-2);
}
.jy-ui .form-check-input {
  position: relative;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  accent-color: var(--jy-color-primary);
  cursor: pointer;
  margin: 0;
}
.jy-ui .form-check-label {
  font-size: var(--jy-text-sm);
  color: var(--jy-color-text);
  cursor: pointer;
  line-height: 1.4;
  margin-bottom: 0;
}

/* ─── Cards ───────────────────────────────────────────────────── */
.jy-ui .card {
  background: var(--jy-color-bg);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-lg);
  box-shadow: var(--jy-shadow-sm);
  overflow: hidden;
  margin-bottom: var(--jy-space-4);
}
.jy-ui .card:last-child { margin-bottom: 0; }
.jy-ui .mb-3 { margin-bottom: var(--jy-space-4) !important; }

.jy-ui .card-header {
  padding: var(--jy-space-4) var(--jy-space-5);
  background: var(--jy-color-surface);
  border-bottom: 1px solid var(--jy-color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--jy-space-3);
}
.jy-ui .card-header.bg-body-tertiary { background: var(--jy-color-surface); }
.jy-ui .card-header h6,
.jy-ui .card-header .h6 {
  margin-bottom: 0;
  font-size: var(--jy-text-sm);
  font-weight: 600;
}
.jy-ui .card-body { padding: var(--jy-space-5); }
.jy-ui .card-footer {
  padding: var(--jy-space-4) var(--jy-space-5);
  background: var(--jy-color-surface);
  border-top: 1px solid var(--jy-color-border);
}

/* ─── Auth Card ───────────────────────────────────────────────── */
.jy-ui .auth-page,
.jy-ui .auth-wrap {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  min-height: calc(100vh - 60px);
  padding: var(--jy-space-8) var(--jy-space-5);
  background: var(--jy-color-surface);
}
.jy-ui .auth-card {
  width: 420px;
  max-width: 100%;
  background: var(--jy-color-bg);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-lg);
  padding: var(--jy-space-6);
  box-shadow: var(--jy-shadow-md);
}
.jy-ui .auth-logo {
  display: flex;
  justify-content: center;
  margin-bottom: var(--jy-space-5);
}
.jy-ui .auth-logo a {
  display: flex;
  align-items: center;
  gap: var(--jy-space-2);
  font-family: var(--jy-font-display);
  font-size: var(--jy-text-xl);
  font-weight: 700;
  color: var(--jy-color-text);
  text-decoration: none;
}
.jy-ui .auth-logo img { height: 40px; width: auto; }
.jy-ui .auth-card h3 {
  font-size: var(--jy-text-2xl);
  text-align: center;
  margin-bottom: var(--jy-space-5);
}
.jy-ui .auth-card .btn-primary { width: 100%; margin-top: var(--jy-space-4); }
.jy-ui .auth-footer-text {
  margin-top: var(--jy-space-5);
  text-align: center;
  font-size: var(--jy-text-sm);
  color: var(--jy-color-text-muted);
}
.jy-ui .auth-links {
  display: flex;
  justify-content: space-between;
  margin-top: var(--jy-space-4);
  font-size: var(--jy-text-sm);
}

/* ─── Alerts ──────────────────────────────────────────────────── */
/* renderAlert() outputs .alert .alert-{type}
   types used: success, warning (mapped from 'warn'), error, info */
.jy-ui .alert {
  display: flex;
  align-items: flex-start;
  gap: var(--jy-space-3);
  padding: var(--jy-space-3) var(--jy-space-4);
  border-radius: var(--jy-radius-md);
  border: 1px solid transparent;
  font-size: var(--jy-text-sm);
  margin-bottom: var(--jy-space-4);
}
.jy-ui .alert:last-child { margin-bottom: 0; }
.jy-ui .alert[role="alert"] h4 {
  font-size: var(--jy-text-sm);
  font-weight: 700;
  margin-bottom: var(--jy-space-1);
}
.jy-ui .alert[role="alert"] p { margin-bottom: 0; }
.jy-ui .alert svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; }

.jy-ui .alert-success {
  background: var(--jy-color-success-bg);
  color: var(--jy-color-success);
  border-color: color-mix(in srgb, var(--jy-color-success) 25%, transparent);
}
.jy-ui .alert-info {
  background: var(--jy-color-info-bg);
  color: var(--jy-color-info);
  border-color: color-mix(in srgb, var(--jy-color-info) 25%, transparent);
}
.jy-ui .alert-warning,
.jy-ui .alert-warn {
  background: var(--jy-color-warning-bg);
  color: var(--jy-color-warning);
  border-color: color-mix(in srgb, var(--jy-color-warning) 25%, transparent);
}
.jy-ui .alert-error,
.jy-ui .alert-danger {
  background: var(--jy-color-danger-bg);
  color: var(--jy-color-danger);
  border-color: color-mix(in srgb, var(--jy-color-danger) 25%, transparent);
}

/* ─── Badges ──────────────────────────────────────────────────── */
.jy-ui .badge {
  display: inline-flex;
  align-items: center;
  gap: var(--jy-space-1);
  padding: 2px var(--jy-space-2);
  font-size: var(--jy-text-xs);
  font-weight: 600;
  border-radius: var(--jy-radius-full);
  line-height: 1.5;
  background: var(--jy-color-surface-alt);
  color: var(--jy-color-text-muted);
  border: 1px solid var(--jy-color-border);
  white-space: nowrap;
}
.jy-ui .badge-success { background: var(--jy-color-success-bg); color: var(--jy-color-success); border-color: transparent; }
.jy-ui .badge-warning { background: var(--jy-color-warning-bg); color: var(--jy-color-warning); border-color: transparent; }
.jy-ui .badge-danger,
.jy-ui .badge-error   { background: var(--jy-color-danger-bg);  color: var(--jy-color-danger);  border-color: transparent; }
.jy-ui .badge-info    { background: var(--jy-color-info-bg);    color: var(--jy-color-info);    border-color: transparent; }
.jy-ui .badge-primary {
  background: color-mix(in srgb, var(--jy-color-primary) 12%, var(--jy-color-bg));
  color: var(--jy-color-primary);
  border-color: transparent;
}
.jy-ui .badge-muted { background: var(--jy-color-surface-alt); color: var(--jy-color-text-subtle); border-color: transparent; }
.jy-ui .tag {
  display: inline-block;
  padding: var(--jy-space-1) var(--jy-space-3);
  font-size: var(--jy-text-xs);
  font-weight: 500;
  background: var(--jy-color-surface);
  color: var(--jy-color-text-muted);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-sm);
}

/* ─── Tables ──────────────────────────────────────────────────── */
.jy-ui .table-wrap,
.jy-ui .table-wrapper {
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-md);
  overflow: hidden;
  background: var(--jy-color-bg);
  margin-bottom: var(--jy-space-5);
}
.jy-ui table,
.jy-ui table.data,
.jy-ui .styled-table { width: 100%; border-collapse: collapse; font-size: var(--jy-text-sm); }
.jy-ui table th {
  text-align: left;
  padding: var(--jy-space-3) var(--jy-space-4);
  background: var(--jy-color-surface);
  font-weight: 600;
  color: var(--jy-color-text-muted);
  font-size: var(--jy-text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-bottom: 1px solid var(--jy-color-border);
}
.jy-ui table td {
  text-align: left;
  padding: var(--jy-space-3) var(--jy-space-4);
  border-bottom: 1px solid var(--jy-color-border);
  color: var(--jy-color-text);
  vertical-align: middle;
}
.jy-ui table tbody tr:nth-child(even) td { background: var(--jy-color-surface); }
.jy-ui table tbody tr:hover td { background: var(--jy-color-surface-alt); }
.jy-ui table tbody tr:last-child td { border-bottom: none; }
.jy-ui td.num { text-align: right; font-variant-numeric: tabular-nums; }

/* ─── Profile Tabs ────────────────────────────────────────────── */
.jy-ui .tabs {
  display: flex;
  border-bottom: 1px solid var(--jy-color-border);
  margin-bottom: var(--jy-space-5);
  gap: var(--jy-space-1);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.jy-ui .tab {
  padding: var(--jy-space-3) var(--jy-space-4);
  font-size: var(--jy-text-sm);
  font-weight: 500;
  color: var(--jy-color-text-muted);
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  cursor: pointer;
  background: none;
  font-family: var(--jy-font-sans);
  transition: color 0.15s;
}
.jy-ui .tab:hover { color: var(--jy-color-text); }
.jy-ui .tab.active {
  color: var(--jy-color-primary);
  border-bottom-color: var(--jy-color-primary);
  font-weight: 600;
}

/* ─── Item Grids ──────────────────────────────────────────────── */
.jy-ui .grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--jy-space-5); }
.jy-ui .grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--jy-space-5); }

.jy-ui .event-card,
.jy-ui .product-card {
  background: var(--jy-color-bg);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--jy-shadow-sm);
  transition: transform 0.15s, box-shadow 0.15s;
  text-decoration: none;
  color: inherit;
}
.jy-ui .event-card:hover,
.jy-ui .product-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--jy-shadow-md);
  text-decoration: none;
}
.jy-ui .thumb {
  aspect-ratio: 16 / 10;
  background: var(--jy-color-surface-alt);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.jy-ui .product-card .thumb { aspect-ratio: 4 / 3; }
.jy-ui .thumb img { width: 100%; height: 100%; object-fit: cover; }
.jy-ui .thumb svg { width: 48px; height: 48px; color: var(--jy-color-text-subtle); }

/* ─── Empty State ─────────────────────────────────────────────── */
.jy-ui .empty {
  text-align: center;
  padding: var(--jy-space-10) var(--jy-space-5);
  background: var(--jy-color-surface);
  border: 1px dashed var(--jy-color-border-strong);
  border-radius: var(--jy-radius-lg);
}
.jy-ui .empty svg { width: 48px; height: 48px; color: var(--jy-color-text-subtle); margin: 0 auto var(--jy-space-4); }
.jy-ui .empty h4 { margin-bottom: var(--jy-space-2); }
.jy-ui .empty p { color: var(--jy-color-text-muted); margin-bottom: var(--jy-space-4); }

/* ─── Cart Summary ────────────────────────────────────────────── */
.jy-ui .cart {
  background: var(--jy-color-bg);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-lg);
  overflow: hidden;
}
.jy-ui .cart-line {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: var(--jy-space-4);
  align-items: center;
  padding: var(--jy-space-4) var(--jy-space-5);
  border-bottom: 1px solid var(--jy-color-border);
  font-size: var(--jy-text-sm);
}
.jy-ui .cart-totals { background: var(--jy-color-surface); padding: var(--jy-space-3) var(--jy-space-5); }
.jy-ui .cart-totals .row {
  display: flex;
  justify-content: space-between;
  padding: var(--jy-space-1) 0;
  font-size: var(--jy-text-sm);
  color: var(--jy-color-text-muted);
}
.jy-ui .cart-totals .row.total {
  font-size: var(--jy-text-lg);
  font-weight: 700;
  color: var(--jy-color-text);
  border-top: 1px solid var(--jy-color-border);
  padding-top: var(--jy-space-3);
  margin-top: var(--jy-space-2);
}
.jy-ui .cart-cta { padding: var(--jy-space-5); }
.jy-ui .cart-cta .btn { width: 100%; }

/* ─── Pagination ──────────────────────────────────────────────── */
.jy-ui .pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--jy-space-2);
  flex-wrap: wrap;
  margin: var(--jy-space-6) 0;
}
.jy-ui .pagination a,
.jy-ui .pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: var(--jy-control-h-sm);
  height: var(--jy-control-h-sm);
  padding: 0 var(--jy-space-3);
  border: 1px solid var(--jy-color-border);
  border-radius: var(--jy-radius-sm);
  font-size: var(--jy-text-sm);
  color: var(--jy-color-text);
  background: var(--jy-color-bg);
  text-decoration: none;
  transition: background 0.15s;
}
.jy-ui .pagination a:hover { background: var(--jy-color-surface-alt); text-decoration: none; }
.jy-ui .pagination .active,
.jy-ui .pagination .current {
  background: var(--jy-color-primary);
  border-color: var(--jy-color-primary);
  color: var(--jy-color-primary-text);
}
.jy-ui .pagination .ellipsis { border: none; background: none; color: var(--jy-color-text-subtle); }
.jy-ui .pagination .disabled { opacity: 0.4; pointer-events: none; }

/* ─── Scoped Breadcrumbs ──────────────────────────────────────── */
.jy-ui nav.jy-breadcrumbs { font-size: var(--jy-text-sm); color: var(--jy-color-text-muted); }
.jy-ui nav.jy-breadcrumbs ol { display: flex; align-items: center; gap: var(--jy-space-2); list-style: none; flex-wrap: wrap; }
.jy-ui nav.jy-breadcrumbs li { display: flex; align-items: center; gap: var(--jy-space-2); }
.jy-ui nav.jy-breadcrumbs li::before { content: '›'; color: var(--jy-color-text-subtle); }
.jy-ui nav.jy-breadcrumbs li:first-child::before { display: none; }
.jy-ui nav.jy-breadcrumbs a { color: var(--jy-color-text-muted); }
.jy-ui nav.jy-breadcrumbs a:hover { color: var(--jy-color-primary); text-decoration: none; }
.jy-ui nav.jy-breadcrumbs li.active { color: var(--jy-color-text); font-weight: 500; }

/* ─── Content Helpers ─────────────────────────────────────────── */
.jy-ui .action-row { display: flex; gap: var(--jy-space-3); margin-top: var(--jy-space-5); flex-wrap: wrap; }
.jy-ui .pill-row   { display: flex; gap: var(--jy-space-2); flex-wrap: wrap; }
.jy-ui .stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--jy-space-4);
}

/* ─── Responsive ──────────────────────────────────────────────── */
@media (max-width: 900px) {
  .jy-ui .grid-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .jy-ui .grid-3,
  .jy-ui .grid-2 { grid-template-columns: 1fr; }
  .jy-ui .auth-page,
  .jy-ui .auth-wrap { padding: var(--jy-space-4) var(--jy-space-3); }
  .jy-ui .auth-card { padding: var(--jy-space-5); }
}
