/* ================================================================
   TFE Event Registration — event-page.css v2.3.1
   Aesthetic: Dark editorial / concert-poster energy
   Fonts: Unbounded (display) + Manrope (body)
   ================================================================ */

.tfe-reg-page {
    --tfe-accent:     #e1251b;
    --tfe-accent-rgb: 225,37,27;
    --tfe-dark:       #0d0d0d;
    --tfe-dark-2:     #161616;
    --tfe-dark-3:     #1e1e1e;
    --tfe-border:     rgba(255,255,255,.08);
    --tfe-text:       #f0f0f0;
    --tfe-muted:      rgba(240,240,240,.5);
    --tfe-radius:     16px;
    --tfe-font-disp:  'Unbounded', sans-serif;
    --tfe-font-body:  'Manrope', sans-serif;
}

.tfe-reg-page /* Reset scoped to plugin */
.tfe-reg-page *,
.tfe-reg-page *::before,
.tfe-reg-page *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

.tfe-reg-page {
    font-family: var(--tfe-font-body);
    background: var(--tfe-dark);
    color: var(--tfe-text);
    line-height: 1.6;
    overflow-x: hidden;
    /* Override theme styles */
    margin-left: calc(-50vw + 50%);
    width: 100vw;
    position: relative;
}

.tfe-reg-page /* Preview-mode banner (visible to admins only) */
.tfe-preview-banner {
    background: #f0a500;
    color: #000;
    padding: .75rem 1.5rem;
    font-weight: 700;
    text-align: center;
    font-family: var(--tfe-font-body);
    font-size: .9rem;
    letter-spacing: .02em;
}

.tfe-reg-page /* ----------------------------------------------------------------
   HERO
   ---------------------------------------------------------------- */
.tfe-hero {
    position: relative;
    min-height: 92vh;
    display: flex;
    align-items: flex-end;
    padding: 5rem 2rem 5rem;
    overflow: hidden;
}

.tfe-reg-page .tfe-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center top;
    transform: scale(1.05);
    transition: transform 8s ease;
    filter: saturate(1.1);
}

.tfe-reg-page .tfe-hero:hover .tfe-hero-bg {
    transform: scale(1.0);
}

.tfe-reg-page .tfe-hero-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(to top, var(--tfe-dark) 0%, rgba(13,13,13,.6) 50%, rgba(13,13,13,.2) 100%),
        linear-gradient(135deg, rgba(var(--tfe-accent-rgb),.15) 0%, transparent 60%);
}

.tfe-reg-page /* Noise grain */
.tfe-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
    opacity: .4;
    pointer-events: none;
}

.tfe-reg-page .tfe-hero-content {
    position: relative;
    z-index: 2;
    max-width: 900px;
    width: 100%;
    margin: 0 auto;
}

.tfe-reg-page .tfe-badge {
    display: inline-block;
    font-family: var(--tfe-font-disp);
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--tfe-accent);
    border: 1px solid var(--tfe-accent);
    padding: .3em .8em;
    border-radius: 100px;
    margin-bottom: 1.25rem;
    animation: tfe-fadein .6s ease both;
}

.tfe-reg-page .tfe-event-title {
    font-family: var(--tfe-font-disp);
    font-size: clamp(2.4rem, 7vw, 5.5rem);
    font-weight: 900;
    line-height: 1.0;
    letter-spacing: -.02em;
    color: #fff;
    margin-bottom: 1rem;
    animation: tfe-slideup .7s ease .1s both;
}

.tfe-reg-page .tfe-event-subtitle {
    font-size: clamp(1rem, 2.5vw, 1.25rem);
    color: var(--tfe-muted);
    margin-bottom: 1.75rem;
    max-width: 600px;
    animation: tfe-slideup .7s ease .2s both;
}

.tfe-reg-page .tfe-hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem 1.5rem;
    margin-bottom: 2.25rem;
    animation: tfe-slideup .7s ease .3s both;
}

.tfe-reg-page .tfe-meta-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .95rem;
    color: var(--tfe-muted);
}

.tfe-reg-page .tfe-meta-item svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    opacity: .7;
}

.tfe-reg-page .tfe-meta-item a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.tfe-reg-page .tfe-hero-cta {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: var(--tfe-accent);
    color: #fff;
    font-family: var(--tfe-font-disp);
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .03em;
    padding: 1em 2.25em;
    border-radius: 100px;
    text-decoration: none;
    transition: background .2s, transform .2s, box-shadow .2s;
    box-shadow: 0 4px 32px rgba(var(--tfe-accent-rgb),.4);
    animation: tfe-slideup .7s ease .4s both;
}

