body{
    font-family:'Poppins',sans-serif;
    background:#000;
    color:#fff;
}

.register-page{
    position:relative;
    min-height:100vh;
    background:url("../../assets/img/stadium.jpg") center/cover no-repeat;
    padding:40px 0;
    overflow:hidden;
}

.register-overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(rgba(0,60,120,0.60), rgba(0,0,0,0.92));
    z-index:1;
}

.register-page .container{
    z-index:2;
}

.register-card{
    max-width:1020px;
    margin:0 auto;
    background:rgba(15,28,47,0.92);
    border:1px solid rgba(0,150,255,0.25);
    border-radius:20px;
    padding:30px;
    box-shadow:
        0 0 14px rgba(0,150,255,0.35),
        0 0 28px rgba(0,150,255,0.20),
        0 0 40px rgba(0,150,255,0.12);
    backdrop-filter:blur(8px);
}

.register-header{
    margin-bottom:28px;
}

.register-header h3{
    font-size:40px;
    line-height:1.15;
    font-weight:800;
    letter-spacing:-0.4px;
    margin-bottom:14px !important;
    color:#fff;
    text-shadow:0 2px 16px rgba(0,170,255,0.18);
}

.register-counter{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding:10px 18px;
    border-radius:999px;
    background:rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.12);
    font-size:16px;
    font-weight:700;
    color:#d7e9ff;
    box-shadow:0 0 12px rgba(255,255,255,0.04);
}

.register-counter span{
    color:#00ff88;
    font-weight:800;
}

.register-card hr{
    margin:26px 0;
    border-color:rgba(255,255,255,0.10);
    opacity:1;
}

.register-card label,
.register-card .form-label,
.register-card h6{
    color:#fff;
    font-weight:600;
}

.register-card .form-label{
    display:inline-block;
    font-size:14px;
    font-weight:700;
    letter-spacing:.2px;
    margin-bottom:9px;
    color:#f3f7ff;
}

.register-card .mb-3{
    margin-bottom:20px !important;
}

.register-card .form-control,
.register-card .form-select{
    background:rgba(255,255,255,0.08);
    border:1px solid rgba(255,255,255,0.14);
    color:#fff;
    border-radius:12px;
    min-height:48px;
    box-shadow:none;
    transition:all .25s ease;
}

.register-card .form-control::placeholder{
    color:rgba(255,255,255,0.65);
}

.register-card .form-control:focus,
.register-card .form-select:focus{
    background:rgba(255,255,255,0.10);
    border-color:#00aaff;
    color:#fff;
    box-shadow:0 0 0 0.2rem rgba(0,170,255,0.15);
}

.register-card .form-select option{
    color:#000;
}

#team_msg,
#upi_msg,
#contact_msg{
    display:block;
    margin-top:6px;
    font-size:14px;
    font-weight:500;
}

.validation-message{
    display:block;
    margin-top:7px;
    font-size:13px;
    font-weight:600;
    letter-spacing:.1px;
    min-height:20px;
    opacity:.95;
}

.validation-message.success{
    color:#00e676;
}

.validation-message.error{
    color:#ff6b6b;
}

.register-card .form-control.is-valid,
.register-card .form-select.is-valid{
    border-color:#00e676 !important;
    background:rgba(0,230,118,0.08);
    box-shadow:0 0 0 0.18rem rgba(0,230,118,0.12);
}

.register-card .form-control.is-invalid,
.register-card .form-select.is-invalid{
    border-color:#ff6b6b !important;
    background:rgba(255,107,107,0.08);
    box-shadow:0 0 0 0.18rem rgba(255,107,107,0.12);
}

.register-card .form-control.is-valid:focus,
.register-card .form-select.is-valid:focus{
    border-color:#00e676 !important;
    box-shadow:0 0 0 0.2rem rgba(0,230,118,0.14);
}

