@keyframes card-fade-in{0%{opacity:0;transform:translateY(8px)}}.concert-card{background:#fff;border-radius:16px;grid-template:"image body""image location"/1fr 2fr;gap:0 1rem;margin-bottom:1rem;transition:transform .2s cubic-bezier(0,0,.2,1),box-shadow .2s;display:grid;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000a}@media (prefers-reduced-motion:no-preference){.concert-card:hover{transform:translateY(-4px)scale(1.01);box-shadow:0 8px 24px #0000001a}}.concert-card:focus-within{outline-offset:2px;outline:2px solid #ff6ba3}@media (prefers-reduced-motion:no-preference){.concert-card--animated{animation:.4s cubic-bezier(0,0,.2,1) both card-fade-in}.concert-card--animated:first-child{animation-delay:0s}.concert-card--animated:nth-child(2){animation-delay:50ms}.concert-card--animated:nth-child(3){animation-delay:.1s}.concert-card--animated:nth-child(4){animation-delay:.15s}.concert-card--animated:nth-child(5){animation-delay:.2s}.concert-card--animated:nth-child(6){animation-delay:.25s}.concert-card--animated:nth-child(7){animation-delay:.3s}.concert-card--animated:nth-child(8){animation-delay:.35s}.concert-card--animated:nth-child(9){animation-delay:.4s}.concert-card--animated:nth-child(10){animation-delay:.45s}}.concert-card.future{background:#fff0f5;box-shadow:0 4px 24px #ff066633,0 0 0 1px #ff06661f}.concert-card.future:before{content:"Upcoming";color:#fff;text-transform:uppercase;letter-spacing:.05em;z-index:2;background:linear-gradient(135deg,#ff0666 0%,#ff6ba3 100%);border-radius:100px;padding:.25rem .625rem;font-size:.6875rem;font-weight:700;position:absolute;top:.75rem;right:.75rem}.concert-card.future .bands .badge.bg-primary{background-color:#fff}.concert-card.future .bands .badge.bg-primary:hover{background-color:#ff0666}@media (prefers-reduced-motion:no-preference){.concert-card.future:hover{box-shadow:0 8px 32px #ff066647,0 0 0 1px #ff06662e}}.concert-card .concert-card-image{background:#f5f4f2;grid-area:image;position:relative;overflow:hidden}.concert-card .concert-card-image:after{content:"";pointer-events:none;background:linear-gradient(#0000 70%,#00000014 100%);position:absolute;inset:0}.concert-card .concert-card-image-img{object-fit:cover;object-position:50% 50%}.concert-card .concert-card-image-placeholder{background:radial-gradient(circle at 30% 25%,#ffffffa6 0%,#fff0 45%),linear-gradient(135deg,#ff06662e 0%,#0000000a 100%);width:100%;height:100%}.concert-card .concert-card-body{z-index:1;grid-area:body;padding:1em 1em 0 0;position:relative}.concert-card .concert-card-body .card-title{text-shadow:-1px 0 #fff,0 1px #fff,1px 0 #fff,0 -1px #fff;font-size:2rem}.concert-card .concert-card-body .concert-card-meta{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.concert-card .concert-card-body .concert-card-meta span:first-child{background:linear-gradient(135deg,#ff0666 0%,#ff6ba3 100%);-webkit-text-fill-color:#0000;-webkit-background-clip:text;background-clip:text;font-weight:600}.concert-card .concert-card-body .bands{margin-top:.5em}.concert-card .concert-card-body .bands .badge{color:#ff0666;background:#fff0f5;border:1px solid #0000;border-radius:100px;margin:0 .25rem .25rem 0;padding:.25em .75em;font-size:.8125rem;font-weight:600;transition:background-color .2s,color .2s,transform .15s cubic-bezier(0,0,.2,1),border-color .2s;display:inline-block}.concert-card .concert-card-body .bands .badge:hover{color:#fff;background:#ff0666;border-color:#ff0666;transform:scale(1.05)}.concert-card .concert-card-body .bands .badge:focus-visible{outline-offset:2px;outline:2px solid #ff6ba3}.concert-card .concert-card-location{z-index:1;grid-area:location;justify-content:space-between;align-items:center;gap:1rem;padding:0 1em 1em 0;display:flex;position:relative}.concert-card .concert-card-location .venue{margin-bottom:.25rem;font-weight:600}.concert-card .concert-card-location .city{color:#666;font-size:.875rem}.concert-card .concert-card-location .city a{color:inherit;transition:color .2s}.concert-card .concert-card-location .city a:hover{color:#ff0666}.concert-card .concert-card-location .club{font-weight:700}.concert-card .concert-card-cost{color:#666;margin-top:.25rem;font-size:.8125rem}@media screen and (min-width:1024px){.concert-card{grid-template-columns:1fr 2fr 2fr 2fr;grid-template-areas:"image body body location"}.concert-card .concert-card-body{padding:1rem 0}.concert-card .concert-card-body .card-title{font-size:2.5rem}}.concert-card-edit-btn{cursor:pointer;border-radius:8px;padding:.75rem 1.5rem;font-family:OpenSans,sans-serif;font-size:1rem;text-decoration:none;transition:background-color .2s,border-color .2s,box-shadow .2s}.concert-card-edit-btn:disabled{cursor:not-allowed;opacity:.6}.concert-card-edit-btn{color:#444;background-color:#0000;border:1px solid #ddd}.concert-card-edit-btn:hover:not(:disabled){color:#444;background-color:#f5f5f5;border-color:#ccc}.concert-card-edit-btn:focus-visible{outline-offset:2px;outline:2px solid #ff0666}.concert-card-edit-btn:active:not(:disabled){background-color:#ebebeb}.concert-card-edit-btn{white-space:nowrap;border-radius:8px;margin-left:auto;padding:.5rem 1rem;font-size:.875rem}.concert-card-attendees{color:#ff0666;white-space:nowrap;background:#fff0f5;border-radius:100px;padding:.25rem .5rem;font-size:.75rem;font-weight:600}
@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-pulse{background:linear-gradient(90deg,#f5f4f2 0%,#ff06660d 50%,#f5f4f2 100%) 0 0/200% 100%;border-radius:4px;animation:1.5s ease-in-out infinite skeleton-pulse}.concert-card-skeleton{background:#fff;border-radius:16px;grid-template:"image body""image location"/1fr 2fr;gap:0 1rem;margin-bottom:1rem;display:grid;overflow:hidden;box-shadow:0 2px 8px #0000000a}.concert-card-skeleton .concert-card-skeleton-image{background:#f5f4f2;grid-area:image}.concert-card-skeleton .concert-card-skeleton-body{flex-direction:column;grid-area:body;gap:.5rem;padding:1em 1em 0 0;display:flex}.concert-card-skeleton .concert-card-skeleton-body .skeleton-title{width:70%;height:2rem}.concert-card-skeleton .concert-card-skeleton-body .skeleton-date{width:40%;height:1rem}.concert-card-skeleton .concert-card-skeleton-body .skeleton-badges{gap:.5rem;margin-top:.5em;display:flex}.concert-card-skeleton .concert-card-skeleton-body .skeleton-badge{border-radius:100px;width:4rem;height:1.5rem}.concert-card-skeleton .concert-card-skeleton-location{flex-direction:column;grid-area:location;justify-content:center;gap:.25rem;padding:0 1em 1em 0;display:flex}.concert-card-skeleton .concert-card-skeleton-location .skeleton-club{width:60%;height:1rem}.concert-card-skeleton .concert-card-skeleton-location .skeleton-city{width:40%;height:1rem}@media screen and (min-width:1024px){.concert-card-skeleton{grid-template-columns:1fr 2fr 2fr 2fr;grid-template-areas:"image body body location"}.concert-card-skeleton .concert-card-skeleton-body{padding:1rem 0}.concert-card-skeleton .concert-card-skeleton-body .skeleton-title{height:2.5rem}}