.tfe-reg-page .tfe-hero-cta:hover {
    background: #c8201a;
    transform: translateY(-2px);
    box-shadow: 0 8px 40px rgba(var(--tfe-accent-rgb),.55);
}

.tfe-reg-page /* ----------------------------------------------------------------
   COUNTDOWN
   ---------------------------------------------------------------- */
.tfe-countdown-section {
    background: var(--tfe-dark-2);
    border-top: 1px solid var(--tfe-border);
    border-bottom: 1px solid var(--tfe-border);
    padding: 3rem 2rem;
    text-align: center;
}

.tfe-reg-page .tfe-countdown-label {
    font-size: .8rem;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--tfe-muted);
    margin-bottom: 1.5rem;
    font-family: var(--tfe-font-disp);
}

.tfe-reg-page .tfe-countdown {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: .5rem 1rem;
    flex-wrap: wrap;
}

.tfe-reg-page .tfe-cd-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 80px;
}

.tfe-reg-page .tfe-cd-num {
    font-family: var(--tfe-font-disp);
    font-size: clamp(2.5rem, 8vw, 5rem);
    font-weight: 900;
    color: var(--tfe-accent);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.tfe-reg-page .tfe-cd-lbl {
    font-size: .7rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--tfe-muted);
    margin-top: .4rem;
}

.tfe-reg-page .tfe-cd-sep {
    font-family: var(--tfe-font-disp);
    font-size: clamp(2rem, 6vw, 3.5rem);
    font-weight: 900;
    color: var(--tfe-border);
    line-height: 1;
    margin-bottom: 1.5rem;
    align-self: flex-start;
    padding-top: .1em;
}

.tfe-reg-page /* ----------------------------------------------------------------
   SECTIONS COMMON
   ---------------------------------------------------------------- */
.tfe-section-inner {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 2rem;
}

.tfe-reg-page .tfe-section-title {
    font-family: var(--tfe-font-disp);
    font-size: clamp(1.4rem, 4vw, 2.25rem);
    font-weight: 700;
    color: #fff;
    margin-bottom: 2rem;
    position: relative;
    padding-bottom: .75rem;
}

.tfe-reg-page .tfe-section-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 3rem;
    height: 3px;
    background: var(--tfe-accent);
    border-radius: 2px;
}

.tfe-reg-page /* ----------------------------------------------------------------
   ABOUT
   ---------------------------------------------------------------- */
.tfe-about-section {
    padding: 5rem 0;
    background: var(--tfe-dark);
}

.tfe-reg-page .tfe-about-text {
    font-size: 1.1rem;
    color: rgba(240,240,240,.8);
    max-width: 680px;
    line-height: 1.8;
}

.tfe-reg-page .tfe-about-text p { margin-bottom: 1rem; }

.tfe-reg-page /* ----------------------------------------------------------------
   ARTISTS
   ---------------------------------------------------------------- */
.tfe-artists-section {
    padding: 5rem 0;
    background: var(--tfe-dark-2);
    border-top: 1px solid var(--tfe-border);
}

.tfe-reg-page .tfe-artists-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 1.5rem;
}

.tfe-reg-page .tfe-artist-card {
    background: var(--tfe-dark-3);
    border: 1px solid var(--tfe-border);
    border-radius: var(--tfe-radius);
    overflow: hidden;
    transition: transform .2s, border-color .2s, box-shadow .2s;
}

.tfe-reg-page .tfe-artist-card:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--tfe-accent-rgb),.4);
    box-shadow: 0 12px 40px rgba(0,0,0,.4);
}

.tfe-reg-page .tfe-artist-photo {
    width: 100%;
    aspect-ratio: 1;
    background-size: cover;
    background-position: center;
    background-color: var(--tfe-dark-3);
}

.tfe-reg-page .tfe-artist-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(var(--tfe-accent-rgb),.2), rgba(var(--tfe-accent-rgb),.05));
}

.tfe-reg-page .tfe-artist-placeholder span {
    font-family: var(--tfe-font-disp);
    font-size: 3rem;
    font-weight: 900;
    color: var(--tfe-accent);
    opacity: .6;
}

.tfe-reg-page .tfe-artist-info {
    padding: 1rem;
}

.tfe-reg-page .tfe-artist-name {
    font-family: var(--tfe-font-disp);
    font-size: .85rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.3;
    margin-bottom: .25rem;
}

.tfe-reg-page .tfe-artist-role {
    font-size: .78rem;
    color: var(--tfe-muted);
}

