/* ═══════════════════════════════════════════════
   ULTRAJEWELS EVENTOS — front.css
   Variables overridden via settings page inline style
═══════════════════════════════════════════════ */

.uj-eventos-widget {
    --uj-orange:  #f09030;
    --uj-text:    #5E4F40;
    --uj-muted:   #9a9088;
    --uj-border:  #ece6da;
    --uj-bg:      #FAF6F1;
    --uj-card-bg: #ffffff;
    --uj-font-heading: 'Futura', 'Futura PT', 'Century Gothic', sans-serif;
    --uj-font-body:    'Almarose', Georgia, serif;

    font-family: var(--uj-font-body);
    -webkit-font-smoothing: antialiased;
    background: var(--uj-bg) !important;
    padding: 2.5rem 2.5rem 3rem !important;
    border-radius: 4px;
}

/* Force background — override ALL Elementor wrappers */
.elementor-widget-shortcode .uj-eventos-widget,
.elementor .uj-eventos-widget,
[class*="elementor"] .uj-eventos-widget {
    background: var(--uj-bg) !important;
}

/* Override the elementor-shortcode wrapper itself that sits ABOVE the widget */
.elementor-shortcode:has(.uj-eventos-widget) {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
}
.elementor-widget-container:has(.uj-eventos-widget) {
    background: transparent !important;
    padding: 0 !important;
}
/* Fallback for browsers without :has() — force widget bg to show */
.uj-eventos-widget {
    position: relative;
    z-index: 1;
}
.uj-eventos-widget::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--uj-bg);
    z-index: -1;
    border-radius: 4px;
}

