@import url('https://fonts.googleapis.com/css2?family=Hind+Siliguri:wght@300;400;500;600;700&display=swap');

/* ══════════════════════════════════════════
   ROOT
══════════════════════════════════════════ */
.upf-wrap {
    --acc:        #16a34a;
    --acc-light:  #dcfce7;
    --acc-dark:   #15803d;
    --dark:       #0f172a;
    --surface:    #ffffff;
    --bg:         #f8fafc;
    --border:     #e2e8f0;
    --text:       #1e293b;
    --muted:      #64748b;
    --r:          12px;
    --r-sm:       8px;
    --shadow:     0 1px 3px rgba(0,0,0,.06), 0 4px 12px rgba(0,0,0,.05);
    --shadow-h:   0 4px 24px rgba(0,0,0,.12);
    --font:       'Hind Siliguri', sans-serif;

    font-family:  var(--font);
    background:   transparent;
    color:        var(--text);
    max-width:    1180px;
    margin:       0 auto;
    padding:      40px 20px 80px;
    -webkit-font-smoothing: antialiased;
}

/* ══════════════════════════════════════════
   HEADER
══════════════════════════════════════════ */
.upf-header {
    text-align:    center;
    margin-bottom: 36px;
}
.upf-header__title {
    font-size:   clamp(24px,4vw,38px);
    font-weight: 800;
    color:       var(--dark);
    margin:      0 0 8px;
    line-height: 1.25;
}
.upf-header__sub {
    font-size: 15px;
    color:     var(--muted);
    margin:    0;
}


/* ══════════════════════════════════════════
   HERO / FEATURED PROJECT
══════════════════════════════════════════ */
.upf-hero {
    display:       flex;
    background:    var(--surface);
    border-radius: var(--r);
    overflow:      hidden;
    margin-bottom: 36px;
    box-shadow:    0 4px 24px rgba(0,0,0,.10);
    min-height:    260px;
    position:      relative;
}

/* Hero Slider wrapper */
.upf-hero--slider {
    display:    flex;
    overflow:   hidden;
    min-height: 280px;
    align-items: stretch;
}

/* Slider track — slides sit side by side */
.upf-hero-track {
    display:    flex;
    width:      100%;
    flex:       1;
    transition: transform .45s cubic-bezier(.22,1,.36,1);
    align-items: stretch;
}

/* Each individual slide — full-width flex row (image left, body right) */
.upf-hero-slide {
    display:    flex;
    min-width:  100%;
    width:      100%;
    flex-shrink: 0;
    align-items: stretch;
    min-height: 280px;
}