.tfe-reg-page /* ----------------------------------------------------------------
   REGISTRATION FORM
   ---------------------------------------------------------------- */
.tfe-register-section {
    padding: 5rem 0 7rem;
    background: var(--tfe-dark);
    border-top: 1px solid var(--tfe-border);
}

.tfe-reg-page .tfe-form-wrap {
    max-width: 560px;
    margin: 0 auto;
    background: var(--tfe-dark-3);
    border: 1px solid var(--tfe-border);
    border-radius: 24px;
    padding: 3rem 2.5rem;
    position: relative;
    overflow: hidden;
}

.tfe-reg-page /* Glow top */
.tfe-form-wrap::before {
    content: '';
    position: absolute;
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
    width: 300px;
    height: 120px;
    background: radial-gradient(ellipse, rgba(var(--tfe-accent-rgb),.25) 0%, transparent 70%);
    pointer-events: none;
}

.tfe-reg-page .tfe-form-header {
    text-align: center;
    margin-bottom: 2rem;
    position: relative;
}

.tfe-reg-page .tfe-form-title {
    font-family: var(--tfe-font-disp);
    font-size: clamp(1.2rem, 3.5vw, 1.7rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
    margin-bottom: .5rem;
}

.tfe-reg-page .tfe-form-subtitle {
    font-size: .9rem;
    color: var(--tfe-muted);
}

.tfe-reg-page /* Language toggle */
.tfe-lang-toggle {
    display: flex;
    gap: .5rem;
    justify-content: center;
    margin-bottom: 2rem;
    background: rgba(255,255,255,.04);
    border-radius: 100px;
    padding: .25rem;
}

.tfe-reg-page .tfe-lang-btn {
    flex: 1;
    padding: .55rem 1rem;
    border-radius: 100px;
    border: none;
    background: transparent;
    color: var(--tfe-muted);
    font-family: var(--tfe-font-body);
    font-size: .85rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s, color .2s;
}

.tfe-reg-page .tfe-lang-btn.active {
    background: var(--tfe-accent);
    color: #fff;
    box-shadow: 0 2px 12px rgba(var(--tfe-accent-rgb),.4);
}

.tfe-reg-page /* Fields */
.tfe-registration-form {
    display: block;
}

.tfe-reg-page .tfe-hp-field {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.tfe-reg-page .tfe-fields {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    margin-bottom: 1.5rem;
}

.tfe-reg-page .tfe-field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.tfe-reg-page .tfe-field {
    display: flex;
    flex-direction: column;
    gap: .4rem;
}

.tfe-reg-page .tfe-label {
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--tfe-muted);
}

.tfe-reg-page .tfe-input {
    background: rgba(255,255,255,.05);
    border: 1.5px solid var(--tfe-border);
    border-radius: 10px;
    padding: .85rem 1rem;
    font-size: 1rem;
    font-family: var(--tfe-font-body);
    color: var(--tfe-text);
    width: 100%;
    transition: border-color .2s, background .2s, box-shadow .2s;
    outline: none;
}

.tfe-reg-page .tfe-input::placeholder {
    color: rgba(240,240,240,.2);
}

.tfe-reg-page .tfe-input:focus {
    border-color: var(--tfe-accent);
    background: rgba(255,255,255,.07);
    box-shadow: 0 0 0 3px rgba(var(--tfe-accent-rgb),.15);
}

.tfe-reg-page /* Submit */
.tfe-submit-btn {
    width: 100%;
    padding: 1rem 2rem;
    background: var(--tfe-accent);
    color: #fff;
    border: none;
    border-radius: 12px;
    font-family: var(--tfe-font-disp);
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .03em;
    cursor: pointer;
    transition: background .2s, transform .15s, box-shadow .2s;
    box-shadow: 0 4px 24px rgba(var(--tfe-accent-rgb),.35);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    min-height: 56px;
}

.tfe-reg-page .tfe-submit-btn:hover {
    background: #c8201a;
    transform: translateY(-1px);
    box-shadow: 0 8px 32px rgba(var(--tfe-accent-rgb),.5);
}

.tfe-reg-page .tfe-submit-btn:active {
    transform: translateY(0);
}

.tfe-reg-page .tfe-submit-btn:disabled {
    opacity: .6;
    cursor: not-allowed;
    transform: none;
}

.tfe-reg-page /* Spinner */
.tfe-spinner {
    width: 22px;
    height: 22px;
    animation: tfe-spin .8s linear infinite;
}

.tfe-reg-page /* Message */
.tfe-message {
    margin-top: 1.25rem;
    padding: 1rem 1.25rem;
    border-radius: 10px;
    font-size: .95rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
}

.tfe-reg-page .tfe-message.success {
    background: rgba(34,197,94,.1);
    border: 1px solid rgba(34,197,94,.3);
    color: #4ade80;
}

.tfe-reg-page .tfe-message.error {
    background: rgba(var(--tfe-accent-rgb),.1);
    border: 1px solid rgba(var(--tfe-accent-rgb),.3);
    color: #f87171;
}

.tfe-reg-page /* ----------------------------------------------------------------
   ANIMATIONS
   ---------------------------------------------------------------- */
@keyframes tfe-fadein {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes tfe-slideup {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}

@keyframes tfe-spin {
    to { transform: rotate(360deg); }
}

.tfe-reg-page /* ----------------------------------------------------------------
   SMOOTH SCROLL
   ---------------------------------------------------------------- */
.tfe-reg-page { scroll-behavior: smooth; }

.tfe-reg-page /* ----------------------------------------------------------------
   RESPONSIVE — tablet (768px)
   ---------------------------------------------------------------- */
@media (max-width: 768px) {
    .tfe-reg-page .tfe-hero { padding: 4rem 1.75rem 5rem; min-height: 85vh; }
    .tfe-reg-page .tfe-event-title { font-size: clamp(2rem, 6.5vw, 3.5rem); }
    .tfe-reg-page .tfe-cd-block { min-width: 70px; }
    .tfe-reg-page .tfe-section-inner { padding: 0 1.75rem; }
    .tfe-reg-page .tfe-form-wrap { padding: 2.5rem 2rem; }
    .tfe-reg-page .tfe-artists-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
    .tfe-reg-page .tfe-about-section,
    .tfe-reg-page .tfe-artists-section,
    .tfe-reg-page .tfe-register-section { padding: 4rem 0; }
}

.tfe-reg-page /* ----------------------------------------------------------------
   RESPONSIVE — mobile (600px)
   ---------------------------------------------------------------- */
@media (max-width: 600px) {
    .tfe-reg-page .tfe-hero { padding: 3rem 1.25rem 4rem; min-height: 80vh; }
    .tfe-reg-page .tfe-field-row { grid-template-columns: 1fr; }
    .tfe-reg-page .tfe-form-wrap { padding: 2rem 1.25rem; }
    .tfe-reg-page .tfe-artists-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
    .tfe-reg-page .tfe-countdown { gap: .25rem .5rem; }
    .tfe-reg-page .tfe-cd-block { min-width: 60px; }
    .tfe-reg-page .tfe-section-inner { padding: 0 1.25rem; }
    .tfe-reg-page .tfe-about-section,
    .tfe-reg-page .tfe-artists-section,
    .tfe-reg-page .tfe-register-section { padding: 3.5rem 0; }
}


/* Embedded form mode for TicketsFest single-event.php */
.tfe-reg-page.tfe-reg-page--form {
    width: 100%;
    margin: 0;
    background: transparent;
    color: inherit;
    overflow: visible;
    font-family: var(--tfe-font-body);
}
.tfe-reg-page--form .tfe-register-section {
    padding: 0;
    background: transparent;
    border-top: 0;
}
.tfe-reg-page--form .tfe-section-inner {
    max-width: 100%;
    padding: 0;
}
.tfe-reg-page--form .tfe-form-wrap {
    max-width: 100%;
    margin: 0;
    background: radial-gradient(circle at top right, rgba(var(--tfe-accent-rgb), .14), transparent 36%), #0f172a;
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: 0 24px 56px rgba(15,23,42,.18);
}
.tfe-reg-page--form .tfe-form-title,
.tfe-reg-page--form .tfe-form-subtitle,
.tfe-reg-page--form .tfe-label,
.tfe-reg-page--form .tfe-input,
.tfe-reg-page--form .tfe-lang-btn,
.tfe-reg-page--form .tfe-submit-btn {
    font-family: var(--tfe-font-body);
}
.tfe-reg-page--form .tfe-form-title {
    font-size: clamp(24px,4vw,32px);
    letter-spacing: -.02em;
}
.tfe-reg-page--form .tfe-submit-btn {
    background: var(--tfe-accent);
}
.tfe-reg-admin-warning {
    padding: 16px 18px;
    border-radius: 12px;
    background: #fff7ed;
    border: 1px solid #fed7aa;
    color: #9a3412;
    font-weight: 700;
}