.register-card .form-control.is-invalid:focus,
.register-card .form-select.is-invalid:focus{
    border-color:#ff6b6b !important;
    box-shadow:0 0 0 0.2rem rgba(255,107,107,0.14);
}

#typeTag{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    min-height:18px;
}

#typeTag .badge{
    display:inline-flex !important;
    align-items:center;
    gap:8px;
    padding:10px 14px !important;
    border-radius:999px;
    background:linear-gradient(135deg,#00aaff,#0066ff) !important;
    color:#fff !important;
    border:none;
    font-size:13px;
    font-weight:700;
    letter-spacing:.2px;
    box-shadow:0 0 12px rgba(0,170,255,0.20);
}

#typeTag .btn-close{
    filter:invert(1);
    opacity:1;
    transform:scale(.8);
    margin:0 !important;
}

#addPlayer{
    min-height:48px;
    border:none;
    border-radius:12px;
    font-weight:700;
    font-size:15px;
    background:linear-gradient(135deg,#00aaff,#0066ff);
    box-shadow:0 0 12px rgba(0,170,255,0.28);
    transition:all .25s ease;
}

#addPlayer:hover{
    transform:translateY(-1px);
    box-shadow:0 0 16px rgba(0,170,255,0.35);
}

.player-list-wrap{
    margin-top:14px;
    display:flex;
    flex-direction:column;
    gap:12px;
}

.player-card{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    padding:16px 18px;
    border-radius:16px;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.10);
    box-shadow:0 0 14px rgba(0,0,0,0.10);
}

.player-card-left{
    display:flex;
    align-items:center;
    gap:14px;
    min-width:0;
}

.player-number{
    width:42px;
    height:42px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:14px;
    font-weight:800;
    color:#fff;
    background:linear-gradient(135deg,#00aaff,#0066ff);
    box-shadow:0 0 10px rgba(0,170,255,0.20);
    flex-shrink:0;
}

.player-details{
    min-width:0;
}

.player-name{
    font-size:17px;
    font-weight:700;
    color:#ffffff;
    line-height:1.3;
    word-break:break-word;
}

.player-role-badges{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-top:8px;
}

.player-role-badge{
    display:inline-flex;
    align-items:center;
    padding:6px 12px;
    border-radius:999px;
    background:rgba(0,255,102,0.10);
    border:1px solid rgba(0,255,102,0.25);
    color:#dfffea;
    font-size:12px;
    font-weight:700;
    letter-spacing:.2px;
}

.player-card-actions{
    display:flex;
    align-items:center;
    gap:8px;
    flex-shrink:0;
}

.player-card-actions .btn{
    min-width:76px;
    border-radius:10px;
    font-size:13px;
    font-weight:700;
    padding:7px 12px;
}

.player-empty-state{
    padding:18px 16px;
    border-radius:14px;
    text-align:center;
    font-size:15px;
    color:rgba(255,255,255,0.72);
    background:rgba(255,255,255,0.04);
    border:1px dashed rgba(255,255,255,0.14);
    font-style:italic;
}

#captain{
    color:#fff;
}

#submitBtn{
    margin-top:20px;
}

.register-submit-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    text-decoration:none;
    background:linear-gradient(135deg,#00ff88 0%,#00c853 100%);
    color:#ffffff;
    padding:15px 34px;
    font-size:18px;
    font-weight:800;
    letter-spacing:.35px;
    border-radius:50px;
    border:1px solid rgba(255,255,255,0.12);
    box-shadow:
        0 0 12px rgba(0,255,136,0.45),
        0 0 24px rgba(0,255,136,0.18);
    transition:all .3s ease;
}

.register-submit-btn:hover{
    color:#fff;
    transform:translateY(-2px);
    box-shadow:
        0 0 16px rgba(0,255,136,0.65),
        0 0 32px rgba(0,255,136,0.28);
}

.register-submit-btn:disabled{
    opacity:.65;
    cursor:not-allowed;
    transform:none;
    box-shadow:none;
}