/* Hero prev/next buttons */
.upf-hero-prev,
.upf-hero-next {
    position:        absolute;
    top:             50%;
    transform:       translateY(-50%);
    z-index:         10;
    width:           40px;
    height:          40px;
    border-radius:   50%;
    border:          none;
    background:      rgba(255,255,255,.85);
    color:           #0f172a;
    font-size:       22px;
    line-height:     1;
    cursor:          pointer;
    display:         flex;
    align-items:     center;
    justify-content: center;
    box-shadow:      0 2px 8px rgba(0,0,0,.18);
    transition:      background .15s, transform .15s;
}
.upf-hero-prev { left: 12px; }
.upf-hero-next { right: 12px; }
.upf-hero-prev:hover,
.upf-hero-next:hover { background: #fff; transform: translateY(-50%) scale(1.08); }

/* Hero dot navigation */
.upf-hero-dots {
    position:        absolute;
    bottom:          14px;
    left:            50%;
    transform:       translateX(-50%);
    display:         flex;
    gap:             8px;
    z-index:         10;
}
.upf-hero-dot {
    width:         10px;
    height:        10px;
    border-radius: 50%;
    border:        2px solid rgba(255,255,255,.7);
    background:    transparent;
    cursor:        pointer;
    padding:       0;
    transition:    background .2s, border-color .2s;
}
.upf-hero-dot--active {
    background:    #fff;
    border-color:  #fff;
}

.upf-hero__img {
    flex:       0 0 44%;
    position:   relative;
    overflow:   hidden;
    background: #e2e8f0;
    display:    flex;
    align-self: stretch;
    min-height: 280px;
}
.upf-hero__img img {
    position:    absolute;
    top:         0;
    left:        0;
    width:       100%;
    height:      100%;
    object-fit:  cover;
    object-position: center;
    display:     block;
    transition:  transform .5s ease;
}
.upf-hero-slide:hover .upf-hero__img img { transform: scale(1.04); }
.upf-hero__img-ph {
    width:      100%;
    height:     100%;
    display:    flex;
    align-items:center;
    justify-content:center;
    font-size:  64px;
    background: linear-gradient(135deg,#e2e8f0,#cbd5e1);
}
.upf-hero__badge {
    position:      absolute;
    top:           16px;
    left:          16px;
    padding:       5px 14px;
    border-radius: 20px;
    font-size:     12px;
    font-weight:   700;
    font-family:   var(--font);
}

.upf-hero__body {
    flex:    1;
    padding: 30px 34px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap:     0;
}
.upf-hero__title {
    font-size:   clamp(18px,2.4vw,26px);
    font-weight: 800;
    color:       #0f172a;
    margin:      0 0 10px;
    line-height: 1.35;
}
.upf-hero__desc {
    font-size:   14px;
    color:       var(--muted);
    margin:      0 0 22px;
    line-height: 1.7;
    display:     -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow:    hidden;
}

.upf-hero__meta {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   12px 20px;
    margin-bottom:         22px;
}
.upf-hero__meta-item {
    display:    flex;
    align-items:flex-start;
    gap:        9px;
}
.upf-hero__meta-item svg {
    width:      17px;
    height:     17px;
    flex-shrink:0;
    color:      var(--acc);
    margin-top: 2px;
}
.upf-hero__meta-lbl {
    display:    block;
    font-size:  11px;
    color:      var(--muted);
    font-weight:600;
    text-transform:uppercase;
    letter-spacing:.4px;
    margin-bottom:2px;
}
.upf-hero__meta-val {
    display:    block;
    font-size:  14px;
    font-weight:700;
    color:      #0f172a;
}

.upf-hero__prog { margin-top:auto; }
.upf-hero__prog-head {
    display:         flex;
    justify-content: space-between;
    align-items:     center;
    font-size:       13px;
    color:           var(--muted);
    margin-bottom:   7px;
    font-weight:     600;
}
.upf-hero__prog-head strong {
    font-size:  15px;
    font-weight:800;
    color:      var(--acc);
}
.upf-hero__prog-track {
    background:    #e9ecef;
    border-radius: 20px;
    height:        11px;
    overflow:      hidden;
}
.upf-hero__prog-fill {
    height:     100%;
    background: linear-gradient(90deg, var(--acc-dark,#15803d), var(--acc));
    border-radius: 20px;
    transition: width 1s cubic-bezier(.22,1,.36,1);
}

@media (max-width:800px) {
    .upf-hero-slide { flex-direction:column; }
    .upf-hero__img { flex:none; height:220px; min-height:220px; }
    .upf-hero__img img { position:absolute; }
    .upf-hero__body { padding:22px; }
    .upf-hero__meta { grid-template-columns:1fr; gap:10px; }
}

/* ══════════════════════════════════════════
   OVERVIEW CARDS
══════════════════════════════════════════ */
.upf-overview {
    display:               grid;
    grid-template-columns: repeat(4,1fr);
    gap:                   16px;
    margin-bottom:         40px;
}

.upf-ov-card {
    background:    var(--surface);
    border:        1.5px solid var(--border);
    border-radius: var(--r);
    padding:       24px 20px 20px;
    text-align:    center;
    cursor:        pointer;
    transition:    transform .2s, box-shadow .2s, border-color .2s;
    box-shadow:    var(--shadow);
    font-family:   var(--font);
    position:      relative;
    overflow:      hidden;
}
.upf-ov-card::before {
    content:  '';
    position: absolute;
    top:0;left:0;right:0;
    height:   3px;
    background: var(--border);
    transition: background .2s;
}
.upf-ov-card:hover {
    transform:    translateY(-4px);
    box-shadow:   0 8px 28px rgba(22,163,74,.18);
    border-color: var(--acc);
    background:   linear-gradient(160deg, #fff 60%, #f0fdf4);
}
.upf-ov-card.active {
    transform:    translateY(-4px);
    box-shadow:   0 8px 28px rgba(22,163,74,.22);
    border-color: var(--acc);
    background:   linear-gradient(160deg, #f0fdf4, #dcfce7);
}
.upf-ov-card:hover::before,
.upf-ov-card.active::before { background: var(--acc); }
.upf-ov-card.active .upf-ov-card__num { color: var(--acc); }

.upf-ov-card__icon {
    width:            44px;
    height:           44px;
    margin:           0 auto 12px;
    background:       var(--acc-light);
    border-radius:    10px;
    display:          flex;
    align-items:      center;
    justify-content:  center;
    color:            var(--acc);
}
.upf-ov-card__icon svg { width:22px;height:22px; }

.upf-ov-card__num {
    font-size:   40px;
    font-weight: 800;
    color:       var(--dark);
    line-height: 1;
    margin-bottom: 6px;
}
.upf-ov-card__label {
    font-size:  13px;
    color:      var(--muted);
    font-weight: 500;
}

/* ══════════════════════════════════════════
   MAIN TABS
══════════════════════════════════════════ */
.upf-tabs {
    display:         flex;
    gap:             0;
    margin-bottom:   28px;
    border-bottom:   2px solid var(--border);
}
.upf-tab {
    padding:         13px 28px;
    font-family:     var(--font);
    font-size:       15px;
    font-weight:     600;
    color:           var(--muted);
    background:      transparent;
    border:          none;
    border-bottom:   3px solid transparent;
    margin-bottom:   -2px;
    cursor:          pointer;
    transition:      color .18s, border-color .18s;
}
.upf-tab:hover { color: var(--acc); }
.upf-tab--active {
    color:        var(--acc);
    border-bottom-color: var(--acc);
}

/* ══════════════════════════════════════════
   FILTERS
══════════════════════════════════════════ */
.upf-filters {
    background:    var(--surface);
    border:        1.5px solid var(--border);
    border-radius: var(--r);
    padding:       18px 22px;
    margin-bottom: 28px;
    box-shadow:    var(--shadow);
}

/* One row: left (dropdowns) + right (status buttons) */
.upf-filter-row {
    display:     flex;
    align-items: flex-end;
    gap:         20px;
}

.upf-filter-left {
    display:  flex;
    gap:      12px;
    flex-wrap: nowrap;
    align-items: flex-end;
}

.upf-filter-right {
    display:       flex;
    flex-direction: column;
    gap:           7px;
    margin-left:   auto;   /* push to right */
    flex-shrink:   0;
}

.upf-filter-item { display:flex; flex-direction:column; gap:7px; }

.upf-filter-label {
    font-size:      11px;
    font-weight:    700;
    color:          var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space:    nowrap;
}

.upf-filter-btns { display:flex; flex-wrap:wrap; gap:6px; }

.upf-fbtn {
    padding:       7px 16px;
    border-radius: 20px;
    border:        1.5px solid var(--border);
    background:    var(--surface);
    font-family:   var(--font);
    font-size:     13px;
    font-weight:   600;
    color:         var(--muted);
    cursor:        pointer;
    transition:    all .15s;
    white-space:   nowrap;
}
.upf-fbtn:hover { border-color:var(--acc); color:var(--acc); background:var(--acc-light); }
.upf-fbtn--active { background:var(--acc); border-color:var(--acc); color:#fff; }

.upf-select {
    padding:      8px 12px;
    border-radius: var(--r-sm);
    border:       1.5px solid var(--border);
    font-family:  var(--font);
    font-size:    13px;
    color:        var(--text);
    background:   var(--surface);
    cursor:       pointer;
    outline:      none;
    transition:   border-color .15s;
    width:        150px;
}
.upf-select:focus  { border-color:var(--acc); }
.upf-select:disabled { opacity:.5; cursor:not-allowed; background:#f8fafc; }

/* ══════════════════════════════════════════
   LOADING
══════════════════════════════════════════ */
.upf-loading {
    display:         flex;
    justify-content: center;
    padding:         60px;
}
.upf-spinner {
    width:         40px;
    height:        40px;
    border:        3px solid var(--border);
    border-top-color: var(--acc);
    border-radius: 50%;
    animation:     upf-spin .8s linear infinite;
}
@keyframes upf-spin { to { transform:rotate(360deg); } }

/* ══════════════════════════════════════════
   PANELS
══════════════════════════════════════════ */
.upf-panel { display:none; }
.upf-panel--active {
    display:   block;
    animation: upf-fade .28s ease;
}
@keyframes upf-fade { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* ══════════════════════════════════════════
   PROJECT GRID
══════════════════════════════════════════ */
.upf-grid {
    display:               grid;
    grid-template-columns: repeat(3,1fr);
    gap:                   22px;
}
.upf-grid--social {
    grid-template-columns: repeat(3,1fr);
}

.upf-no-results {
    grid-column: 1/-1;
    text-align:  center;
    padding:     60px;
    color:       var(--muted);
    font-size:   16px;
    background:  var(--surface);
    border-radius: var(--r);
    border:      1.5px dashed var(--border);
}

/* ══════════════════════════════════════════
   PROJECT CARD
══════════════════════════════════════════ */
.upf-card {
    background:    var(--surface);
    border-radius: var(--r);
    border:        1.5px solid var(--border);
    overflow:      hidden;
    box-shadow:    var(--shadow);
    transition:    transform .22s, box-shadow .22s;
}
.upf-card:hover {
    transform:  translateY(-5px);
    box-shadow: 0 12px 36px rgba(22,163,74,.14), 0 2px 8px rgba(0,0,0,.06);
    border-color: rgba(22,163,74,.35);
}

/* Image slider */
.upf-slider {
    position:   relative;
    overflow:   hidden;
    height:     210px;
    background: #f1f5f9;
}
.upf-slider__track {
    display:    flex;
    height:     100%;
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    align-items:stretch;
}
.upf-slide {
    min-width:  100%;
    height:     100%;
    overflow:   hidden;
    background: #e2e8f0;
    flex-shrink:0;
}
.upf-slide img {
    width:       100%;
    height:      100%;
    object-fit:  cover;
    object-position: center top;
    display:     block;
    transition:  transform .45s;
    transform-origin: center center;
}
/* card image no zoom on hover */
.upf-slide img:hover,
.upf-card .upf-slide img:hover { transform: none !important; }

.upf-slide--empty {
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       52px;
    background:      linear-gradient(135deg,#e2e8f0,#cbd5e1);
}

.upf-slider__btn {
    position:        absolute;
    top:             50%;
    transform:       translateY(-50%);
    width:           34px;
    height:          34px;
    border-radius:   50%;
    background:      rgba(255,255,255,.9);
    border:          none;
    font-size:       20px;
    line-height:     1;
    cursor:          pointer;
    z-index:         3;
    box-shadow:      0 2px 8px rgba(0,0,0,.18);
    display:         flex;
    align-items:     center;
    justify-content: center;
    transition:      background .15s, opacity .15s;
    opacity:         0;
    padding:         0;
}
.upf-slider:hover .upf-slider__btn { opacity:1; }
.upf-slider__btn--prev { left:10px; }
.upf-slider__btn--next { right:10px; }
.upf-slider__btn:hover { background:#fff; }

.upf-slider__dots {
    position:        absolute;
    bottom:          10px;
    left:            50%;
    transform:       translateX(-50%);
    display:         flex;
    gap:             5px;
    z-index:         3;
}
.upf-dot {
    width:         7px;
    height:        7px;
    border-radius: 50%;
    background:    rgba(255,255,255,.5);
    transition:    background .2s, transform .2s;
}
.upf-dot--active {
    background: #fff;
    transform:  scale(1.3);
}

/* Status badge */
.upf-card__badge {
    position:      absolute;
    top:           12px;
    right:         12px;
    padding:       4px 12px;
    border-radius: 20px;
    font-size:     11px;
    font-weight:   700;
    font-family:   var(--font);
    white-space:   nowrap;
    z-index:       2;
}
.upf-card__badge--ongoing   { background:var(--dark);   color:#fff; }
.upf-card__badge--completed { background:var(--acc);    color:#fff; }
.upf-card__badge--upcoming  { background:#3b82f6;       color:#fff; }
/* Social badges */
.upf-card__badge--green     { background:#16a34a; color:#fff; }
.upf-card__badge--blue      { background:#2563eb; color:#fff; }
.upf-card__badge--orange    { background:#ea580c; color:#fff; }
.upf-card__badge--purple    { background:#7c3aed; color:#fff; }
.upf-card__badge--teal      { background:#0891b2; color:#fff; }

/* Card body */
.upf-card__body {
    padding: 18px 20px 20px;
}
.upf-card__title {
    font-size:   16px;
    font-weight: 700;
    color:       var(--dark);
    margin:      0 0 7px;
    line-height: 1.4;
}
.upf-card__desc {
    font-size:          13px;
    color:              var(--muted);
    margin:             0 0 14px;
    line-height:        1.65;
    display:            -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow:           hidden;
}
.upf-card__details {
    display:       flex;
    flex-direction:column;
    gap:           7px;
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border);
}
.upf-card__detail {
    display:    flex;
    align-items:center;
    gap:        7px;
    font-size:  13px;
    color:      var(--muted);
}
.upf-card__detail svg { width:15px;height:15px;flex-shrink:0;color:var(--acc); }
.upf-card__detail strong { color:var(--text); font-weight:600; }

/* Progress bar */
.upf-card__prog-head {
    display:         flex;
    justify-content: space-between;
    align-items:     center;
    margin-bottom:   7px;
}
.upf-card__prog-label { font-size:12px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.4px; }
.upf-card__prog-pct   { font-size:14px; font-weight:800; color:var(--acc); }
.upf-card__prog-track {
    background:    #e9ecef;
    border-radius: 20px;
    height:        9px;
    overflow:      hidden;
}
.upf-card__prog-fill {
    height:        100%;
    background:    linear-gradient(90deg, var(--acc-dark), var(--acc));
    border-radius: 20px;
    transition:    width 1s cubic-bezier(.22,1,.36,1);
}

/* ══════════════════════════════════════════
   SOCIAL CARD
══════════════════════════════════════════ */
.upf-scard {
    background:    var(--surface);
    border-radius: var(--r);
    border:        1.5px solid var(--border);
    overflow:      hidden;
    box-shadow:    var(--shadow);
    transition:    transform .22s, box-shadow .22s;
}
.upf-scard:hover { transform:translateY(-5px); box-shadow:0 12px 36px rgba(22,163,74,.14),0 2px 8px rgba(0,0,0,.06); border-color:rgba(22,163,74,.35); }
.upf-scard__body { padding:18px 20px 20px; }
.upf-scard__title { font-size:16px;font-weight:700;color:var(--dark);margin:0 0 7px;line-height:1.4; }
.upf-scard__desc  { font-size:13px;color:var(--muted);margin:0 0 14px;line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
.upf-scard__details { display:flex;flex-direction:column;gap:7px; }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width:1024px) {
    .upf-overview { grid-template-columns:repeat(2,1fr); }
    .upf-grid, .upf-grid--social { grid-template-columns:repeat(2,1fr); }
    .upf-filter-left { flex-wrap:wrap; }
    .upf-select { width:130px; }
}

@media (max-width:768px) {
    .upf-wrap { padding:24px 14px 48px; }

    /* Overview */
    .upf-overview { grid-template-columns:1fr 1fr; gap:10px; }
    .upf-ov-card { padding:16px 12px 14px; }
    .upf-ov-card__num { font-size:26px; }

    /* Tabs */
    .upf-tabs { overflow-x:auto; -webkit-overflow-scrolling:touch; }
    .upf-tab  { padding:12px 18px; white-space:nowrap; font-size:14px; }

    /* Filters: stack vertically on mobile */
    .upf-filter-row {
        flex-direction: column;
        align-items:    stretch;
        gap:            14px;
    }
    .upf-filter-left {
        display:   flex;
        flex-direction: row;
        flex-wrap: wrap;
        gap:       10px;
    }
    .upf-filter-left .upf-filter-item { flex:1 1 130px; }
    .upf-filter-left .upf-select { width:100%; }
    .upf-filter-right {
        margin-left: 0;   /* no longer pushed right */
        border-top:  1px solid var(--border);
        padding-top: 14px;
    }
    .upf-fbtn { font-size:12px; padding:6px 12px; }

    /* Cards */
    .upf-grid, .upf-grid--social { grid-template-columns:1fr; }
    .upf-slider { height:180px; }
}

@media (max-width:480px) {
    .upf-overview { gap:8px; }
    .upf-ov-card__icon { width:36px; height:36px; }
    .upf-ov-card__icon svg { width:18px; height:18px; }
}

/* ══════════════════════════════════════════
   FIXED CARD HEIGHT
══════════════════════════════════════════ */
.upf-card {
    display:        flex;
    flex-direction: column;
}
.upf-card__body {
    flex:    1;
    display: flex;
    flex-direction: column;
    padding: 16px 18px 18px;
}
/* Fixed height title - 2 lines max */
.upf-card__title {
    font-size:              15px;
    font-weight:            800;
    color:                  #0f172a;
    margin:                 0 0 7px;
    line-height:            1.4;
    min-height:             2.8em;   /* exactly 2 lines */
    max-height:             2.8em;
    overflow:               hidden;
    display:                -webkit-box;
    -webkit-line-clamp:     2;
    -webkit-box-orient:     vertical;
}
/* Fixed height desc - 2 lines max */
.upf-card__desc {
    font-size:              13px;
    color:                  var(--muted);
    margin:                 0 0 12px;
    line-height:            1.6;
    min-height:             2.6em;
    max-height:             2.6em;
    overflow:               hidden;
    display:                -webkit-box;
    -webkit-line-clamp:     2;
    -webkit-box-orient:     vertical;
}
.upf-card__details {
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
    min-height: unset;
}
.upf-card__prog-wrap { margin-top:auto; }

.upf-card__detail-link {
    display:      block;
    text-align:   center;
    margin-top:   12px;
    padding:      7px 0;
    color:        var(--acc);
    font-size:    13px;
    font-weight:  700;
    text-decoration: none;
    border:       1.5px solid var(--acc);
    border-radius: var(--r-sm);
    transition:   all .16s;
}
.upf-card__detail-link:hover {
    background:  var(--acc);
    color:       #fff !important;
    border-color: var(--acc);
}

/* ══════════════════════════════════════════
   SOCIAL CARD - FIXED HEIGHT
══════════════════════════════════════════ */
.upf-scard {
    display:        flex;
    flex-direction: column;
}
.upf-scard__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 16px 18px 18px;
}
.upf-scard__title {
    font-size:          15px;
    font-weight:        800;
    color:              #0f172a;
    margin:             0 0 7px;
    line-height:        1.4;
    min-height:         2.8em;
    max-height:         2.8em;
    overflow:           hidden;
    display:            -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.upf-scard__desc {
    font-size:          13px;
    color:              var(--muted);
    margin:             0 0 12px;
    line-height:        1.6;
    min-height:         2.6em;
    max-height:         2.6em;
    overflow:           hidden;
    display:            -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.upf-scard__details { margin-top:auto; }

/* ══════════════════════════════════════════
   MORE BUTTON
══════════════════════════════════════════ */
.upf-more-wrap {
    text-align: center;
    margin-top: 32px;
}
.upf-more-btn {
    display:       inline-flex;
    align-items:   center;
    gap:           8px;
    padding:       12px 32px;
    background:    var(--surface);
    border:        2px solid var(--acc);
    border-radius: 50px;
    color:         var(--acc);
    font-family:   var(--font);
    font-size:     15px;
    font-weight:   700;
    cursor:        pointer;
    text-decoration: none;
    transition:    all .18s;
}
.upf-more-btn:hover {
    background:  var(--acc);
    color:       #fff;
    transform:   translateY(-2px);
    box-shadow:  0 6px 20px rgba(22,163,74,.25);
}

/* ══════════════════════════════════════════
   POPUP MODAL
══════════════════════════════════════════ */
.upf-popup-overlay {
    position:       fixed;
    inset:          0;
    background:     rgba(15,23,42,.65);
    z-index:        99999;
    display:        flex;
    align-items:    center;
    justify-content:center;
    padding:        16px;
    backdrop-filter: blur(4px);
    animation:      upf-overlay-in .2s ease;
}
@keyframes upf-overlay-in { from{opacity:0} to{opacity:1} }

.upf-popup {
    background:    #fff;
    border-radius: 18px;
    width:         100%;
    max-width:     780px;
    max-height:    88vh;
    overflow-y:    auto;
    position:      relative;
    box-shadow:    0 24px 80px rgba(0,0,0,.22);
    animation:     upf-popup-in .25s cubic-bezier(.22,1,.36,1);
}
@keyframes upf-popup-in { from{opacity:0;transform:translateY(20px) scale(.97)} to{opacity:1;transform:translateY(0) scale(1)} }

.upf-popup__close {
    position:    absolute;
    top:         12px;
    right:       12px;
    width:       38px;
    height:      38px;
    border-radius: 50%;
    border:      2px solid rgba(0,0,0,.15);
    background:  #fff;
    color:       #0f172a;
    font-size:   18px;
    font-weight: 700;
    cursor:      pointer;
    z-index:     10;
    display:     flex;
    align-items: center;
    justify-content: center;
    box-shadow:  0 2px 8px rgba(0,0,0,.18);
    transition:  all .15s;
    line-height: 1;
}
.upf-popup__close:hover { background:#ef4444; color:#fff; border-color:#ef4444; transform:scale(1.1); }

.upf-popup__inner { padding: 0; overflow: hidden; }
.upf-popup__loading { padding:60px; text-align:center; display:flex; justify-content:center; }

/* Popup content styles */
.upf-popup-slider {
    border-radius: 12px 12px 0 0;
    overflow:      hidden;
    height:        280px;
    background:    #e2e8f0;
    margin:        0 0 22px;
    position:      relative;
}
.upf-popup-slider:empty { display: none; }
.upf-popup-slider .upf-slider { height: 100%; border-radius: 0; }
.upf-popup-slider .upf-slider__track { display:flex; height:100%; transition:transform .35s; }
.upf-popup-slider .upf-slide { min-width:100%; height:100%; flex-shrink:0; }
.upf-popup-slider .upf-slide img { width:100%;height:100%;object-fit:cover;object-position:center; }
.upf-popup-slider .upf-slide--empty { display:flex;align-items:center;justify-content:center;font-size:60px; }
.upf-popup-slider .upf-slider__btn { opacity: 1; }
.upf-popup__inner-content { padding: 22px 28px 28px; }

.upf-popup__title { font-size:22px;font-weight:800;color:#0f172a;margin:0 0 10px;line-height:1.35; }
.upf-popup__desc  { font-size:14px;color:#475569;line-height:1.75;margin:0 0 20px; }
.upf-popup__meta  { display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px; }
.upf-popup__meta-item { background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px; }
.upf-popup__meta-lbl  { font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px; }
.upf-popup__meta-val  { font-size:14px;font-weight:700;color:#0f172a; }
.upf-popup__prog-wrap { margin-bottom:20px; }
.upf-popup__prog-head { display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px;color:#64748b;font-weight:600; }
.upf-popup__prog-head strong { font-size:16px;font-weight:800;color:var(--acc); }
.upf-popup__prog-track { background:#e9ecef;border-radius:20px;height:11px;overflow:hidden; }
.upf-popup__prog-fill  { height:100%;background:linear-gradient(90deg,#15803d,#16a34a);border-radius:20px;transition:width 1s cubic-bezier(.22,1,.36,1); }
.upf-popup__footer { display:flex;gap:10px;flex-wrap:wrap; }
.upf-popup__link { display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--acc);color:#fff;border-radius:8px;text-decoration:none;font-weight:700;font-size:14px;transition:background .15s; }
.upf-popup__link:hover { background:#15803d;color:#fff; }

@media (max-width:600px) {
    .upf-popup { max-height:94vh; }
    .upf-popup__inner { padding:0; }
    .upf-popup__inner-content { padding:16px 16px 20px; }
    .upf-popup-slider { height:200px; }
    .upf-popup__title { font-size:18px; }
}

/* Prevent body scroll when popup open */
body.upf-no-scroll { overflow: hidden !important; }