/* ── Loading ── */
.uj-loading { display:flex; gap:6px; padding:2rem; }
.uj-loading span {
    width:6px; height:6px; border-radius:50%;
    background:var(--uj-border);
    animation:ujPulse 1.2s ease-in-out infinite;
}
.uj-loading span:nth-child(2){animation-delay:.2s}
.uj-loading span:nth-child(3){animation-delay:.4s}
@keyframes ujPulse{0%,80%,100%{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}

/* ── Header ── */
.uj-header {
    display:flex; align-items:flex-end; justify-content:space-between;
    margin-bottom:2.5rem; padding-bottom:1.75rem;
    border-bottom:.5px solid var(--uj-border);
}
.uj-eyebrow {
    font-family:var(--uj-font-heading); font-size:9px; font-weight:400;
    letter-spacing:.35em; text-transform:uppercase;
    color:var(--uj-orange); margin-bottom:.45rem;
}
.uj-section-title {
    font-family:var(--uj-font-heading); font-size:23px; font-weight:300;
    letter-spacing:.2em; text-transform:uppercase; color:var(--uj-text);
}
.uj-month-nav { display:flex; align-items:center; gap:1.1rem; }
.uj-month-label {
    font-family:var(--uj-font-heading); font-size:10px; font-weight:600;
    letter-spacing:.22em; text-transform:uppercase;
    color:var(--uj-text); min-width:115px; text-align:center;
}
.uj-nav-btn {
    background:#ffffff !important; border:.5px solid #ece6da !important;
    width:32px; height:32px; border-radius:50%;
    cursor:pointer; font-size:15px; color:#9a9088 !important;
    display:flex !important; align-items:center !important; justify-content:center !important;
    transition:all .2s; line-height:1;
}
.uj-nav-btn:hover{border-color:#f09030 !important;color:#f09030 !important;}

/* ── Track (shared by full + editorial) ── */
.uj-track-wrap{overflow-x:auto;scrollbar-width:none;}
.uj-track-wrap::-webkit-scrollbar{display:none;}
.uj-track{display:flex;gap:16px;min-width:max-content;align-items:stretch;padding-bottom:.5rem;}
/* Card max/min width — won't stretch beyond 4 visible cards */
.uj-card{min-width:280px;max-width:380px;}

/* ══════════════════════════════════════════
   VIEW: FULL  (default — cards with gradient top)
══════════════════════════════════════════ */
.uj-card {
    width:316px; flex-shrink:0;
    background:var(--uj-card-bg);
    border-radius:10px;
    border:.5px solid var(--uj-border);
    overflow:hidden;
    display:flex; flex-direction:column;
    transition:transform .32s cubic-bezier(.16,1,.3,1),
               box-shadow .32s cubic-bezier(.16,1,.3,1),
               border-color .28s;
    animation:ujFadeUp .45s cubic-bezier(.16,1,.3,1) both;
}
.uj-card:hover{
    transform:translateY(-7px);
    box-shadow:0 22px 60px rgba(0,0,0,.05),0 5px 18px rgba(0,0,0,.025);
    border-color:rgba(240,144,48,.4);
}
@keyframes ujFadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

.uj-card-grad{
    border-radius:10px 10px 0 0;overflow:hidden;height:72px;flex-shrink:0;position:relative;overflow:hidden;}
.uj-card-grad::after{
    content:'';position:absolute;bottom:0;left:0;right:0;height:32px;
    background:linear-gradient(to bottom,rgba(255,255,255,0),var(--uj-card-bg));
    pointer-events:none;
}
.uj-card-brand-zone{
    position:absolute;inset:0;z-index:2;
    display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
    padding:0 1.4rem;gap:4px;
}
.uj-card-brand{
    font-family:var(--uj-font-heading);font-size:17px;font-weight:600;
    letter-spacing:.22em;text-transform:uppercase;color:var(--uj-text);line-height:1;
}
.uj-card-category{
    font-family:var(--uj-font-heading);font-size:7.5px;font-weight:400;
    letter-spacing:.22em;text-transform:uppercase;color:var(--uj-muted);
}
.uj-card-body{flex:1;display:flex;flex-direction:column;padding:.1rem 1.4rem 1.5rem;overflow:hidden;}

.uj-date-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:.75rem;flex-shrink:0;}
.uj-day{font-family:var(--uj-font-heading);font-size:52px;font-weight:300;color:var(--uj-text);line-height:1;letter-spacing:-.02em;}
.uj-date-sub{display:flex;flex-direction:column;gap:1px;padding-top:4px;}
.uj-mon{font-family:var(--uj-font-heading);font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--uj-orange);}
.uj-yr{font-family:var(--uj-font-heading);font-size:9px;font-weight:300;letter-spacing:.12em;color:var(--uj-muted);}
.uj-date-range{font-family:var(--uj-font-body);font-size:12px;font-style:italic;color:var(--uj-muted);margin-top:3px;line-height:1.4;}
.uj-card-title{
    font-family:var(--uj-font-heading);font-size:14px;font-weight:600;
    letter-spacing:.1em;text-transform:uppercase;color:var(--uj-text);line-height:1.3;
    margin-bottom:.45rem;flex-shrink:0;
}
.uj-card-desc{
    font-family:var(--uj-font-body);font-size:14.5px;font-style:italic;
    color:var(--uj-muted);line-height:1.65;margin-bottom:.9rem;flex-shrink:0;
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.uj-divider{height:.5px;background:var(--uj-border);margin-bottom:.9rem;flex-shrink:0;}

/* Locations */
.uj-loc-label{
    font-family:var(--uj-font-heading);font-size:7.5px;font-weight:600;
    letter-spacing:.3em;text-transform:uppercase;color:var(--uj-muted);margin-bottom:.5rem;flex-shrink:0;
}
.uj-loc-scroll-wrap{position:relative;flex-shrink:0;margin-bottom:1rem;}
.uj-loc-list{max-height:108px;overflow-y:auto;scrollbar-width:none;display:flex;flex-direction:column;}
.uj-loc-list::-webkit-scrollbar{display:none;}
.uj-loc-fade{
    position:absolute;bottom:0;left:0;right:0;height:52px;
    background:linear-gradient(to bottom,rgba(255,255,255,0) 0%,rgba(255,255,255,.75) 40%,var(--uj-card-bg) 100%);
    pointer-events:none;transition:opacity .25s;
    display:flex;align-items:flex-end;justify-content:center;padding-bottom:2px;
}
.uj-loc-fade.has-more{pointer-events:all;cursor:pointer;}
.uj-loc-fade.hidden{opacity:0;pointer-events:none;}
.uj-loc-fade-hint{
    font-family:var(--uj-font-heading);font-size:9px;font-weight:600;
    letter-spacing:.18em;text-transform:uppercase;color:var(--uj-orange);
    display:flex;align-items:center;gap:4px;
    animation:ujBounce 1.4s ease-in-out infinite;
}
@keyframes ujBounce{0%,100%{transform:translateY(0);opacity:.7}50%{transform:translateY(3px);opacity:1}}
.uj-loc-link{
    display:flex;align-items:flex-start;justify-content:space-between;gap:8px;
    padding:9px 0;border-bottom:.5px solid rgba(236,230,218,.45);
    text-decoration:none;flex-shrink:0;
}
.uj-loc-link:last-child{border-bottom:none;}
.uj-loc-link:hover .uj-loc-name{color:var(--uj-orange);}
.uj-loc-link:hover .uj-loc-arrow{opacity:1;transform:translateX(0);color:var(--uj-orange);}
.uj-loc-left{display:flex;flex-direction:column;gap:2px;}
.uj-loc-name{font-family:var(--uj-font-heading);font-size:9.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--uj-text);transition:color .18s;}
.uj-loc-dates{font-family:var(--uj-font-body);font-size:12px;font-style:italic;color:var(--uj-muted);}
.uj-loc-arrow{font-size:14px;color:var(--uj-muted);flex-shrink:0;margin-top:1px;opacity:0;transform:translateX(-4px);transition:opacity .18s,transform .18s,color .18s;}

