﻿/* ==========================================================================
   Athenian Product Add-ons â€” Compact â€œProâ€ Dark UI (Token-aware) â€” DEDUPED
   - Single token system (APF â†’ CTL â†’ generic â†’ cosmic fallback)
   - Unified base shell + groups + inputs + choices
   - Swatches grid, WTL micro-row, multi-upload cards (chevron + upload-head),
     status card, dim/infill row, AI modal, hybrid UI
   ========================================================================== */

/* --------------------------------------------------------------------------
   0) Scope + resets
   -------------------------------------------------------------------------- */
.athenian-addons,
.athenian-addons * { box-sizing: border-box; }

.athenian-addons :where(button, input, select, textarea){
  font: inherit;
  color: inherit;
}
.athenian-addons :where(label){ cursor: pointer; }

/* --------------------------------------------------------------------------
   1) Tokens (TOKEN-FIRST) + cosmic fallback
   -------------------------------------------------------------------------- */
.athenian-addons{
  /* Density + radius */
  --apadd-pad: 10px;
  --apadd-gap: 8px;
  --apadd-radius: 12px;
  --apadd-radius-sm: 10px;
  --apadd-radius-xs: 9px;

  /* Typography (slightly smaller) */
  --apadd-font: 11px;
  --apadd-label-font: 11px;
  --apadd-help-font: 10px;
  --apadd-title-font: 10px;

  /* Cosmic fallback palette */
  --apadd-fb-hue1: 270;
  --apadd-fb-hue2: 220;
  --apadd-fb-hue3: 305;

  --apadd-fb-s0: rgba(6, 7, 18, .92);
  --apadd-fb-s1: rgba(10, 12, 28, .86);
  --apadd-fb-s2: rgba(14, 18, 38, .78);
  --apadd-fb-s3: rgba(18, 24, 52, .64);

  --apadd-fb-text: rgba(234, 240, 255, .92);
  --apadd-fb-mid:  rgba(196, 206, 232, .78);
  --apadd-fb-low:  rgba(164, 176, 206, .62);

  --apadd-fb-bd:   rgba(180, 196, 230, .16);
  --apadd-fb-bd2:  rgba(180, 196, 230, .12);

  --apadd-fb-c1: oklch(0.78 0.20 var(--apadd-fb-hue3));
  --apadd-fb-c2: oklch(0.82 0.16 var(--apadd-fb-hue2));
  --apadd-fb-c3: oklch(0.90 0.06 260);
  --apadd-fb-c4: oklch(0.60 0.16 var(--apadd-fb-hue1));
  --apadd-fb-c5: oklch(0.74 0.14 210);
  --apadd-fb-c6: oklch(0.44 0.08 300);

  /* Accent scale */
  --apadd-c1: var(--apf-c1, var(--ctl-c1, var(--apadd-fb-c1)));
  --apadd-c2: var(--apf-c2, var(--ctl-c2, var(--apadd-fb-c2)));
  --apadd-c3: var(--apf-c3, var(--ctl-c3, var(--apadd-fb-c3)));
  --apadd-c4: var(--apf-c4, var(--ctl-c4, var(--apadd-fb-c4)));
  --apadd-c5: var(--apf-c5, var(--ctl-c5, var(--apadd-fb-c5)));
  --apadd-c6: var(--apf-c6, var(--ctl-c6, var(--apadd-fb-c6)));

  /* Text */
  --apadd-text:  var(--apf-text,     var(--text-high, var(--apadd-fb-text)));
  --apadd-muted: var(--apf-text-mid, var(--text-mid,  var(--apadd-fb-mid)));
  --apadd-help:  var(--apf-text-low, var(--text-low,  var(--apadd-fb-low)));

  /* Surfaces */
  --apadd-surface-0: var(--apf-surface-0, var(--surface-0, var(--apadd-fb-s0)));
  --apadd-surface-1: var(--apf-surface-1, var(--surface-1, var(--apadd-fb-s1)));
  --apadd-surface-2: var(--apf-surface-2, var(--surface-2, var(--apadd-fb-s2)));
  --apadd-surface-3: var(--apf-surface-3, var(--surface-3, var(--apadd-fb-s3)));

  /* Borders */
  --apadd-border:      var(--apf-border, var(--border, var(--apadd-fb-bd)));
  --apadd-border-soft: color-mix(in oklch, var(--apadd-border) 75%, transparent);

  /* Accent */
  --apadd-accent:   var(--ath-accent, var(--ast-accent, var(--apadd-c1, #ec8639)));
  --apadd-accent-2: color-mix(in oklch, var(--apadd-accent) 22%, transparent);

  /* Palette outputs */
  --apadd-bg:      color-mix(in oklch, var(--apadd-surface-1) 82%, transparent);
  --apadd-bg2:     color-mix(in oklch, var(--apadd-surface-2) 72%, transparent);
  --apadd-surface: color-mix(in oklch, var(--apadd-surface-2) 62%, transparent);

  /* Shadows + blur */
  --apadd-shadow: 0 10px 26px rgba(0,0,0,0.22);
  --apadd-shadow-soft: 0 6px 14px rgba(0,0,0,0.18);

  /* Focus ring */
  --apadd-ring:
    0 0 0 1px color-mix(in oklch, var(--apadd-accent) 55%, transparent),
    0 0 0 4px color-mix(in oklch, var(--apadd-accent) 20%, transparent);

  /* Inputs */
  --apadd-input-bg:     color-mix(in oklch, var(--apadd-surface-2) 62%, transparent);
  --apadd-input-border: color-mix(in oklch, var(--apadd-border) 78%, var(--apadd-c2) 8%);

  /* Chips / choice tiles */
  --apadd-chip-bg:       color-mix(in oklch, var(--apadd-surface-2) 56%, transparent);
  --apadd-chip-bg-hover: color-mix(in oklch, var(--apadd-surface-2) 68%, transparent);
  --apadd-chip-border:   color-mix(in oklch, var(--apadd-border) 70%, transparent);

  /* Motion */
  --apadd-ease: cubic-bezier(.2,.8,.2,1);
  --apadd-fast: 120ms;
  --apadd-med: 180ms;

  /* Multi-upload knobs */
  --apadd-mu-head-pad-y: 10px;
  --apadd-mu-head-pad-x: 12px;
  --apadd-mu-body-pad: 12px;
  --apadd-mu-head-fs: 11.75px;
  --apadd-mu-price-fs: 10px;
}

/* --------------------------------------------------------------------------
   2) Outer container + groups
   -------------------------------------------------------------------------- */
.athenian-addons--product{
  margin: 12px 0;
}

.athenian-addons__group{
  margin: 0 0 var(--apadd-gap);
  padding: var(--apadd-pad);
  border-radius: var(--apadd-radius);
  background: color-mix(in srgb, var(--apadd-bg2) 84%, transparent);
  border: 1px solid var(--apadd-border-soft);
}
.athenian-addons__group:last-child{ margin-bottom: 0; }

.athenian-addons__group-title{
  font-size: var(--apadd-title-font);
  font-weight: 800;
  letter-spacing: 0.12em;
  color: var(--apadd-muted);
}

/* --------------------------------------------------------------------------
   3) Fields + labels
   -------------------------------------------------------------------------- */

.athenian-addons__label{
  display:block;
  font-size: var(--apadd-label-font);
  font-weight: 750;
  margin: 0 0 6px;
  color: var(--apadd-text);
}
.athenian-addons__required{ color:#ef4444; font-weight: 900; }

.athenian-addons__help{
  margin: 4px 0 0;
  font-size: var(--apadd-help-font);
  color: var(--apadd-help);
}

/* --------------------------------------------------------------------------
   4) Inputs
   -------------------------------------------------------------------------- */
.athenian-addons__input{
  width: 100%;
  max-width: 100%;
  border-radius: var(--apadd-radius-sm);
  border: 1px solid var(--apadd-input-border);
  padding: 7px 10px;
  font-size: var(--apadd-font);
  line-height: 1.2;
  color: var(--apadd-text);
  background-color: var(--apadd-input-bg);
  transition:
    border-color var(--apadd-fast) var(--apadd-ease),
    box-shadow   var(--apadd-fast) var(--apadd-ease),
    background-color var(--apadd-fast) var(--apadd-ease),
    transform    var(--apadd-fast) var(--apadd-ease);
}
.athenian-addons__input::placeholder{ color: var(--apadd-muted); opacity: .92; }

.athenian-addons__input:focus{
  outline:none;
  border-color: color-mix(in srgb, var(--apadd-accent) 55%, transparent);
  box-shadow: var(--apadd-ring);
  background-color: color-mix(in srgb, var(--apadd-input-bg) 72%, rgba(0,0,0,0.18));
}
.athenian-addons__input:disabled{ opacity: .65; cursor: not-allowed; }

.athenian-addons__input--multi-select{
  min-height: 120px;
  padding: 8px 10px;
}

/* Select arrow + truncation */
.athenian-addons :where(select.athenian-addons__input, select.athenian-addons__input--select){
  -webkit-appearance:none;
  appearance:none;
  padding-right: 30px;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position:
    calc(100% - 14px) 50%,
    calc(100% - 9px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

/* --------------------------------------------------------------------------
   5) Default choices layout (2-col grid)
   - Exempt: swatches + multi-upload
   -------------------------------------------------------------------------- */
.athenian-addons .athenian-addons__choices{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));

  align-items: stretch;
}

/* Base choice chip */
.athenian-addons .athenian-addons__choice{
  width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;


  font-size: 10.75px;

  border-radius: 999px;
  border: 1px solid var(--apadd-chip-border);
  background: var(--apadd-chip-bg);
  color: var(--apadd-text);

  cursor:pointer;
  transition:
    background-color var(--apadd-fast) var(--apadd-ease),
    border-color     var(--apadd-fast) var(--apadd-ease),
    transform        var(--apadd-fast) var(--apadd-ease),
    box-shadow       var(--apadd-fast) var(--apadd-ease);
}

.athenian-addons .athenian-addons__choice input{ accent-color: var(--apadd-accent); }

.athenian-addons .athenian-addons__choice:hover{
  background: var(--apadd-chip-bg-hover);
  border-color: color-mix(in srgb, var(--apadd-border) 75%, transparent);
  transform: translateY(-1px);
  box-shadow: var(--apadd-shadow-soft);
}

.athenian-addons .athenian-addons__choice:has(input:checked){
  border-color: color-mix(in srgb, var(--apadd-accent) 55%, transparent);
  box-shadow: 0 0 0 3px var(--apadd-accent-2);
  background: color-mix(in srgb, var(--apadd-chip-bg) 70%, var(--apadd-accent-2));
}

.athenian-addons .athenian-addons__choice:has(input:focus-visible){
  box-shadow: var(--apadd-ring);
  border-color: color-mix(in srgb, var(--apadd-accent) 60%, transparent);
}

/* Mobile 1-col (non-swatches, non-multi-upload) */
@media (max-width: 520px){
  .athenian-addons .athenian-addons__choices:not(.athenian-addons__choices--swatch):not(.athenian-addons__choices--multi-upload){
    grid-template-columns: 1fr;
  }
}

/* --------------------------------------------------------------------------
   5b) Image choices (RADIO/CHECKBOX) â€” 2-row layout (input+thumb / title+price)
   - Row 1: input + thumb
   - Row 2: label + price (wraps, no clipping)
   - Tight padding + smaller fonts
   -------------------------------------------------------------------------- */
.athenian-addons__choices--image .athenian-addons__choice,
.athenian-addons__choices--image-swatch .athenian-addons__choice{
  display: grid !important;
  grid-template-columns: 16px 38px 1fr; /* input | thumb | spacer */
  grid-template-rows: auto auto;        /* row1, row2 */
  align-items: center;
  column-gap: 8px;
  row-gap: 4px;

  padding: 6px 8px !important;
  border-radius: var(--apadd-radius-sm) !important;
  font-size: 10.5px;
}

.athenian-addons__choices--image .athenian-addons__choice > input[type="checkbox"],
.athenian-addons__choices--image .athenian-addons__choice > input[type="radio"],
.athenian-addons__choices--image-swatch .athenian-addons__choice > input[type="checkbox"],
.athenian-addons__choices--image-swatch .athenian-addons__choice > input[type="radio"]{
  grid-column: 1;
  grid-row: 1;
  width: 14px;
  height: 14px;
  margin: 0 !important;
  align-self: center;
  accent-color: var(--apadd-accent);
}

.athenian-addons__choices--image .athenian-addons__choice-thumb,
.athenian-addons__choices--image-swatch .athenian-addons__choice-thumb{
  grid-column: 2;
  grid-row: 1;
  width: 38px;
  height: 38px;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.athenian-addons__choices--image .athenian-addons__choice-thumb img,
.athenian-addons__choices--image-swatch .athenian-addons__choice-thumb img{
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.athenian-addons__choices--image .athenian-addons__choice-inner,
.athenian-addons__choices--image-swatch .athenian-addons__choice-inner{
  display: contents !important;
}

/* WRAPPING label (no clipping) */
.athenian-addons__choices--image .athenian-addons__choice-label-text,
.athenian-addons__choices--image-swatch .athenian-addons__choice-label-text{
  grid-column: 1 / -1;
  grid-row: 2;

  font-size: 10px;
  line-height: 1.12;
  font-weight: 800;

  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
  word-break: break-word;
  overflow-wrap: anywhere;

  margin: 0;
  padding: 0;
}

/* Compact price pill */
.athenian-addons__choices--image .athenian-addons__choice-price,
.athenian-addons__choices--image-swatch .athenian-addons__choice-price{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  margin-left: 6px;
  padding: 2px 6px;
  border-radius: 999px;

  font-size: 9.25px;
  font-weight: 950;
  white-space: nowrap;

  border: 1px solid color-mix(in srgb, var(--apadd-accent) 38%, var(--apadd-border-soft));
  background: color-mix(in srgb, rgba(0,0,0,.18) 70%, var(--apadd-accent-2));
  color: color-mix(in oklch, var(--apadd-text) 94%, transparent);
}

/* --------------------------------------------------------------------------
   6) WTL micro-row (Width + Thickness + Layers)
   -------------------------------------------------------------------------- */
.athenian-addons__group{
  --apadd-wtl-gap: 8px;
  --apadd-wtl-label: 10.5px;
  --apadd-wtl-ctl-h: 30px;
  --apadd-wtl-ctl-r: 9px;
  --apadd-wtl-ctl-px: 8px;
  --apadd-wtl-ctl-fs: 12px;
}
.athenian-addons .ath-ap-row--w-t-l{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--apadd-wtl-gap);
  align-items:end;
  margin: 0 0 10px;
}
.athenian-addons .ath-ap-row--w-t-l .athenian-addons__field{
  margin: 0 !important;
  padding: 0 !important;
}
.athenian-addons .ath-ap-row--w-t-l .athenian-addons__label{
  margin: 0 0 6px !important;
  font-size: var(--apadd-wtl-label) !important;
  line-height: 1.05 !important;
  letter-spacing: .2px !important;
  color: var(--apadd-muted) !important;
  font-weight: 750 !important;
}
.athenian-addons .ath-ap-row--w-t-l .athenian-addons__input{
  height: var(--apadd-wtl-ctl-h) !important;
  min-height: var(--apadd-wtl-ctl-h) !important;
  padding: 0 var(--apadd-wtl-ctl-px) !important;
  border-radius: var(--apadd-wtl-ctl-r) !important;
  font-size: var(--apadd-wtl-ctl-fs) !important;
  line-height: 1 !important;
}
.athenian-addons .ath-ap-row--w-t-l select.athenian-addons__input{
  padding-right: calc(var(--apadd-wtl-ctl-px) + 18px) !important;
}
.athenian-addons .ath-ap-row--w-t-l .athenian-addons__help{ display:none !important; }

@media (max-width: 720px){
  .athenian-addons .ath-ap-row--w-t-l{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .athenian-addons .ath-ap-row--w-t-l .athenian-addons__field[data-field-name="layers"]{ grid-column: 1 / -1; }
}

/* --------------------------------------------------------------------------
   7) Multi-upload choices (card tiles) â€” chevron header + upload-head row
   -------------------------------------------------------------------------- */
.athenian-addons .athenian-addons__choices.athenian-addons__choices--multi-upload{
  grid-template-columns: 1fr;
  gap: 8px;
}

.athenian-addons .athenian-addons__choice.athenian-addons__choice--multi-upload{
  display:block !important;
  padding:0 !important;
  border-radius: 14px !important;
  overflow:hidden !important;
  border: 1px solid var(--apadd-chip-border);
  background: color-mix(in srgb, var(--apadd-chip-bg) 86%, transparent);
  transition:
    background-color var(--apadd-fast) var(--apadd-ease),
    border-color     var(--apadd-fast) var(--apadd-ease),
    box-shadow       var(--apadd-fast) var(--apadd-ease),
    transform        var(--apadd-fast) var(--apadd-ease);
}
.athenian-addons .athenian-addons__choice--multi-upload:hover{
  border-color: color-mix(in srgb, var(--apadd-border) 78%, transparent);
  background: var(--apadd-chip-bg-hover);
  box-shadow: var(--apadd-shadow-soft);
  transform: translateY(-1px);
}

/* Header row */
.athenian-addons .athenian-addons__choice--multi-upload > label.athenian-addons__choice-main{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap: 10px !important;

  padding: 8px 10px !important;
  margin: 0 !important;

  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)) !important;
  border-bottom: 1px solid var(--apadd-border-soft) !important;
}

.athenian-addons .athenian-addons__choice--multi-upload
> label.athenian-addons__choice-main > input[type="checkbox"]{
  width: 14px !important;
  height: 14px !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
  accent-color: var(--apadd-accent);
}

.athenian-addons .athenian-addons__choice--multi-upload
> label.athenian-addons__choice-main .athenian-addons__choice-label{
  display:flex !important;
  align-items:baseline !important;
  gap: 8px !important;
  flex: 1 1 auto !important;
  min-width:0 !important;

  font-size: 11.5px !important;
  font-weight: 950 !important;
  line-height: 1.05 !important;
}

.athenian-addons .athenian-addons__choice--multi-upload
> label.athenian-addons__choice-main .apadd-title{
  flex: 1 1 auto !important;
  min-width:0 !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
  white-space:nowrap !important;
}

.athenian-addons .athenian-addons__choice--multi-upload
> label.athenian-addons__choice-main .athenian-addons__choice-price{
  flex: 0 0 auto !important;
  white-space:nowrap !important;
  margin:0 !important;

  font-size: 9.75px !important;
  font-weight: 950 !important;
  opacity: .9 !important;

  padding: 2px 6px !important;
  border-radius: 999px !important;
  border: 1px solid color-mix(in srgb, var(--apadd-accent) 38%, var(--apadd-border-soft)) !important;
  background: color-mix(in srgb, rgba(0,0,0,.18) 70%, var(--apadd-accent-2)) !important;
}

/* Open body */
.athenian-addons .athenian-addons__choice--multi-upload > .athenian-addons__choice-upload{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  padding: 10px !important;
  background: transparent !important;
}

/* File UI */
.apadd-file-ui{ display:grid; gap:6px; }

.apadd-file-ui__native{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}
.apadd-file-ui input[type="file"].apadd-file-ui__native{ display:none !important; }

.apadd-file-ui__top{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.apadd-file-ui__btn,
.apadd-file-ui__clear{
  appearance:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  border:1px solid var(--apadd-border-soft);
  background: color-mix(in srgb, var(--apadd-surface) 70%, rgba(0,0,0,0.08));
  color: var(--apadd-text);
  padding: 7px 10px;
  border-radius: var(--apadd-radius-sm);
  font-size: 11px;
  font-weight: 750;
  cursor:pointer;
  transition:
    border-color var(--apadd-fast) var(--apadd-ease),
    box-shadow   var(--apadd-fast) var(--apadd-ease),
    background-color var(--apadd-fast) var(--apadd-ease),
    transform    var(--apadd-fast) var(--apadd-ease);
}

.apadd-file-ui__btn:hover{
  border-color: color-mix(in srgb, var(--apadd-accent) 45%, var(--apadd-border-soft));
  box-shadow: 0 0 0 3px var(--apadd-accent-2);
  transform: translateY(-1px);
}
.apadd-file-ui__btn:focus-visible,
.apadd-file-ui__clear:focus-visible{
  outline:none;
  box-shadow: var(--apadd-ring);
  border-color: color-mix(in srgb, var(--apadd-accent) 60%, transparent);
}

.apadd-file-ui__name{
  flex: 1;
  min-width:0;
  font-size: 8.5px;
  color: var(--apadd-muted);
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}

/* Clear: subtle danger */
.apadd-file-ui__clear{
  color: var(--apadd-muted);
  font-weight: 700;
}
.apadd-file-ui__clear:hover{
  color:#fecaca;
  border-color: rgba(239, 68, 68, 0.35);
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.12);
}

.apadd-file-ui__preview{
  display:none;
  width:100%;
  max-width:240px;
  border-radius: var(--apadd-radius);
  overflow:hidden;
  border:1px solid var(--apadd-border-soft);
  background: rgba(0,0,0,0.14);
}
.apadd-file-ui__preview.is-visible{ display:block; }
.apadd-file-ui__preview img{ display:block; width:100%; height:auto; }

.athenian-addons__file-hint{
  font-size: var(--apadd-help-font);
  color: var(--apadd-help);
  opacity: .9;
}

.athenian-addons__file-meta,
.athenian-addons__url-meta{
  margin-top:8px;
  font-size: 10.5px;
  color: var(--apadd-help);
}
.athenian-addons__file-link{
  text-decoration:none;
  border-bottom:1px dashed currentColor;
}
.athenian-addons__file-link:hover{ border-bottom-style: solid; }

/* --------------------------------------------------------------------------
   9) Swatches (ultra compact)
   -------------------------------------------------------------------------- */
.athenian-addons__field--swatch{
  --sw-size: 22px;
  --sw-gap: 3px;
  --sw-text: var(--apadd-text);
  --sw-ring: var(--apadd-ring);
}

.athenian-addons__field--swatch .athenian-addons__choices.athenian-addons__choices--swatch{
  display:grid !important;
  grid-template-columns: repeat(8, minmax(0, 1fr)) !important;
}

.athenian-addons__field--swatch .athenian-addons__choice--swatch{
  position:relative;
  display:block;
  margin:0;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  user-select:none;
}
.athenian-addons__field--swatch .athenian-addons__choice--swatch > :where(input[type="radio"], input[type="checkbox"]){
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.athenian-addons__field--swatch .athenian-addons__choice-inner{
  display:grid;
  justify-items:center;
  padding: 3px;
  transition:
    transform var(--apadd-fast) var(--apadd-ease),
    box-shadow var(--apadd-fast) var(--apadd-ease);
  min-height:0;
}
.athenian-addons__field--swatch .athenian-addons__choice--swatch:hover .athenian-addons__choice-inner{
  transform: translateY(-2px);
}

.athenian-addons__field--swatch .athenian-addons__swatch{
  width: var(--sw-size);
  height: var(--sw-size);
  border-radius: 999px;
}

/* White swatches */
.athenian-addons__field--swatch .athenian-addons__swatch[style*="#FFF"],
.athenian-addons__field--swatch .athenian-addons__swatch[style*="#fff"]{
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.35),
    inset 0 0 0 2px rgba(0,0,0,0.25);
}

.athenian-addons__field--swatch .athenian-addons__choice-label-text{
  display:block;
  text-align:center;
  font-size: 7.5px;
  line-height: 1.05;
  font-weight: 800;
  color: var(--sw-text);
  margin: 0;
  max-width:100%;
  word-break: break-word;
  hyphens:auto;
}

.athenian-addons__field--swatch
.athenian-addons__choice--swatch > input:checked
+ .athenian-addons__choice-inner::after{
  content:none !important;
}

/* Responsive swatch columns */
@media (max-width: 1024px){
  .athenian-addons__field--swatch .athenian-addons__choices.athenian-addons__choices--swatch{
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 720px){
  .athenian-addons__field--swatch .athenian-addons__choices.athenian-addons__choices--swatch{
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 480px){
  .athenian-addons__field--swatch .athenian-addons__choices.athenian-addons__choices--swatch{
    grid-template-columns: repeat(8, minmax(0, 1fr)) !important;
  }
}

/* --------------------------------------------------------------------------
   10) APA status / lead-time card (apf-css reuse)
   -------------------------------------------------------------------------- */
.athenian-addons .apf-css{
  --apf-price-bd: var(--apf-price-bd, var(--apa-border, var(--border, #2a2d36)));
  --apf-text:     var(--apf-text,     var(--apa-text, #e6edf7));
  --apf-text-mid: var(--apf-text-mid, var(--apa-text-mid, #b8c3d4));
  --tone: var(--apf-css-color, var(--apf-ok, color-mix(in oklch, var(--apa-c1, #6aa6ff) 65%, #000)));

  background: color-mix(in oklch, var(--apa-surface-1, #121217) 85%, var(--tone)) !important;
  border: 1px solid color-mix(in oklch, var(--tone) 28%, var(--apf-price-bd)) !important;
  border-radius: .6rem !important;
  padding: .6rem .7rem .65rem .85rem !important;
  color: var(--apf-text) !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: 6px 6px 18px rgba(0,0,0,.35), -2px -2px 10px rgba(255,255,255,.04) !important;
}
.athenian-addons .apf-css::before{
  content:"";
  position:absolute;
  inset:.5rem auto .5rem 0;
  width:4px;
  background: linear-gradient(
    180deg,
    color-mix(in oklch, var(--tone) 90%, #000),
    color-mix(in oklch, var(--tone) 65%, #000)
  );
  border-radius:4px;
}
.athenian-addons .apf-css__label{
  display:flex;
  align-items:center;
  gap:.4rem;
  font-weight:900;
  letter-spacing:.2px;
}
.athenian-addons .apf-css__label::before{
  content:"";
  width:.55rem;
  height:.55rem;
  border-radius:50%;
  background: color-mix(in oklch, var(--tone) 92%, #000);
  box-shadow: 0 0 0 1px color-mix(in oklch, var(--tone) 40%, transparent);
}
.athenian-addons .apf-css__details{
  margin-top:.25rem;
  color: color-mix(in oklch, var(--apf-text-mid) 92%, transparent);
  font-size:.88rem;
}
.athenian-addons .apf-css__lead{
  margin-top:.35rem;
  font-size:.86rem;
  color: color-mix(in oklch, var(--apf-text) 96%, transparent);
}
.athenian-addons .apf-css__lead strong{
  color: color-mix(in oklch, var(--tone) 42%, var(--apf-text));
}

.athenian-addons .apf-css[data-state="ok"],
.athenian-addons .apf-css[data-state="in_stock"]{
  --tone: var(--apf-ok, color-mix(in oklch, #35d3a7 85%, #000));
}
.athenian-addons .apf-css[data-state="warn"],
.athenian-addons .apf-css[data-state="extended_lead"]{
  --tone: var(--apf-warn, color-mix(in oklch, #f2b24b 85%, #000));
}
.athenian-addons .apf-css[data-state="wait"],
.athenian-addons .apf-css[data-state="back_ordered"]{
  --tone: var(--apf-wait, color-mix(in oklch, #60aed5 85%, #000));
}
.athenian-addons .apf-css[data-state="danger"],
.athenian-addons .apf-css[data-state="out_of_stock"]{
  --tone: var(--apf-danger, #ff5c73);
}

/* --------------------------------------------------------------------------
   11) 4-up row utility (dims/infill)
   -------------------------------------------------------------------------- */
.apf-dim-infill-row{
  display:grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 12px !important;
  width:100% !important;
}
.apf-dim-infill-row > .athenian-addons__field{
  min-width:0 !important;
  margin:0 !important;
}
.apf-dim-infill-row .athenian-addons__input{ width:100% !important; }
.apf-dim-infill-row select.athenian-addons__input{ min-height:42px; }
.apf-dim-infill-row .athenian-addons__help{
  font-size: 8.5px !important;
  line-height:1 !important;
  opacity:.85 !important;
}
@media (max-width: 860px){
  .apf-dim-infill-row{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 520px){
  .apf-dim-infill-row{ grid-template-columns: 1fr !important; }
}

/* Hide APA rendered_file field entirely */
.athenian-addons__field[data-field-name="rendered_file"]{ display:none !important; }

/* --------------------------------------------------------------------------
   12) AI Modal (modern, token-first) â€” fonts slightly smaller
   -------------------------------------------------------------------------- */
.apadd-file-ui__btn--ai{
  margin-left:6px;
  white-space:nowrap;
}

.apadd-file-ui__btn-label{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
}

.apadd-file-ui__ai-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:12px;
  height:12px;
  flex:0 0 12px;
}

.apadd-file-ui__ai-icon svg{
  display:block;
  width:100%;
  height:100%;
}

.apadd-ai-modal{
  position:fixed;
  inset:0;
  z-index:99999;
  display:none;
}
.apadd-ai-modal[aria-hidden="false"]{ display:block; }

.apadd-ai-modal__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(8px);
}

.apadd-ai-modal__panel{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%,-50%);
  width: min(1040px, calc(100vw - 24px));
  max-height: min(86vh, calc(100svh - 24px));
  overflow:auto;
  border-radius:16px;

  border: 1px solid color-mix(in oklch, var(--apadd-border, rgba(255,255,255,.14)) 85%, transparent);
  background: color-mix(in oklch, var(--apadd-surface-1, rgba(10,12,18,.92)) 92%, transparent);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
}

.apadd-ai-modal__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-bottom: 1px solid color-mix(in oklch, var(--apadd-border, rgba(255,255,255,.12)) 85%, transparent);
}

.apadd-ai-modal__titlewrap{ min-width:0; }
.apadd-ai-modal__title{
  font-weight:800;
  letter-spacing:.2px;
  font-size: 13px;
  line-height:1.1;
}
.apadd-ai-modal__subtitle{
  margin-top:4px;
  font-size: 10.75px;
  opacity:.78;
  line-height:1.2;
}

.apadd-ai-modal__x{
  width:38px;
  height:38px;
  flex: 0 0 auto;
  border-radius:12px;
  border: 1px solid color-mix(in oklch, var(--apadd-border, rgba(255,255,255,.14)) 85%, transparent);
  background: color-mix(in oklch, var(--apadd-surface-2, rgba(20,24,34,.8)) 90%, transparent);
  color: inherit;
  cursor:pointer;
  line-height:1;
  font-size:22px;
}
.apadd-ai-modal__x:hover{ filter: brightness(1.08); }

.apadd-ai-modal__body{
  display:grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr);
  gap:14px;
  padding:14px;
}
@media (max-width: 900px){
  .apadd-ai-modal__body{ grid-template-columns: 1fr; }
}

.apadd-ai-canvas{
  border-radius:16px;
  border: 1px solid color-mix(in oklch, var(--apadd-border, rgba(255,255,255,.14)) 85%, transparent);
  background: color-mix(in oklch, var(--apadd-surface-2, rgba(20,24,34,.72)) 92%, transparent);
  padding:10px;
  position:relative;
  overflow:hidden;
}

.apadd-ai-canvas__stage{
  position:relative;
  width:100%;
  max-width:560px;
  margin:0 auto;
  border-radius:14px;
  overflow:hidden;
  border: 1px solid color-mix(in oklch, var(--apadd-border, rgba(255,255,255,.16)) 85%, transparent);
  background:
    linear-gradient(45deg, rgba(255,255,255,.08) 25%, transparent 25%, transparent 75%, rgba(255,255,255,.08) 75%, rgba(255,255,255,.08)),
    linear-gradient(45deg, rgba(255,255,255,.08) 25%, transparent 25%, transparent 75%, rgba(255,255,255,.08) 75%, rgba(255,255,255,.08));
  background-position: 0 0, 10px 10px;
  background-size: 20px 20px;
  aspect-ratio: 1 / 1;
}
.apadd-ai-canvas__canvas{ width:100%; height:100%; display:block; }

.apadd-ai-canvas__empty{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(255,255,255,.78);
  font-size: 11px;
  pointer-events:none;
  text-shadow: 0 1px 0 rgba(0,0,0,.4);
}

/* --------------------------------------------------------------------------
   14) Responsive tweaks
   -------------------------------------------------------------------------- */
@media (max-width: 640px){
  .athenian-addons__group{ padding: 10px; }
  .athenian-addons__field--swatch .athenian-addons__choices--swatch{ gap: 6px !important; }
}

/* Product/variation injection helper node (data carrier) */
.athenian-addons__product-choice{
  display:none !important;
}

/* Hide entire APADD field if it contains a hidden input */
.athenian-addons__field:has(
  > input.athenian-addons__input[type="hidden"]
) {
  display: none !important;
}

/* ======================================================================
   Multi-upload: collapsible cards + single-option auto-open styling (2026-03)
   - JS toggles .is-open on .athenian-addons__choice--multi-upload
   - Keeps existing .apadd-file-ui buttons (Media / AI / Clear)
   ====================================================================== */

/* Collapse upload body by default */
.athenian-addons .athenian-addons__choice--multi-upload > .athenian-addons__choice-upload{
  display:none;
}

/* Expand when open */
.athenian-addons .athenian-addons__choice--multi-upload.is-open > .athenian-addons__choice-upload{
  display:block;
}

/* Header chevron (token-aware) */
.athenian-addons .athenian-addons__choice--multi-upload > label.athenian-addons__choice-main{
  position:relative;
  padding-right: 34px !important;
}
.athenian-addons .athenian-addons__choice--multi-upload > label.athenian-addons__choice-main::after{
  content:"";
  position:absolute;
  right: 12px;
  top: 50%;
  width: 10px;
  height: 10px;
  transform: translateY(-50%) rotate(45deg);
  border-right: 2px solid color-mix(in srgb, var(--apadd-muted) 85%, transparent);
  border-bottom: 2px solid color-mix(in srgb, var(--apadd-muted) 85%, transparent);
  opacity:.9;
  transition: transform var(--apadd-med) var(--apadd-ease), opacity var(--apadd-fast) var(--apadd-ease);
}
.athenian-addons .athenian-addons__choice--multi-upload.is-open > label.athenian-addons__choice-main::after{
  transform: translateY(-50%) rotate(225deg);
  opacity:1;
}

/* Open state emphasis (token-first) */
.athenian-addons .athenian-addons__choice--multi-upload.is-open{
  border-color: color-mix(in srgb, var(--apadd-accent) 48%, var(--apadd-chip-border));
  box-shadow:
    0 0 0 3px var(--apadd-accent-2),
    var(--apadd-shadow-soft);
  background: color-mix(in srgb, var(--apadd-chip-bg-hover) 70%, var(--apadd-accent-2));
  transform: translateY(-1px);
}

/* Single-option group hint (subtle) */
.athenian-addons .athenian-addons__choices--multi-upload.apadd-mu-single .athenian-addons__choice--multi-upload{
  border-color: color-mix(in srgb, var(--apadd-accent) 30%, var(--apadd-chip-border));
}
/* FORCE a 4-up equal-width button row using FLEX (multi-upload only) */
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui__top{
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  align-items: center !important;
}

/* Buttons share the row equally */
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui__top > .apadd-file-ui__btn,
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui__top > .apadd-file-ui__clear{
  flex: 1 1 0 !important;     /* equal widths */
  width: auto !important;     /* prevent "100%" stacking */
  min-width: 0 !important;    /* allow shrinking */
  justify-content: center !important;
  text-align: center !important;
  white-space: nowrap !important;
}

/* Filename is always its own full-width row */
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui__top > .apadd-file-ui__name{
  flex: 0 0 100% !important;
  order: 99 !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 2px !important;
  font-size: 8.5px !important;
  opacity: .9 !important;
}
/* ==========================================================
   MU File UI â€” 4 buttons ALWAYS in one row (no wrap)
   - Buttons fill width evenly
   - Text truncates instead of wrapping
   - Filename stays on its own line below
   ========================================================== */

.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui__top{
  display: flex !important;
  flex-wrap: nowrap !important;     /* <-- critical: prevents stacking */
  gap: 6px !important;
  align-items: center !important;
}

/* Make the 4 controls share the row evenly */
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui__top > .apadd-file-ui__btn,
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui__top > .apadd-file-ui__clear{
  flex: 1 1 0 !important;
  min-width: 0 !important;          /* <-- critical: allows shrink + ellipsis */
  width: auto !important;
  justify-content: center !important;
  text-align: center !important;

  /* shrink a bit so 4 fit */
  padding: 5px 6px !important;
  font-size: 10px !important;
}

/* Truncate long labels (Media Library) instead of wrapping */
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui__top
  > :is(.apadd-file-ui__btn, .apadd-file-ui__clear){
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Put the filename BELOW the button row (not part of the flex row) */
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui__name{
  display: block !important;
  margin-top: 6px !important;
  font-size: 8.5px !important;
  opacity: .9 !important;
}
/* =============================================================================
 * APADD â€” Multi-Upload File UI Button Row (Single-Row Fill) â€” Console-Tested Fix
 * -----------------------------------------------------------------------------
 * Goal:
 * - Keep your existing markup/buttons (Choose / Media Library / AI Generate / Clear)
 * - Force ONE single filled row (no wrap) for the 4 controls
 * - Keep filename visible below the row even though it lives inside .apadd-file-ui__top
 *
 * Why this exists:
 * - Your computed styles showed .apadd-file-ui__top ended up with flex-wrap: wrap
 *   despite earlier attempts. This override pins nowrap at high specificity.
 *
 * Usage:
 * - Append this block AFTER your main "Compact Pro Dark UI" stylesheet
 *   (or load as a later stylesheet).
 * ============================================================================= */

/* ---------------------------------------------------------------------------
 * 1) Hard-pin the top row to ONE line (no wrapping)
 * ------------------------------------------------------------------------- */
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui .apadd-file-ui__top{
  display: flex !important;
  flex-wrap: nowrap !important;  /* critical */
  gap: 6px !important;
  align-items: center !important;

  /* Make room for the filename we pin below */
  position: relative !important;
  padding-bottom: 18px !important;
}

/* ---------------------------------------------------------------------------
 * 2) Buttons fill the row evenly (4-up) and truncate labels if needed
 * ------------------------------------------------------------------------- */
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui .apadd-file-ui__top
> :is(.apadd-file-ui__btn, .apadd-file-ui__clear){
  flex: 1 1 0 !important;       /* equal widths */
  width: auto !important;
  min-width: 0 !important;      /* allow shrink + ellipsis */

  justify-content: center !important;
  text-align: center !important;

  /* slightly tighter so 4 fit */
  padding: 5px 6px !important;
  font-size: 10px !important;

  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Optional: if you want Clear to be slightly narrower, uncomment:
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui .apadd-file-ui__top
> .apadd-file-ui__clear{
  flex: 0 0 auto !important;
  padding-inline: 10px !important;
}
*/

/* ---------------------------------------------------------------------------
 * 3) Filename: pin to a dedicated "row" under the buttons (without markup changes)
 * ------------------------------------------------------------------------- */
.athenian-addons .athenian-addons__choices--multi-upload .apadd-file-ui .apadd-file-ui__top
> .apadd-file-ui__name{
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;

  margin: 0 !important;
  padding: 0 2px !important;

  font-size: 8.5px !important;
  color: var(--apadd-muted) !important;
  opacity: .9 !important;

  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
/* Connected segmented toggle for empty swatch fields */
.athenian-addons .athenian-addons__field--swatch:has(.athenian-addons__swatch:not([style*="background"]))
  .athenian-addons__choices--swatch{
  grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  gap: 0 !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  border: 1px solid color-mix(in oklch, var(--apadd-border) 75%, transparent) !important;
  background: color-mix(in oklch, var(--apadd-surface-2) 60%, transparent) !important;
}

.athenian-addons .athenian-addons__field--swatch:has(.athenian-addons__swatch:not([style*="background"]))
  .athenian-addons__swatch{ display:none !important; }

.athenian-addons .athenian-addons__field--swatch:has(.athenian-addons__swatch:not([style*="background"]))
  .athenian-addons__choice--swatch{
  border-radius: 0 !important;
}

.athenian-addons .athenian-addons__field--swatch:has(.athenian-addons__swatch:not([style*="background"]))
  .athenian-addons__choice--swatch > .athenian-addons__choice-inner{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap: 8px !important;
  padding: 10px 10px !important;
  border: 0 !important;
  background: transparent !important;
}

.athenian-addons .athenian-addons__field--swatch:has(.athenian-addons__swatch:not([style*="background"]))
  .athenian-addons__choice--swatch + .athenian-addons__choice--swatch{
  border-left: 1px solid color-mix(in oklch, var(--apadd-border) 75%, transparent) !important;
}

.athenian-addons .athenian-addons__field--swatch:has(.athenian-addons__swatch:not([style*="background"]))
  .athenian-addons__choice--swatch > input:checked + .athenian-addons__choice-inner{
  background: color-mix(in oklch, var(--apadd-surface-2) 70%, var(--apadd-accent-2)) !important;
  box-shadow: inset 0 0 0 1px color-mix(in oklch, var(--apadd-accent) 50%, transparent) !important;
}
