*{box-sizing:border-box}body{margin:0;font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top,rgba(37,99,235,.08),transparent 32%),linear-gradient(180deg,#f8fbff,#f4f7fb);color:#1f2937}body.modal-open{overflow:hidden}.container{max-width:1120px;margin:32px auto;padding:0 16px 40px}h1{margin:0 0 16px}h2,h3,p{margin-top:0}.muted{color:#6b7280}.card{background:#ffffffeb;border:1px solid rgba(229,231,235,.9);border-radius:18px;padding:18px;box-shadow:0 12px 30px #0f172a0f;margin-bottom:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.surface-soft{background:linear-gradient(180deg,#fffffff2,#f8fafceb)}.hero{display:flex;align-items:center;justify-content:space-between;gap:16px}.compact-hero{padding:12px 16px;margin-bottom:12px}.compact-hero h2{margin:0;font-size:18px}.hidden{display:none!important}label{display:block;font-weight:600;margin-bottom:8px}input[type=password],input[type=file],select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:12px;margin-bottom:12px;background:#fff}button,.link-btn{border:none;border-radius:12px;background:#2563eb;color:#fff;padding:10px 14px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:transform .15s ease,opacity .15s ease,box-shadow .15s ease}button:hover,.link-btn:hover{opacity:.96;transform:translateY(-1px)}button.secondary,.link-btn.secondary{background:#f3f4f6;color:#111827}button.danger{background:#dc2626}button:disabled{opacity:.65;cursor:wait;transform:none}.row{display:flex;align-items:center;gap:10px}.between{justify-content:space-between}.wrap-gap{flex-wrap:wrap}.upload-form{margin-bottom:16px}.upload-row{display:flex;align-items:end;gap:12px}.upload-row input{margin-bottom:0}.controls-inline{align-items:end}.filter-inline{display:flex;flex-direction:column;gap:6px;margin:0;min-width:130px}.filter-inline select{margin-bottom:0}.filter-check{display:inline-flex;align-items:center;gap:8px;margin:0 4px 10px 0;font-weight:600}.filter-check input{width:auto;margin:0}.title-row{gap:8px}.count-pill{display:inline-flex;align-items:center;justify-content:center;min-width:52px;height:28px;padding:0 10px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-size:12px;font-weight:700}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:14px}.empty-state{padding:28px 10px 12px;text-align:center;color:#6b7280}.item{border:1px solid rgba(226,232,240,.9);border-radius:16px;overflow:hidden;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:0 12px 30px #0f172a0d}.preview-wrap{position:relative}.item .meta{padding:12px;font-size:12px}.item .name{font-weight:700;margin-bottom:6px;word-break:break-all;line-height:1.35;font-size:14px}.meta-line{color:#4b5563;margin-top:4px}.item-top-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.item-actions{display:flex;gap:8px;margin-top:14px}.item-actions>*{flex:1}.preview{width:100%;aspect-ratio:1 / 1;object-fit:cover;background:#0f172a}.badge-row{position:absolute;top:10px;left:10px;display:flex;gap:6px;flex-wrap:wrap}.badge{padding:6px 9px;border-radius:999px;background:#0f172ab8;color:#fff;font-size:11px;font-weight:700;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.badge.liked{background:#dc2626d9}.icon-btn{min-width:40px;width:40px;height:40px;padding:0;font-size:18px;line-height:1;border-radius:999px}.like-btn{background:#f3f4f6;color:#6b7280;box-shadow:inset 0 0 0 1px #d1d5dbb3}.like-btn.liked{background:#fee2e2;color:#dc2626;box-shadow:inset 0 0 0 1px #fca5a5a6}.status{min-height:22px;color:#374151;font-weight:500;margin-top:16px}.status.error{color:#b91c1c}.modal-backdrop{position:fixed;inset:0;background:#0f172a8f;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.modal-card{width:min(100%,520px);background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 22px 60px #0f172a59}.modal-head,.modal-preview{padding:16px 16px 0}.modal-media{width:100%;max-height:320px;object-fit:cover;border-radius:16px;background:#0f172a}.modal-media.empty{min-height:120px;display:grid;place-items:center;color:#e5e7eb}.modal-body{padding:16px}.modal-file-name{font-size:18px;font-weight:700;margin-bottom:8px;word-break:break-all}.modal-actions{justify-content:flex-end;padding:0 16px 16px}@media(max-width:820px){.hero,.upload-row{flex-direction:column;align-items:stretch}}@media(max-width:640px){.item-actions,.modal-actions{flex-direction:column}}
