/* ===================================================================
   KIMS Scholarship — public front-end
   Refined editorial-minimal. Display serif (Fraunces) + Be Vietnam Pro.
   Brand kept: navy #333f57 · green #40cc6f · slate accent #7b68ee.
   =================================================================== */

:root {
    --ink:      #1c2435;   /* primary text — deep navy ink */
    --navy:     #333f57;
    --navy-d:   #232d42;
    --green:    #2fb866;   /* refined primary */
    --green-br: #40cc6f;   /* bright accent */
    --green-d:  #1f9a52;
    --slate:    #7b68ee;
    --muted:    #69718a;
    --line:     #e8ebf1;
    --line-2:   #f0f2f6;
    --bg:       #f6f7f9;
    --bg-warm:  #fbfbfc;
    --paper:    #ffffff;

    --font-display: 'Fraunces', 'Newsreader', Georgia, 'Times New Roman', serif;
    --font-body:    'Be Vietnam Pro', 'Be Vietnam', -apple-system, system-ui, sans-serif;

    --r:    18px;
    --r-sm: 11px;
    --r-pill: 999px;

    --sh-sm: 0 1px 2px rgba(28,36,53,.04), 0 2px 8px rgba(28,36,53,.04);
    --sh:    0 2px 6px rgba(28,36,53,.05), 0 14px 34px -14px rgba(28,36,53,.16);
    --sh-lg: 0 4px 12px rgba(28,36,53,.06), 0 30px 60px -22px rgba(28,36,53,.28);
    --ring:  0 0 0 4px rgba(47,184,102,.16);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--font-body);
    color: var(--ink);
    background: var(--bg);
    line-height: 1.65;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

h1, h2, h3 { font-family: var(--font-display); font-weight: 540; letter-spacing: -0.015em; color: var(--ink); line-height: 1.12; }
h1 { font-size: clamp(1.7rem, 1.2rem + 1.8vw, 2.5rem); margin: 0 0 .6rem; }
h2 { font-size: clamp(1.25rem, 1rem + 1vw, 1.6rem); margin: 1.8rem 0 .8rem; font-weight: 540; }
p { margin: 0 0 1rem; }
a { color: var(--green-d); text-decoration: none; transition: color .18s; }
a:hover { color: var(--ink); }
.muted { color: var(--muted); font-size: .95rem; }