/* Action buttons */
.uj-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto;flex-shrink:0;padding-top:4px;position:relative;}
.uj-eventos-widget .uj-actions .uj-btn,
.uj-btn{
    font-family:var(--uj-font-heading) !important;font-size:7.5px !important;font-weight:600 !important;
    letter-spacing:.14em !important;text-transform:uppercase !important;
    border:.5px solid #ece6da !important;background:#ffffff !important;
    padding:5px 10px !important;cursor:pointer !important;color:#9a9088 !important;
    border-radius:4px !important;transition:all .2s;
    text-decoration:none !important;display:inline-flex !important;align-items:center !important;gap:4px !important;
    line-height:1.2 !important;min-height:unset !important;height:auto !important;
    box-shadow:none !important;margin:0 !important;width:auto !important;
}
.uj-eventos-widget .uj-actions .uj-btn:hover,
.uj-btn:hover{border-color:#f09030 !important;color:#f09030 !important;background:#ffffff !important;}
.uj-eventos-widget .uj-actions .uj-btn.uj-btn-primary,
.uj-btn.uj-btn-primary{background:#f09030 !important;border-color:#f09030 !important;color:#fff !important;}
.uj-eventos-widget .uj-actions .uj-btn.uj-btn-primary:hover{background:#d07828 !important;border-color:#d07828 !important;}


/* Share popup */
.uj-share-popup{
    position:absolute;bottom:calc(100% + 6px);left:0;
    background:#ffffff !important;border:.5px solid #ece6da !important;
    border-radius:8px;padding:6px 0;
    box-shadow:0 8px 32px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.08) !important;
    min-width:180px;z-index:9999 !important;
    animation:ujFadeUp .18s cubic-bezier(.16,1,.3,1) both;
}
.uj-share-popup.hidden{display:none;}
.uj-share-item{
    display:flex;align-items:center;gap:10px;
    padding:9px 14px;cursor:pointer;
    font-family:var(--uj-font-heading);font-size:9px;font-weight:600;
    letter-spacing:.12em;text-transform:uppercase;color:#5E4F40 !important;
    transition:background .15s;border:none !important;background:#ffffff !important;width:100%;text-align:left;
}
.uj-share-item:hover{background:#fdf9f6 !important;color:#f09030 !important;}
.uj-share-item svg{flex-shrink:0;opacity:.6;}
.uj-share-item:hover svg{opacity:1;}
.uj-share-copied{color:#f09030 !important;}

/* ══════════════════════════════════════════
   VIEW: MINIMAL  (clean list, no gradient cards)
══════════════════════════════════════════ */
.uj-minimal-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
    gap:12px;
    /* Hard cap at 4 columns — cards won't stretch thinner than 260px */
    max-width:100%;
}
/* Prevent more than 4 columns on wide screens */
@media(min-width:1200px){
    .uj-minimal-grid{grid-template-columns:repeat(4,minmax(0,320px));}
}
@media(min-width:900px) and (max-width:1199px){
    .uj-minimal-grid{grid-template-columns:repeat(3,1fr);}
}
.uj-minimal-card{
    background:var(--uj-card-bg);
    padding:1rem 1.25rem .9rem;
    display:flex;flex-direction:column;gap:.4rem;
    border:.5px solid var(--uj-border);border-radius:10px;
    position:relative;overflow:hidden;
    transition:box-shadow .22s,border-color .22s;
    cursor:default;
}
.uj-minimal-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(to right,var(--card-grad-start,#4a8fa8),var(--card-grad-end,#d4b84a));
}
.uj-minimal-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.06);border-color:rgba(240,144,48,.25);}
.uj-minimal-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.15rem;}
.uj-minimal-cat{
    font-family:var(--uj-font-heading);font-size:7px;font-weight:600;
    letter-spacing:.3em;text-transform:uppercase;color:var(--uj-orange);
}
.uj-minimal-day{
    font-family:var(--uj-font-heading);font-size:28px;font-weight:300;
    color:var(--uj-text);line-height:1;
}
.uj-minimal-brand{
    font-family:var(--uj-font-heading);font-size:14px;font-weight:600;
    letter-spacing:.18em;text-transform:uppercase;color:var(--uj-text);
}
.uj-minimal-title{
    font-family:var(--uj-font-body);font-size:15px;font-style:italic;
    color:var(--uj-muted);line-height:1.4;
}
.uj-minimal-range{
    font-family:var(--uj-font-heading);font-size:8px;letter-spacing:.12em;
    text-transform:uppercase;color:var(--uj-muted);margin-bottom:.1rem;
}
.uj-min-top-zone{cursor:pointer;}
/* Minimal description — 2 lines truncated, expandable with arrow */
.uj-min-desc{
    font-family:var(--uj-font-body);font-size:13px;font-style:italic;
    color:var(--uj-muted);line-height:1.5;
    /* Hidden by default — revealed on expand */
    display:none;overflow:hidden;
    margin-bottom:.1rem;position:relative;
    transition:all .25s ease;
}
.uj-min-desc.is-expanded{display:block;overflow:visible;}
.uj-min-desc-toggle{
    background:none;border:none;padding:0;cursor:pointer;
    color:var(--uj-orange);font-size:8px;line-height:1.6;
    display:block;margin:.1rem 0 .3rem;
    font-family:var(--uj-font-heading);font-weight:600;letter-spacing:.12em;text-transform:uppercase;
    /* Always visible — no opacity tricks */
    opacity:1 !important;
    visibility:visible !important;
}
/* Minimal locs — no label, thin separator only */
.uj-minimal-card .uj-loc-label{display:none !important;}
.uj-minimal-card .uj-loc-scroll-wrap{border-top:.5px solid var(--uj-border);padding-top:.6rem;margin-top:.1rem;}
.uj-carousel-slide .uj-loc-label{display:none !important;}
.uj-carousel-slide .uj-loc-scroll-wrap{border-top:.5px solid var(--uj-border);padding-top:.5rem;margin-top:.1rem;}

/* ══════════════════════════════════════════
   VIEW: EDITORIAL  (magazine, large image-like layout)
══════════════════════════════════════════ */
.uj-editorial-list{display:flex;flex-direction:column;gap:0;}
.uj-editorial-row{
    display:grid;
    grid-template-columns:80px 1fr 1fr auto;
    align-items:center;gap:0;
    border-bottom:.5px solid var(--uj-border);
    padding:1.5rem 0;
    transition:background .18s;
}
.uj-editorial-row:first-child{border-top:.5px solid var(--uj-border);}
.uj-editorial-row:hover{background:rgba(255,255,255,.6);}
.uj-ed-date{
    display:flex;flex-direction:column;align-items:center;
    border-right:.5px solid var(--uj-border);padding-right:1.5rem;
}
.uj-ed-day-big{
    font-family:var(--uj-font-heading);font-size:40px;font-weight:300;
    color:var(--uj-text);line-height:1;
}
.uj-ed-mon{
    font-family:var(--uj-font-heading);font-size:8px;font-weight:600;
    letter-spacing:.2em;text-transform:uppercase;color:var(--uj-orange);
}
.uj-ed-brand-block{padding:0 2rem;}
.uj-ed-brand{
    font-family:var(--uj-font-heading);font-size:13px;font-weight:600;
    letter-spacing:.18em;text-transform:uppercase;color:var(--uj-text);
    margin-bottom:4px;
}
.uj-ed-cat{
    font-family:var(--uj-font-heading);font-size:7px;font-weight:400;
    letter-spacing:.22em;text-transform:uppercase;color:var(--uj-muted);
}
.uj-ed-title-block{border-left:.5px solid var(--uj-border);padding:0 2rem;}
.uj-ed-title{
    font-family:var(--uj-font-heading);font-size:12px;font-weight:600;
    letter-spacing:.08em;text-transform:uppercase;color:var(--uj-text);
    margin-bottom:4px;
}
.uj-ed-desc{
    font-family:var(--uj-font-body);font-size:13px;font-style:italic;
    color:var(--uj-muted);line-height:1.5;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.uj-ed-locs{
    padding-left:2rem;
    display:flex;flex-direction:column;gap:4px;
    min-width:160px;
}
.uj-ed-actions{margin-top:8px;}
.uj-ed-actions .uj-actions{flex-direction:column;align-items:flex-start;}
.uj-ed-loc{
    font-family:var(--uj-font-heading);font-size:8px;font-weight:600;
    letter-spacing:.1em;text-transform:uppercase;color:var(--uj-text);
}
.uj-ed-loc-dates{
    font-family:var(--uj-font-body);font-size:11px;font-style:italic;color:var(--uj-muted);
}

/* ══════════════════════════════════════════
   VIEW: COMPACT  (accordion)
══════════════════════════════════════════ */
.uj-compact-list{display:flex;flex-direction:column;gap:0;}
.uj-compact-row{
    display:flex;align-items:center;gap:0;
    border-bottom:.5px solid var(--uj-border);
    cursor:pointer;transition:background .18s;overflow:hidden;
}
.uj-compact-row:first-child{border-top:.5px solid var(--uj-border);}
.uj-compact-row:hover{background:rgba(255,255,255,.5);}
.uj-compact-row.is-open{background:rgba(255,255,255,.7);}
.uj-compact-swatch{width:3px;align-self:stretch;flex-shrink:0;}
.uj-compact-main{flex:1;display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;}
.uj-compact-date{font-family:var(--uj-font-heading);font-size:22px;font-weight:300;color:var(--uj-text);line-height:1;min-width:36px;text-align:right;flex-shrink:0;}
.uj-compact-meta{display:flex;flex-direction:column;gap:2px;}
.uj-compact-brand{font-family:var(--uj-font-heading);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--uj-text);}
.uj-compact-cat{font-family:var(--uj-font-heading);font-size:8px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--uj-muted);}
.uj-compact-title{font-family:var(--uj-font-body);font-size:15px;font-style:italic;color:var(--uj-muted);margin-left:auto;text-align:right;flex-shrink:0;max-width:160px;}
.uj-compact-chevron{font-size:12px;color:var(--uj-muted);flex-shrink:0;padding:0 1rem;transition:transform .25s;}
.uj-compact-row.is-open .uj-compact-chevron{transform:rotate(90deg);}
.uj-compact-detail{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.16,1,.3,1);background:rgba(255,255,255,.5);border-bottom:.5px solid var(--uj-border);}
.uj-compact-detail.is-open{max-height:600px;}
.uj-compact-detail-inner{padding:1.25rem 1.4rem 1.4rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem 2rem;}
.uj-compact-desc{font-family:var(--uj-font-body);font-size:14.5px;font-style:italic;color:var(--uj-muted);line-height:1.65;grid-column:1/-1;}

