/* ========================================================================== */
/* 1) Theme Tokens & Base                                                     */
/* ========================================================================== */
.iuv-gallery {
  --iuv-accent: #fb0505;
  --iuv-accent-700: #d90404;
  --iuv-accent-50: rgba(251, 5, 5, 0.06);
  --iuv-text: #111;
  --iuv-subtle: #6b7280;
  --iuv-border: #e6e6e6;
  --iuv-radius: 10px;
  --iuv-shadow: 0 6px 18px rgba(0,0,0,.06);

  display: grid;
  grid-template-columns: repeat(var(--iuv-cols, 3), 1fr);
  gap: 20px;
  align-items: stretch;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.iuv-width { width: fit-content; display: flex; flex-direction: column; }

.page-title__utvgallery {
  font-family: "Bruno Ace", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

/* ========================================================================== */
/* 2) Page Layout (sidebar + grid)                                            */
/* ========================================================================== */
.iuv-gallery-layout{
  display:grid;
  grid-template-columns: 260px 1fr; /* keep your existing column width */
  gap: 20px;
  align-items:start;
}

.iuv-gallery-wrapper { display:flex; flex-direction:row; width:100%; gap:1rem; }

/* ========================================================================== */
/* 3) Filter Card                                                             */
/* ========================================================================== */
.iuv-filter-card{
  border:1px solid var(--iuv-border);
  border-radius: 10px;
  background:#fff;
  box-shadow: var(--iuv-shadow);
  padding: 12px 12px 16px;
  /*max-width: 420px; fits your sidebar but roomy enough for labels */
  width: 175px;
}

/* Ribbon header */
.iuv-ribbon{
  display:flex; align-items:center; justify-content:space-between;
  margin:-12px -12px 8px; padding:10px 12px 10px 0; position:relative;
}
.iuv-ribbon__label{
  background: var(--iuv-accent); color:#fff; font-weight:800; letter-spacing:.2px;
  padding:8px 14px 8px 12px;
  clip-path: polygon(0 0, 92% 0, 100% 50%, 92% 100%, 0 100%);
  display:inline-block;
}
.iuv-ribbon__link{
  display:inline-flex; align-items:center; gap:8px;
  color:#64748b; text-decoration:none;
  padding-left: 1rem;
  padding-right: 1rem;
}
.iuv-ribbon__link:hover{ color: var(--iuv-accent); }
.iuv-ribbon__link svg{ width:20px; height:20px; display:block; }

/* Title */
.iuv-filter__title{
  margin:6px 0 12px; text-align:center; font-weight:800; font-size:1.05rem;
}

/* Controls container */
.iuv-filter-controls{ display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:12px; max-width:420px; }
.iuv-filter-controls--stacked{ grid-template-columns: 1fr; gap:10px; }

/* Field + label */
.iuv-field{ display:flex; flex-direction:column; gap:6px; }
.iuv-label{ font-size:.9rem; font-weight:700; color:#374151; }

/* Select */
.iuv-filter-controls select{
  width:100%; padding:12px 38px 12px 12px;
  border:1px solid var(--iuv-border); border-radius:8px; background:#fff;
  font:inherit; line-height:1.2;
  box-shadow: inset 0 1px 0 rgba(0,0,0,.02);
  transition:border-color .15s, box-shadow .15s, transform .02s;
  appearance:none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7l5 6 5-6' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 12px center; background-size:14px;
}
.iuv-filter-controls select:focus{
  outline:0;
  border-color: color-mix(in lab, var(--iuv-accent) 55%, #bbb);
  box-shadow: 0 0 0 2px color-mix(in lab, var(--iuv-accent) 25%, #fff);
}
.iuv-filter-controls select option[value=""]{ color:#6b7280; }

/* Clear link */
.iuv-clear-link { font-size:.9rem; color:#475569; text-decoration:underline; text-underline-offset:2px; width:max-content; }

/* ========================================================================== */
/* 4) Cards (gallery items)                                                   */
/* ========================================================================== */
.iuv-item{
  position:relative; border:1px solid var(--iuv-border); border-radius:var(--iuv-radius);
  padding:14px; text-align:center; display:flex; flex-direction:column; justify-content:space-between;
  min-height:450px; background:#fff; box-shadow:var(--iuv-shadow);
  transition: transform .15s, box-shadow .15s;
  width:100%; max-width:100%; box-sizing:border-box; overflow:hidden;
}
.iuv-item:hover{ transform: translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.1); }

/* Placeholder card */
.iuv-item.iuv-placeholder{
  border:2px dashed color-mix(in lab, var(--iuv-accent) 55%, #ccc);
  background:linear-gradient(180deg, #fff, var(--iuv-accent-50) 90%);
  align-items:center; overflow:hidden;
}

/* Media */
.iuv-item img, .iuv-placeholder-media{
  width:100%; max-width:100%; height:300px; object-fit:cover; aspect-ratio:1/1;
  display:block; margin:0 auto 8px; border-radius:8px;
}
.iuv-placeholder-media{
  background:
    radial-gradient(circle at 50% 45%, rgba(0,0,0,.08) 0 120px, transparent 121px),
    linear-gradient(135deg, rgba(0,0,0,.05) 25%, transparent 25%) 0 0/20px 20px,
    linear-gradient(225deg, rgba(0,0,0,.05) 25%, transparent 25%) 0 0/20px 20px;
  position:relative;
}
.iuv-placeholder-media::after{
  content:"+"; position:absolute; inset:0 0 10% 0; display:grid; place-items:center;
  font-size:64px; font-weight:800; color: color-mix(in lab, var(--iuv-accent) 35%, #000);
}

/* Text & links */
.iuv-item h3{ margin:6px 0 2px; font-size:1.05rem; font-weight:700; color:var(--iuv-text); }
.iuv-content{ margin-top:1rem; }
.iuv-item .iuv-content{ flex-grow:1; margin:6px 0 10px; }
.iuv-votes{ font-weight:700; color:var(--iuv-subtle); margin:8px 0 10px; }
.iuv-read-more{ color:var(--iuv-accent); text-decoration:none; font-weight:700; display:inline-block; margin-top:6px; }
.iuv-read-more:hover{ text-decoration:underline; cursor:pointer; }

/* Buttons */
.iuv-vote-btn, .iuv-cta-btn, .iuv-upload-form button {
  appearance:none; background:var(--iuv-accent); color:#fff; padding:10px 14px;
  border:0; border-radius:8px; cursor:pointer; font-weight:800; letter-spacing:.2px;
  transition: filter .15s, transform .02s;
}
.iuv-vote-btn:hover, .iuv-cta-btn:hover, .iuv-upload-form button:hover{ filter:brightness(.96); }
.iuv-vote-btn:active, .iuv-cta-btn:active, .iuv-upload-form button:active{ transform: translateY(1px); }
.iuv-upload-form button.iuv-loading{ background:var(--iuv-accent-700); cursor:not-allowed; }
.iuv-upload-btn{ background-color:#fb0505 !important; width:fit-content; align-self:center; }
a.added_to_cart.wc-forward{ padding:.5rem; white-space:pre; }

.iuv-cta-btn:hover, .iuv-cta-btn:active, .iuv-cta-btn:focus {
  color: white;
}

/* Trophy */
.iuv-item.iuv-first-place::before{
  content:"\1F3C6"; position:absolute; top:10px; font-size:2em; color:#ffd700 !important;
  text-shadow:0 0 0 rgba(0,0,0,0), 0 0 12px rgba(251,5,5,.35); z-index:20; display:block !important;
}

/* Auth bits */
.iuv-login-prompt{ margin:10px 0; font-size:.9em; }
.iuv-login-prompt a{ color:var(--iuv-accent); text-decoration:none; font-weight:700; }
.iuv-login-prompt a:hover{ text-decoration:underline; }
.iuv-auth-cta{ margin:8px 0 0; font-size:.95rem; color:var(--iuv-text); }
.iuv-auth-link{ color:var(--iuv-accent); font-weight:700; text-decoration:none; }
.iuv-auth-link:hover{ text-decoration:underline; }

/* Search chips, picker */
.iuv-product-picker{ margin:10px 0; }
.iuv-results{ list-style:none; margin:6px 0; padding:0; border:1px solid #eee; max-height:220px; overflow:auto; }
.iuv-results li{ padding:6px 10px; cursor:pointer; }
.iuv-results li:hover{ background:#f6f6f6; }
.iuv-chips{ display:flex; gap:6px; flex-wrap:wrap; margin-top:6px; }
.iuv-chips .chip{ background:#f1f5f9; border:1px solid #000; border-radius:14px; padding:2px 8px; font-size:12px; }
.iuv-chips .chip button{ margin-left:6px; border:0; background:transparent; cursor:pointer; }

/* ========================================================================== */
/* 5) Hero                                                                    */
/* ========================================================================== */
.iuv-hero{ position:relative; width:100%; height:500px; overflow:hidden; border-radius:12px; box-shadow:0 8px 24px rgba(0,0,0,.08); display:flex; }
.iuv-hero img{ width:100%; height:100%; object-fit:cover; object-position:center; border-radius:12px; display:block; aspect-ratio:16/9; }
.iuv-hero .iuv-nav{ position:absolute; top:50%; transform:translateY(-50%); width:40px; height:40px; border-radius:999px; border:0; background:rgba(0,0,0,.45); color:#fff; font-size:24px; display:flex; align-items:center; justify-content:center; cursor:pointer; }
.iuv-hero .iuv-nav.prev{ left:8px; } .iuv-hero .iuv-nav.next{ right:8px; }
.iuv-hero .iuv-nav:hover{ filter:brightness(1.1); }
.iuv-thumbs .iuv-thumb{ position:relative; display:inline-block; }
.iuv-thumbs .iuv-thumb.is-active img{ outline:2px solid #fb0505; outline-offset:2px; }

/* ========================================================================== */
/* 6) Responsive                                                              */
/* ========================================================================== */
@media (max-width: 900px){
  .iuv-gallery-layout{ grid-template-columns: 1fr; }
  .iuv-gallery-filters{ position:static; }
  .iuv-filter-controls{ grid-template-columns: 1fr; max-width:100%; } /* keep mobile stacked */
  .iuv-filter-card { max-width: none; width: 100%; }
}

@media (max-width: 768px){
  .iuv-gallery{ grid-template-columns: repeat(2, 1fr); }
  .iuv-gallery-wrapper{ flex-direction:column; }
  .iuv-width{ width:100%; }
  .iuv-item, .iuv-item.iuv-placeholder{ min-height:400px; }
  .iuv-item img, .iuv-placeholder-media{ height:250px; }
  .iuv-hero img{ height:100% !important; }
}

@media (max-width: 480px){
  .iuv-gallery{ grid-template-columns: 1fr; }
  .iuv-item, .iuv-item.iuv-placeholder{ min-height:350px; }
  .iuv-item img, .iuv-placeholder-media{ height:200px; }
}

/* ========================================================================== */
/* 7) Utilities & FX                                                          */
/* ========================================================================== */
.iuv-loading-inline{ display:inline-block; width:16px; height:16px; border:2px solid #ccc; border-top-color:#555; border-radius:50%; animation:iuvspin .7s linear infinite; margin-left:8px; vertical-align:middle; }
.upload-success-message, .upload-error-message{ text-align:center; }

/* Animations */
@keyframes iuvspin { to { transform: rotate(360deg); } }
@keyframes fadeOut { from{opacity:1;} to{opacity:0; display:none;} }
@keyframes dustCloud { from{opacity:.5; transform:scale(.5);} to{opacity:0; transform:scale(1.5);} }

/* ========================================================================== */
/* 8) Upload Form                                                             */
/* ========================================================================== */
#iuv-upload-form.iuv-upload-form{
  --field-radius: 10px;
  --field-border: var(--iuv-border, #e6e6e6);
  --field-bg: #fff;
  --field-pad: 12px;

  max-width: 980px;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

/* Top note */
#iuv-upload-form > label:first-of-type{
  font-size: .95rem;
  color: var(--iuv-subtle, #6b7280);
  font-weight: 600;
  margin-bottom: 4px;
}

/* Text inputs & textarea */
#iuv-upload-form input[type="text"],
#iuv-upload-form textarea{
  width: 100%;
  background: var(--field-bg);
  border: 1px solid var(--field-border);
  border-radius: var(--field-radius);
  padding: var(--field-pad);
  font: inherit;
  line-height: 1.35;
  box-shadow: inset 0 1px 0 rgba(0,0,0,.02);
  transition: border-color .15s, box-shadow .15s;
}
#iuv-upload-form textarea{
  min-height: 160px;
  resize: vertical;
}

/* File input – keep native but align nicely */
#iuv-upload-form input[type="file"]{
  width: 100%;
  padding: 8px;
  background: #fafafa;
  border: 1px solid var(--field-border);
  border-radius: var(--field-radius);
}

/* Field labels above controls */
#iuv-upload-form > label{
  font-weight: 700;
  color: #374151;
  margin-top: 8px;
}

/* YMM row */
#iuv-upload-form .iuv-ymm{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
#iuv-upload-form .iuv-ymm select{
  width: 100%;
  padding: 12px 38px 12px 12px;
  border: 1px solid var(--field-border);
  border-radius: 8px;
  background: #fff;
  font: inherit;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7l5 6 5-6' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 14px;
  transition: border-color .15s, box-shadow .15s;
}
#iuv-upload-form .iuv-ymm select:focus{
  outline: 0;
  border-color: color-mix(in lab, var(--iuv-accent, #fb0505) 55%, #bbb);
  box-shadow: 0 0 0 2px color-mix(in lab, var(--iuv-accent, #fb0505) 25%, #fff);
}
#iuv-upload-form .iuv-ymm select:disabled{
  background-color: #f5f5f5;
  color: #9ca3af;
  cursor: not-allowed;
  border-color: #e5e7eb;
}

/* Product picker block */
#iuv-product-picker.iuv-product-picker{
  margin-top: 4px;
  padding: 12px;
  border: 1px solid var(--field-border);
  border-radius: var(--field-radius);
  background: #fff;
}
#iuv-load-compatible{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 8px;
  font-weight: 800;
  border: 1px solid transparent;
  background: var(--iuv-accent, #fb0505);
  color: #ffffff;
}
#iuv-load-compatible:hover:enabled{ filter: brightness(.96); }
#iuv-load-compatible:disabled{
  background: #f1f5f9;
  color: #0f172a;
  border-color: #cbd5e1;
  opacity: 1;              /* keep readable */
  cursor: not-allowed;
}

/* Compatible list (override inline style safely) */
#iuv-compatible-list{
  display: none;           /* JS will set display:block when data loads */
  max-height: 300px;
  overflow-y: auto;
  border: 1px solid #ddd;
  padding: 10px;
  margin: 10px 0;
  border-radius: 8px;
  background: #ffffff;     /* ensure contrast */
  color: #0f172a;
}
#iuv-compatible-list li{
  padding: 8px 10px;
  border-radius: 6px;
  cursor: pointer;
  color: #0f172a;
  background: transparent;
  display: inline-flex;
  align-items: center;
}
#iuv-compatible-list li:hover{
  background: #f8fafc;
}

/* Chips */
#iuv-product-chips.iuv-chips{
  margin-top: 8px;
}
#iuv-product-chips .chip{
  background: #f1f5f9;
  border: 1px solid #cbd5e1;
  color: #0f172a;
}

/* Submit button (already themed globally, just add spacing) */
#iuv-upload-form .iuv-upload-btn{
  justify-self: start;
  margin-top: 4px;
}

/* Form focus states to match rest of theme */
#iuv-upload-form input[type="text"]:focus,
#iuv-upload-form textarea:focus,
#iuv-upload-form input[type="file"]:focus{
  outline: 0;
  border-color: color-mix(in lab, var(--iuv-accent, #fb0505) 55%, #bbb);
  box-shadow: 0 0 0 2px color-mix(in lab, var(--iuv-accent, #fb0505) 25%, #fff);
}

/* Responsive – keep your global grid unchanged */
@media (max-width: 700px){
  #iuv-upload-form .iuv-ymm{
    grid-template-columns: 1fr;     /* stack Y/M/M on small screens */
  }
}

.iuv-dust-message {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(0, 0, 0, 0.75);
  color: #fff;
  padding: 10px 20px;
  border-radius: 6px;
  font-family: "Impact", system-ui, sans-serif;
  font-size: 1.25em;
  z-index: 10;
  animation: fadeOut 3s ease forwards;
}
.iuv-dust-cloud {
  position: absolute;
  inset: 0;
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><path fill="rgba(139,69,19,.45)" d="M0,50 C20,30 40,70 60,50 C80,30 100,70 100,50 C100,80 70,90 50,90 C30,90 0,80 0,50 Z"/></svg>')
    center/contain no-repeat;
  animation: dustCloud 2s ease forwards;
}