/* ---- Top utility bar ---- */
.topbar { background: var(--navy-d); color: #aeb6c8; font-size: .82rem; letter-spacing: .01em; }
.topbar .wrap { max-width: 1180px; margin: 0 auto; padding: 9px 28px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px; }
.topbar a { color: #d6dbe6; }
.topbar a:hover { color: var(--green-br); }
.topbar .sep { opacity: .35; padding: 0 10px; }
.topbar nav a { margin-left: 20px; }

/* ---- Header ---- */
.site-header { background: rgba(255,255,255,.82); backdrop-filter: saturate(140%) blur(10px); -webkit-backdrop-filter: saturate(140%) blur(10px); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 30; }
.site-header .wrap { max-width: 1180px; margin: 0 auto; padding: 14px 28px; display: flex; justify-content: space-between; align-items: center; }
.brand { display: flex; align-items: center; gap: 12px; font-family: var(--font-display); font-weight: 600; font-size: 1.3rem; letter-spacing: -0.01em; color: var(--ink); }
.brand img.logo { height: 44px; width: auto; display: block; }
.site-header nav { display: flex; align-items: center; gap: 26px; }
.site-header nav a { color: var(--ink); font-size: .95rem; font-weight: 500; position: relative; }
.site-header nav a::after { content: ''; position: absolute; left: 0; right: 100%; bottom: -6px; height: 2px; background: var(--green); border-radius: 2px; transition: right .22s ease; }
.site-header nav a:hover { color: var(--ink); }
.site-header nav a:hover::after { right: 0; }

/* ---- Hero ---- */
.hero {
    position: relative; isolation: isolate; color: #fff;
    padding: clamp(64px, 6vw, 104px) 28px clamp(96px, 9vw, 140px);
    background:
        radial-gradient(900px 420px at 82% -10%, rgba(47,184,102,.28), transparent 60%),
        linear-gradient(168deg, rgba(35,45,66,.78) 0%, rgba(35,45,66,.92) 62%, rgba(28,36,53,.97) 100%),
        url('kims-hero-bg.jpg') center 32% / cover no-repeat;
}
.hero::after { /* fine grain for depth */
    content: ''; position: absolute; inset: 0; z-index: -1; opacity: .5; pointer-events: none; mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
}
.hero .wrap { max-width: 1180px; margin: 0 auto; }
.hero-kicker { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body); font-size: .72rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: #bfe6cf; padding: 6px 14px; border: 1px solid rgba(255,255,255,.22); border-radius: var(--r-pill); margin-bottom: 18px; }
.hero-kicker .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--green-br); box-shadow: 0 0 0 4px rgba(64,204,111,.25); }
.hero h1 { color: #fff; font-size: clamp(2.1rem, 1.3rem + 3vw, 3.4rem); font-weight: 500; max-width: 16ch; }
.hero p { color: #c9d0df; margin: 10px 0 0; font-size: 1.05rem; max-width: 52ch; }
.hero .wave { position: absolute; left: 0; right: 0; bottom: -1px; width: 100%; height: 72px; display: block; }

/* ---- Layout ---- */
main { max-width: 1140px; margin: 0 auto; padding: 36px 24px 40px; }
main.narrow { max-width: 820px; }
.pull-up { margin-top: clamp(-90px, -7vw, -64px); position: relative; z-index: 2; }
/* Pages whose content starts with a bare heading (not a white card) must clear
   the hero wave; otherwise the dark title overlaps the skyline. */
main.pull-up > h1:first-child, main.pull-up > h2:first-child { padding-top: clamp(88px, 8vw, 114px); }
.auth-card { max-width: 460px; margin-left: auto; margin-right: auto; }

/* ---- Cards ---- */
.card, .block-card {
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--r);
    box-shadow: var(--sh); padding: clamp(24px, 3vw, 36px); margin-bottom: 26px;
}
.card > h1:first-child, .card > h2:first-child, .block-card-header h3 { margin-top: 0; }

/* ---- Forms ---- */
label { display: block; font-size: .85rem; font-weight: 500; color: var(--ink); margin: 16px 0 7px; }
input, select, textarea {
    width: 100%; padding: 12px 14px; font-size: .95rem; font-family: inherit; color: var(--ink);
    border: 1px solid #d9dde6; border-radius: var(--r-sm); background: var(--bg-warm);
    transition: border-color .16s, box-shadow .16s, background .16s;
}
input::placeholder, textarea::placeholder { color: #9aa2b4; }
input[readonly] { background: #eef1f6; color: #6b7385; cursor: default; border-color: #e1e5ee; }
input[readonly]:focus { border-color: #e1e5ee; box-shadow: none; background: #eef1f6; }
input:focus, select:focus, textarea:focus { outline: none; background: #fff; border-color: var(--green); box-shadow: var(--ring); }
.row { display: flex; gap: 16px; flex-wrap: wrap; }
.row > * { flex: 1; min-width: 180px; }

/* ---- Buttons ---- */
.btn, button.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px; cursor: pointer; border: 0;
    font-family: var(--font-body); font-size: .95rem; font-weight: 600; letter-spacing: .01em;
    padding: 12px 24px; border-radius: var(--r-pill); color: #fff;
    background: linear-gradient(135deg, var(--green-br), var(--green-d)); text-decoration: none;
    box-shadow: 0 10px 22px -8px rgba(47,184,102,.6); transition: transform .14s cubic-bezier(.2,.7,.3,1), box-shadow .18s, filter .18s;
}
.btn:hover, button.btn:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 16px 30px -10px rgba(47,184,102,.7); filter: saturate(1.05); }
.btn:active { transform: translateY(0); }
.btn:disabled { opacity: .55; cursor: not-allowed; transform: none; box-shadow: none; }
/* `.btn.btn-secondary` (0,2,0) so it also wins over `button.btn` (0,1,1) for <button> elements. */
.btn.btn-secondary { background: #fff; color: var(--ink); box-shadow: inset 0 0 0 1px var(--line); }
.btn.btn-secondary:hover { background: #fff; color: var(--ink); box-shadow: inset 0 0 0 1px #cfd5e0; }
.btn-block { width: 100%; }
form button[type="submit"], form .btn-submit { margin-top: 22px; }

/* ---- Alerts (hidden by default; shown inline or via views' JS) ---- */
.alert { padding: 13px 16px; border-radius: var(--r-sm); font-size: .92rem; margin: 14px 0; display: none; }
.alert-ok  { background: #e9f9f0; color: #167a42; box-shadow: inset 0 0 0 1px #bdeccf; }
.alert-err { background: #fdeded; color: #a52121; box-shadow: inset 0 0 0 1px #f5cccc; }

/* ---- Misc ---- */
.footer-link { text-align: center; margin-top: 18px; font-size: .9rem; }
code { background: var(--line-2); padding: 2px 8px; border-radius: 6px; font-size: .82rem; color: var(--ink); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
ul.clean { list-style: none; padding: 0; }
.content-prose a { background-image: linear-gradient(var(--green), var(--green)); background-size: 0% 1.5px; background-repeat: no-repeat; background-position: 0 100%; transition: background-size .25s; padding-bottom: 1px; }
.content-prose a:hover { background-size: 100% 1.5px; }

/* ---- Site footer ---- */
.site-footer { background: var(--navy-d); color: #98a1b6; font-size: .9rem; margin-top: 0; }
.site-footer .cols { max-width: 1180px; margin: 0 auto; padding: 52px 28px 30px; display: grid; grid-template-columns: 2fr 1fr 1.4fr; gap: 40px; }
.site-footer h4 { font-family: var(--font-body); color: #fff; font-size: .78rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; margin: 0 0 16px; }
.site-footer .brand-row { display: flex; align-items: center; gap: 11px; margin-bottom: 14px; }
.site-footer .brand-row img { height: 42px; background: #fff; border-radius: 9px; padding: 4px; }
.site-footer .brand-row strong { font-family: var(--font-display); color: #fff; font-size: 1.15rem; font-weight: 600; }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer ul li { margin: 9px 0; }
.site-footer a { color: #b9c0cf; }
.site-footer a:hover { color: var(--green-br); }
.site-footer .contact-item { display: flex; gap: 10px; margin: 9px 0; align-items: flex-start; }
.site-footer .contact-item .la { color: var(--green-br); font-size: 1.05rem; margin-top: 2px; }
.site-footer .copyright { border-top: 1px solid rgba(255,255,255,.08); text-align: center; padding: 18px 24px; font-size: .8rem; }
@media (max-width: 760px) { .site-footer .cols { grid-template-columns: 1fr; gap: 28px; } }

/* ---- Toasts ---- */
#toast-wrap { position: fixed; top: 20px; right: 20px; z-index: 9999; display: flex; flex-direction: column; gap: 10px; }
.toast { min-width: 250px; max-width: 360px; padding: 14px 18px; border-radius: var(--r-sm); color: #fff; box-shadow: var(--sh-lg); font-size: .92rem; animation: toastIn .3s cubic-bezier(.2,.7,.3,1); }
.toast.ok  { background: linear-gradient(135deg, var(--green-br), var(--green-d)); }
.toast.err { background: linear-gradient(135deg, #e06060, #c23636); }
@keyframes toastIn { from { opacity: 0; transform: translateX(24px); } to { opacity: 1; transform: none; } }

/* ---- Shared-folder download progress overlay ---- */
.dlbar-overlay { position: fixed; inset: 0; z-index: 10001; display: grid; place-items: center; padding: 24px; background: rgba(20,28,44,.55); backdrop-filter: blur(2px); }
.dlbar-card { width: 100%; max-width: 380px; background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--sh-lg); padding: 22px 24px; }
.dlbar-title { display: flex; align-items: center; gap: 9px; font-weight: 600; color: var(--ink); margin-bottom: 4px; }
.dlbar-file { font-size: .82rem; color: var(--muted); margin-bottom: 14px; word-break: break-word; }
.dlbar-track { height: 8px; border-radius: 999px; background: var(--line); overflow: hidden; }
.dlbar-fill { height: 100%; width: 0; border-radius: 999px; background: linear-gradient(135deg, var(--green-br), var(--green-d)); transition: width .15s ease; }
.dlbar-fill.indet { width: 40% !important; animation: dlbarIndet 1.1s ease-in-out infinite; }
.dlbar-meta { margin-top: 9px; font-size: .8rem; color: var(--muted); display: flex; justify-content: space-between; }
@keyframes dlbarIndet { 0% { margin-left: -40%; } 100% { margin-left: 100%; } }

/* ---- Shared-folder collapsible tree ---- */
.shared-tree { list-style: none; padding-left: 18px; margin: 4px 0; }
.shared-tree li { margin: 5px 0; }
.shared-folder > summary { cursor: pointer; user-select: none; padding: 4px 8px; border-radius: 8px; display: list-item; }
.shared-folder > summary:hover { background: rgba(28,36,53,.05); color: var(--green-d); }
.shared-tree .ico { margin-right: 4px; }
.shared-empty { color: var(--muted); font-size: .85rem; padding: 2px 0 2px 18px; }

/* ---- Modal dialogs (kimsConfirm / kimsAlert) ---- */
.kmodal-overlay {
    position: fixed; inset: 0; z-index: 10000; display: grid; place-items: center; padding: 24px;
    background: rgba(28, 36, 53, .5); backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
    opacity: 0; transition: opacity .18s ease;
}
.kmodal-overlay.show { opacity: 1; }
.kmodal {
    width: 100%; max-width: 440px; background: var(--paper); border: 1px solid var(--line);
    border-radius: var(--r); box-shadow: var(--sh-lg); padding: 28px 28px 24px;
    display: grid; grid-template-columns: auto 1fr; gap: 4px 18px;
    transform: translateY(12px) scale(.97); opacity: 0;
    transition: transform .2s cubic-bezier(.2,.7,.3,1), opacity .2s;
}
.kmodal-overlay.show .kmodal { transform: none; opacity: 1; }
.kmodal-ic { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; font-size: 1.4rem; background: #e9eeff; color: #2a4ba8; }
.kmodal-ic.danger { background: #fdeaea; color: #b23030; }
.kmodal-ic.warn   { background: #fff4e1; color: #9a6212; }
.kmodal-ic.success{ background: #e6f7ee; color: #137a40; }
.kmodal-body { align-self: center; }
.kmodal-title { font-family: var(--font-display); font-size: 1.25rem; font-weight: 540; margin: 0 0 6px; color: var(--ink); letter-spacing: -.01em; }
.kmodal-msg { margin: 0; font-size: .95rem; color: var(--muted); line-height: 1.55; }
.kmodal-actions { grid-column: 1 / -1; display: flex; justify-content: flex-end; gap: 10px; margin-top: 22px; }
.kmodal-actions .btn { width: auto; }
.kmodal-ok.danger { background: linear-gradient(135deg, #e06060, #c23636); }
.kmodal-ok.warn   { background: linear-gradient(135deg, #e8a93e, #b9791a); }
@media (max-width: 480px) {
    .kmodal { grid-template-columns: 1fr; text-align: center; }
    .kmodal-ic { margin: 0 auto 4px; }
    .kmodal-actions { flex-direction: column-reverse; }
    .kmodal-actions .btn { width: 100%; justify-content: center; }
}

/* ---- Home: CTA / residency table / mission / promo ---- */
.home-cta { text-align: center; }
.home-logo { width: 96px; height: auto; margin: 0 auto 10px; display: block; filter: drop-shadow(0 8px 18px rgba(28,36,53,.14)); }
.home-cta h2 { font-size: clamp(1.5rem, 1.1rem + 1.6vw, 2rem); }
.cta-buttons { margin-top: 24px; display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.cta-buttons .btn { width: auto; }

.spots-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--r-sm); box-shadow: var(--sh-sm); }
.spots-table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: .85rem; }
.spots-table th, .spots-table td { padding: 11px 14px; white-space: nowrap; border-bottom: 1px solid var(--line-2); }
.spots-table thead th { background: var(--navy-d); color: #fff; font-family: var(--font-body); font-weight: 600; font-size: .76rem; letter-spacing: .03em; text-transform: uppercase; position: sticky; top: 0; }
.spots-table tbody tr:nth-child(even) td, .spots-table tbody tr:nth-child(even) th { background: #fafbfc; }
.spots-table tbody tr:hover td, .spots-table tbody tr:hover th { background: #f1f9f4; }
.spots-table tbody th { text-align: left; font-weight: 600; color: var(--ink); position: sticky; left: 0; background: #fff; z-index: 1; }
.spots-table thead th:first-child { position: sticky; left: 0; z-index: 2; text-align: left; }
.spots-table td.center { text-align: center; }
.spots-table td.center .la { color: var(--green); font-size: 1.05rem; }

.mission { position: relative; overflow: hidden; background: linear-gradient(135deg, var(--navy) 0%, var(--navy-d) 100%); color: #fff; border-radius: var(--r); padding: clamp(40px, 5vw, 64px) clamp(28px, 4vw, 56px); text-align: center; margin-bottom: 26px; }
.mission::before { content: ''; position: absolute; inset: 0; background: radial-gradient(600px 300px at 85% -20%, rgba(47,184,102,.35), transparent 60%); pointer-events: none; }
.mission h2 { color: #fff; font-size: clamp(1.6rem, 1.2rem + 1.6vw, 2.2rem); margin: 0 0 14px; }
.mission p { color: #d2d8e4; max-width: 660px; margin: 0 auto; font-size: 1.05rem; }

.promo { display: flex; gap: 34px; align-items: center; flex-wrap: wrap; }
.promo-img { flex: 0 0 260px; }
.promo-img img { width: 100%; height: auto; border-radius: var(--r-sm); box-shadow: var(--sh); }
.promo-body { flex: 1; min-width: 260px; }
.promo-body h2 { margin: 0 0 12px; }

/* ---- Orchestrated page-load reveal ---- */
@media (prefers-reduced-motion: no-preference) {
    .hero .wrap > * { opacity: 0; animation: rise .7s cubic-bezier(.2,.7,.3,1) forwards; }
    .hero-kicker { animation-delay: .05s; }
    .hero h1 { animation-delay: .14s; }
    .hero p  { animation-delay: .24s; }
    main.pull-up > * { opacity: 0; animation: rise .65s cubic-bezier(.2,.7,.3,1) forwards; }
    main.pull-up > *:nth-child(1) { animation-delay: .30s; }
    main.pull-up > *:nth-child(2) { animation-delay: .40s; }
    main.pull-up > *:nth-child(3) { animation-delay: .50s; }
    main.pull-up > *:nth-child(4) { animation-delay: .58s; }
    main.pull-up > *:nth-child(n+5) { animation-delay: .64s; }
    @keyframes rise { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
}

@media (max-width: 600px) {
    .site-header nav { gap: 16px; }
    .site-header nav a { font-size: .88rem; }
}

/* ============================================================
   Applicant form — instant uploads, dependent universities
   ============================================================ */
.form-fields { border: 0; padding: 0; margin: 0; min-width: 0; }
.form-fields[disabled] { opacity: .96; }
.form-card h2 { font-size: 1.25rem; margin: 0 0 4px; }

.check-row { display: flex; align-items: flex-start; gap: 10px; font-weight: 500; color: var(--ink); margin: 10px 0; cursor: pointer; }
.check-row input { width: auto; margin-top: 3px; flex: none; }
.agree-row { font-weight: 600; }
.toggle-body { margin: 10px 0 4px; }
.toggle-item { padding: 4px 0; border-bottom: 1px solid var(--line); }
.toggle-item:last-child { border-bottom: 0; }

.form-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.general-bundle { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--line); }

/* upload grid */
.upload-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 14px; margin-top: 16px; }
/* fixed trio (Personal: photo / passport / civil ID) — equal columns, full width */
.upload-grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 600px) { .upload-grid.cols-3 { grid-template-columns: 1fr; } }
/* full-width uploads, each on its own row (Medical License / CV letter / MCCQE) */
.upload-stack { display: flex; flex-direction: column; gap: 14px; margin-top: 14px; }
.upload-full { width: 100%; }
.upload-help { margin: 7px 0 0; font-size: .85rem; }
.upload-note { margin: 7px 0 0; font-size: .85rem; color: #c0392b; font-weight: 500; }

/* one dropzone */
.uploader-label { font-size: .85rem; font-weight: 500; color: var(--ink); margin-bottom: 7px; }
.dropzone {
    position: relative; display: flex; align-items: center; justify-content: center; gap: 10px;
    min-height: 84px; padding: 14px 16px; text-align: center; cursor: pointer;
    border: 1.5px dashed #c4cbd8; border-radius: var(--r-sm); background: var(--bg-warm);
    color: #6b7280; transition: border-color .15s, background .15s, box-shadow .15s;
}
.dropzone:hover, .dropzone:focus { outline: none; border-color: var(--green); background: #fff; box-shadow: var(--ring); }
.dropzone.drag { border-color: var(--green); border-style: solid; background: #f0fbf4; color: var(--ink); }
/* explicit display on the state blocks would otherwise override the `hidden` attribute */
.uploader [hidden] { display: none !important; }
.dz-idle { display: flex; flex-direction: column; align-items: center; gap: 2px; pointer-events: none; }
.dz-idle i { font-size: 1.7rem; color: var(--green); }
.dz-idle span { font-size: .9rem; font-weight: 500; color: var(--ink); }
.dz-idle small { font-size: .72rem; color: #9aa2b4; }
.dz-busy { display: flex; align-items: center; gap: 9px; font-size: .9rem; }
.dz-spinner { width: 16px; height: 16px; border: 2px solid #cfd5e0; border-top-color: var(--green); border-radius: 50%; animation: dz-spin .7s linear infinite; }
@keyframes dz-spin { to { transform: rotate(360deg); } }

.dropzone.is-done { border-style: solid; border-color: #bdeccf; background: #f1faf4; }
.dz-done { display: flex; align-items: center; gap: 8px; width: 100%; justify-content: center; }
.dz-done i { font-size: 1.3rem; color: var(--green-d); flex: none; }
.dz-view { font-size: .85rem; color: var(--ink); font-weight: 500; word-break: break-all; max-width: 80%; }
.dz-remove { flex: none; width: 22px; height: 22px; line-height: 1; border: 0; border-radius: 50%; background: #e7ebf1; color: #5b6472; font-size: 16px; cursor: pointer; padding: 0; }
.dz-remove:hover { background: #f5cccc; color: #a52121; }
.dz-error { margin-top: 7px; font-size: .8rem; color: #a52121; }

/* dependent universities */
.uni-list { margin-top: 6px; }
.uni-item { padding: 10px 0; border-bottom: 1px solid var(--line); }
.uni-item:last-child { border-bottom: 0; }
.uni-uploads { margin: 4px 0 4px 28px; }
.uni-uploads .uploader + .uploader { margin-top: 12px; }