/* ── No events ── */
.uj-no-events{font-family:var(--uj-font-heading);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#ccc;padding:2rem 0;}


/* ══════════════════════════════════════════
   VIEW: TIMELINE  (vertical axis)
══════════════════════════════════════════ */
.uj-timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:72px;}
.uj-timeline::before{
    content:'';position:absolute;left:36px;top:12px;bottom:12px;
    width:.5px;background:var(--uj-border);
}
.uj-tl-row{
    display:grid;grid-template-columns:1fr;
    position:relative;padding:0 0 2.5rem 1.5rem;
}
.uj-tl-dot{
    position:absolute;left:-36px;top:6px;
    width:10px;height:10px;border-radius:50%;
    background:var(--uj-card-bg);border:2px solid var(--uj-border);
    transform:translateX(-50%);transition:border-color .2s,background .2s;
}
.uj-tl-row:hover .uj-tl-dot{border-color:var(--uj-orange);background:var(--uj-orange);}
.uj-tl-date-chip{
    display:inline-flex;align-items:center;gap:8px;margin-bottom:.75rem;
}
.uj-tl-day-num{
    font-family:var(--uj-font-heading);font-size:32px;font-weight:300;
    color:var(--uj-text);line-height:1;
}
.uj-tl-date-right{display:flex;flex-direction:column;gap:1px;padding-top:3px;}
.uj-tl-mon{font-family:var(--uj-font-heading);font-size:9px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--uj-orange);}
.uj-tl-yr{font-family:var(--uj-font-heading);font-size:8px;font-weight:300;letter-spacing:.12em;color:var(--uj-muted);}
.uj-tl-card{
    background:var(--uj-card-bg);border:.5px solid var(--uj-border);
    border-radius:10px;padding:1.25rem 1.4rem 1.25rem;
    transition:box-shadow .25s,border-color .25s;
}
.uj-tl-row:hover .uj-tl-card{
    box-shadow:0 8px 32px rgba(0,0,0,.06);
    border-color:rgba(240,144,48,.3);
}
.uj-tl-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.5rem;}
.uj-tl-brand{font-family:var(--uj-font-heading);font-size:13px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--uj-text);}
.uj-tl-cat{font-family:var(--uj-font-heading);font-size:7px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--uj-orange);margin-top:2px;}
.uj-tl-range{font-family:var(--uj-font-body);font-size:11px;font-style:italic;color:var(--uj-muted);}
.uj-tl-title{font-family:var(--uj-font-heading);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--uj-text);margin-bottom:.35rem;}
.uj-tl-desc{font-family:var(--uj-font-body);font-size:13.5px;font-style:italic;color:var(--uj-muted);line-height:1.6;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.uj-tl-locs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:.75rem;}
.uj-tl-loc-pill{
    display:inline-flex;flex-direction:column;gap:2px;
    background:#fdf9f6;border:.5px solid #ece6da;
    padding:5px 10px;border-radius:20px;
    text-decoration:none;transition:all .18s;
}
.uj-tl-loc-pill:hover{border-color:#f09030;}
.uj-tl-loc-pill-name{
    font-family:var(--uj-font-heading);font-size:7.5px;font-weight:600;
    letter-spacing:.1em;text-transform:uppercase;color:#5E4F40;
}
.uj-tl-loc-pill:hover .uj-tl-loc-pill-name{color:#f09030;}
.uj-tl-loc-pill-dates{
    font-family:var(--uj-font-body);font-size:10px;font-style:italic;color:#9a9088;
    display:block;
}

/* ══════════════════════════════════════════
   VIEW: COVERS  (luxury magazine rack)
══════════════════════════════════════════ */
.uj-covers-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
    gap:10px;
    align-items:start;
}
@media(min-width:1100px){
    .uj-covers-grid{grid-template-columns:repeat(4,minmax(0,280px));}
}
@media(min-width:768px) and (max-width:1099px){
    .uj-covers-grid{grid-template-columns:repeat(3,1fr);}
}
.uj-cover-card{
    background:var(--uj-card-bg);border-radius:10px;
    border:.5px solid var(--uj-border);overflow:hidden;
    display:flex;flex-direction:column;
    transition:transform .28s cubic-bezier(.16,1,.3,1),box-shadow .28s,border-color .22s;
    animation:ujFadeUp .4s cubic-bezier(.16,1,.3,1) both;
}
.uj-cover-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(0,0,0,.09);border-color:rgba(240,144,48,.3);}
/* Cover zone — gradient area, smaller on mobile */
.uj-cover-zone{
    height:100px;position:relative;
    display:flex;flex-direction:column;justify-content:flex-end;
    padding:.75rem .9rem .65rem;gap:3px;
    flex-shrink:0;cursor:pointer;
}
.uj-cover-cat{
    font-family:var(--uj-font-heading);font-size:7px;font-weight:600;
    letter-spacing:.3em;text-transform:uppercase;color:rgba(94,79,64,.65);
    margin-bottom:2px;
}
.uj-cover-brand{
    font-family:var(--uj-font-heading);font-size:18px;font-weight:600;
    letter-spacing:.2em;text-transform:uppercase;color:var(--uj-text);
    line-height:1;
}
.uj-cover-date-badge{
    position:absolute;top:.75rem;right:.75rem;
    display:flex;flex-direction:column;align-items:center;
    background:rgba(255,255,255,.75);backdrop-filter:blur(4px);
    border-radius:6px;padding:4px 8px;
}
.uj-cover-day{
    font-family:var(--uj-font-heading);font-size:20px;font-weight:300;
    color:var(--uj-text);line-height:1;
}
.uj-cover-mon{
    font-family:var(--uj-font-heading);font-size:7px;font-weight:600;
    letter-spacing:.2em;text-transform:uppercase;color:var(--uj-orange);
}
/* Body below zone */
.uj-cover-body{
    flex:1;display:flex;flex-direction:column;gap:.4rem;
    padding:.75rem .9rem .9rem;border-top:.5px solid var(--uj-border);
    cursor:pointer;
}
.uj-cover-title{
    font-family:var(--uj-font-heading);font-size:9px;font-weight:600;
    letter-spacing:.1em;text-transform:uppercase;color:var(--uj-text);line-height:1.4;
}
.uj-cover-locs{
    font-family:var(--uj-font-body);font-size:11px;font-style:italic;
    color:var(--uj-muted);line-height:1.4;
}
/* Cover expand — CSS checkbox toggle, works on all devices */
.uj-cover-cb{display:none;}
.uj-cover-expand{
    max-height:0;overflow:hidden;
    transition:max-height .35s cubic-bezier(.16,1,.3,1);
    border-top:0 solid var(--uj-border);
}
.uj-cover-cb:checked ~ .uj-cover-expand{
    max-height:500px;
    border-top:.5px solid var(--uj-border);
}
.uj-cover-expand-inner{
    padding:.85rem .9rem .9rem;
    display:flex;flex-direction:column;gap:.5rem;
}
.uj-cover-desc{
    font-family:var(--uj-font-body);font-size:13px;font-style:italic;
    color:var(--uj-muted);line-height:1.55;
}
.uj-cover-trigger{
    cursor:pointer;position:relative;display:block;
    user-select:none;-webkit-user-select:none;
}
.uj-cover-trigger::after{
    content:'›';font-size:16px;color:var(--uj-muted);
    position:absolute;bottom:.7rem;right:.9rem;
    transition:transform .25s,color .2s;pointer-events:none;
}
.uj-cover-card{position:relative;}
.uj-cover-cb:checked ~ .uj-cover-trigger::after{
    transform:rotate(90deg);color:var(--uj-orange);
}