.closed-state-wrap{
    display:flex;
    justify-content:center;
    margin-top:18px;
}

.closed-state-card{
    width:100%;
    max-width:760px;
    text-align:center;
    padding:34px 24px;
    border-radius:22px;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.12);
    box-shadow:
        0 0 18px rgba(0,170,255,0.10),
        0 0 34px rgba(0,0,0,0.22);
    backdrop-filter:blur(8px);
}

/* Registration Closed Icons Fix Start */
.closed-state-icon{
    width:60px;
    height:60px;
    margin:0 auto 18px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:28px;
    background:linear-gradient(135deg, rgba(0,170,255,0.18), rgba(0,255,136,0.14));
    border:1px solid rgba(255,255,255,0.12);
    box-shadow:0 0 18px rgba(0,170,255,0.12);
}

.closed-limit-icon::before{
    content:"🏆";
}

.closed-manual-icon::before{
    content:"📌";
}
/* Registration Closed Icons Fix End */

.closed-state-title{
    font-size:28px;
    line-height:1.2;
    font-weight:800;
    color:#ffffff;
    margin-bottom:12px;
}

.closed-state-text{
    font-size:16px;
    line-height:1.7;
    color:#d7e9ff;
    max-width:620px;
    margin:0 auto 16px;
}

.closed-state-actions{
    margin-top:22px;
}

.closed-state-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:48px;
    padding:12px 24px;
    border-radius:999px;
    font-size:15px;
    font-weight:700;
    color:#fff;
    text-decoration:none;
    background:linear-gradient(135deg,#00aaff,#0066ff);
    border:1px solid rgba(255,255,255,0.10);
    box-shadow:0 0 14px rgba(0,170,255,0.22);
    transition:all .25s ease;
}

.closed-state-btn:hover{
    color:#fff;
    transform:translateY(-1px);
    box-shadow:0 0 18px rgba(0,170,255,0.30);
}

.alert{
    margin-bottom:22px;
    border-radius:14px;
    border:1px solid rgba(255,255,255,0.08);
}

@media (max-width:991px){
    .register-card{
        padding:24px 20px;
    }

    .register-header h3{
        font-size:30px;
        line-height:1.2;
    }

    .register-counter{
        font-size:16px;
    }
}

@media (max-width:767px){
    .register-page{
        padding:20px 0;
    }

    .register-page .container{
        padding-left:14px;
        padding-right:14px;
    }

    .register-card{
        padding:18px 14px;
        border-radius:16px;
    }

    .register-header{
        margin-bottom:22px;
    }

    .register-header h3{
        font-size:28px;
        line-height:1.2;
        margin-bottom:12px !important;
    }

    .register-counter{
        font-size:14px;
        padding:9px 14px;
        line-height:1.4;
    }

    .register-card .form-label{
        font-size:13px;
        margin-bottom:7px;
    }

    .register-card .mb-3{
        margin-bottom:16px !important;
    }

    .register-card hr{
        margin:20px 0;
    }

    .register-card .form-control,
    .register-card .form-select,
    #addPlayer,
    .register-submit-btn{
        min-height:50px;
        font-size:15px;
    }

    .validation-message{
        font-size:12px;
        min-height:18px;
    }

    .row.g-2 > [class*="col-"],
    .row.g-3 > [class*="col-"]{
        margin-bottom:10px;
    }

    #typeTag{
        margin-top:10px !important;
    }

    #typeTag .badge{
        font-size:12px;
        padding:8px 12px !important;
    }

    .player-card{
        flex-direction:column;
        align-items:flex-start;
        padding:14px;
    }

    .player-card-left{
        width:100%;
    }

    .player-card-actions{
        width:100%;
        justify-content:flex-start;
        flex-wrap:wrap;
    }

    .player-card-actions .btn{
        min-width:90px;
    }

    .player-name{
        font-size:15px;
    }

    .register-submit-btn{
        font-size:16px;
    }

    .alert{
        font-size:14px;
        padding:12px 14px;
    }

    .closed-state-card{
        padding:26px 16px;
        border-radius:18px;
    }

    .closed-state-icon{
        width:60px;
        height:60px;
        font-size:28px;
        margin-bottom:16px;
    }

    .closed-state-title{
        font-size:24px;
    }

    .closed-state-text{
        font-size:15px;
    }

    .closed-state-btn{
        width:100%;
    }
}