/* ══════════════════════════════════════════
   VIEW: CAROUSEL  (mobile swipe)
══════════════════════════════════════════ */
.uj-carousel-wrap{overflow:hidden;padding-bottom:4px;}
.uj-carousel-track{
    display:flex;
    transition:transform .35s cubic-bezier(.16,1,.3,1);
    align-items:stretch;
}
.uj-carousel-slide{
    flex:0 0 100%;min-width:0;
    background:var(--uj-card-bg);
    padding:1rem 1.25rem .9rem;
    display:flex;flex-direction:column;gap:.4rem;
    border:.5px solid var(--uj-border);border-radius:10px;
    position:relative;overflow:hidden;
    /* gradient top border */
}
.uj-carousel-slide::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(to right,var(--card-grad-start,#4a8fa8),var(--card-grad-end,#d4b84a));
}
.uj-carousel-dots{
    display:flex;justify-content:center;align-items:center;gap:8px;
    margin-top:16px;padding:6px 0 2px;
}
.uj-dot{
    width:8px;height:8px;border-radius:50%;
    background:#9a9088 !important;border:none !important;padding:0 !important;
    cursor:pointer;transition:background .25s,width .25s;
    flex-shrink:0;display:block !important;
    min-width:8px;min-height:8px;box-shadow:none !important;
}
.uj-dot.active{background:#f09030 !important;width:22px !important;border-radius:4px !important;}



    .uj-vogue-left{min-height:180px;}
    .uj-vogue-brand-big{font-size:22px;}
    .uj-vogue-day{font-size:32px;}
    .uj-vogue-right{padding:1.25rem;}
}


/* ── Active event orb on card ── */
.uj-active-orb{
    position:absolute;top:-5px;right:-5px;
    width:11px;height:11px;border-radius:50%;
    background:rgba(240,144,48,.75);
    box-shadow:0 0 0 0 rgba(240,144,48,.3);
    animation:ujOrbGlow 3s ease-out infinite;
    z-index:20;
    pointer-events:none;
    backdrop-filter:blur(2px);
}
@keyframes ujOrbGlow{
    0%  {box-shadow:0 0 0 0 rgba(240,144,48,.35);}
    65% {box-shadow:0 0 0 7px rgba(240,144,48,0);}
    100%{box-shadow:0 0 0 0 rgba(240,144,48,0);}
}
.uj-card{position:relative;}
.uj-minimal-card{position:relative;}
.uj-tl-card{position:relative;}
.uj-cover-trigger{position:relative;}
.uj-carousel-slide{position:relative;}

/* ── Countdown badge ── */
.uj-countdown-badge{
    display:inline-block;
    font-family:var(--uj-font-heading);font-size:7px;font-weight:600;
    letter-spacing:.14em;text-transform:uppercase;
    background:var(--uj-orange);color:#fff;
    padding:2px 7px;border-radius:20px;
    vertical-align:middle;margin-left:6px;
}

/* ── Expandable description (Full view) ── */
.uj-card-desc{
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
    transition:max-height .3s ease;
}
.uj-card-desc.is-expanded{display:block;overflow:visible;-webkit-line-clamp:unset;}
.uj-desc-toggle{
    background:none;border:none;padding:0;cursor:pointer;
    font-family:var(--uj-font-body);font-size:12px;font-style:italic;
    color:var(--uj-orange);margin-top:4px;display:block;
}

/* ── Dark mode ── */
.uj-eventos-widget.uj-dark{
    --uj-bg:      #1a1714;
    --uj-card-bg: #242018;
    --uj-text:    #f0ebe3;
    --uj-muted:   #9a8f80;
    --uj-border:  #3a342c;
    background:#1a1714 !important;
}
.uj-dark .uj-minimal-card,
.uj-dark .uj-card,
.uj-dark .uj-tl-card,
.uj-dark .uj-cover-card{background:#242018 !important;border-color:#3a342c !important;}
.uj-dark .uj-cover-date-badge{background:rgba(26,23,20,.75);}

/* ── Responsive ── */
@media(max-width:768px){
    .uj-eventos-widget{padding:1.25rem 1rem 1.75rem;}
    /* Header always wraps cleanly — nav always visible */
    .uj-header{flex-direction:column;gap:.75rem;align-items:flex-start;}
    .uj-month-nav{align-self:stretch;justify-content:space-between;width:100%;}
    /* Full — stack cards vertically */
    .uj-track{min-width:unset;flex-direction:column;align-items:stretch;}
    .uj-card{width:100%;min-width:unset;}
    /* Minimal — single col */
    .uj-minimal-grid{grid-template-columns:1fr;}
    /* Editorial — simplified */
    .uj-editorial-row{grid-template-columns:60px 1fr;gap:.75rem;}
    .uj-ed-title-block,.uj-ed-locs{display:none;}
    .uj-ed-brand-block{padding:0 0 0 1rem;border-right:none;}
    /* Compact */
    .uj-compact-title{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
    /* Covers — 2 cols */
    .uj-covers-grid{grid-template-columns:repeat(2,1fr);}
    .uj-cover-zone{height:80px;}
    .uj-cover-brand{font-size:14px;}
    /* Timeline */
    .uj-timeline{padding-left:44px;}
}

/* Cover expand — hide loc label, tighten padding */
.uj-cover-expand-locs .uj-loc-label { display: none; }
.uj-cover-expand-locs .uj-loc-scroll-wrap { border-top: none; padding-top: 0; }