@media (max-width:480px){
    .register-page .container{
        padding-left:10px;
        padding-right:10px;
    }

    .register-card{
        padding:16px 12px;
        border-radius:14px;
    }

    .register-header h3{
        font-size:23px;
    }

    .register-counter{
        font-size:14px;
    }

    .register-card .form-control,
    .register-card .form-select,
    #addPlayer,
    .register-submit-btn{
        font-size:14px;
    }

    .player-card-actions .btn{
        min-width:auto;
        font-size:11px;
    }
}

.register-logo-wrapper{
    display:flex;
    justify-content:center;
    align-items:center;
    width:100%;
    margin-bottom:15px;
}

.register-logo{
    max-height:80px;
    width:auto;
    display:block;
}

.terms-check-wrap{
    margin-bottom:18px;
}

.terms-check-wrap .form-check-input{
    margin-top:0.28rem;
}

.terms-check-wrap .form-check-label{
    color:#d7e9ff;
    font-size:14px;
    line-height:1.6;
}

.terms-check-wrap a{
    color:#00c6ff;
    font-weight:700;
    text-decoration:none;
}

.terms-check-wrap a:hover{
    text-decoration:underline;
}

.modal-content{
    border-radius:16px;
}

.modal-body p{
    line-height:1.8;
}

/* Terms modal theme match */
#termsModal .modal-content{
    background:rgba(15,28,47,0.96);
    color:#ffffff;
    border:1px solid rgba(0,170,255,0.22);
    border-radius:20px;
    box-shadow:
        0 0 18px rgba(0,170,255,0.18),
        0 0 34px rgba(0,0,0,0.30);
    backdrop-filter:blur(10px);
}

#termsModal .modal-header{
    border-bottom:1px solid rgba(255,255,255,0.10);
    background:transparent;
    padding:18px 22px;
}

#termsModal .modal-title{
    color:#ffffff;
    font-size:22px;
    font-weight:800;
    letter-spacing:.2px;
}

#termsModal .btn-close{
    filter:invert(1);
    opacity:1;
}

#termsModal .modal-body{
    padding:22px;
    color:#d7e9ff;
}

#termsModal .modal-body p{
    margin-bottom:14px;
    font-size:15px;
    line-height:1.8;
    color:#d7e9ff;
}

#termsModal .modal-body strong{
    color:#00ff88;
    font-weight:800;
}

#termsModal .modal-footer{
    border-top:1px solid rgba(255,255,255,0.10);
    background:transparent;
    padding:16px 22px 22px;
}

#termsModal .modal-footer .btn{
    min-width:160px;
    min-height:46px;
    border:none;
    border-radius:12px;
    font-weight:700;
    background:linear-gradient(135deg,#00aaff,#0066ff);
    box-shadow:0 0 12px rgba(0,170,255,0.22);
}

#termsModal .modal-footer .btn:hover{
    transform:translateY(-1px);
    box-shadow:0 0 16px rgba(0,170,255,0.30);
}

#termsModal .modal-dialog{
    max-width:760px;
}

@media (max-width:767px){
    #termsModal .modal-content{
        border-radius:16px;
    }

    #termsModal .modal-title{
        font-size:18px;
    }

    #termsModal .modal-body{
        padding:18px 16px;
    }

    #termsModal .modal-body p{
        font-size:14px;
        line-height:1.7;
    }

    #termsModal .modal-footer{
        padding:14px 16px 18px;
    }

    #termsModal .modal-footer .btn{
        width:100%;
    }
}