/* TDL MULTI-STEP ULTIMATE DESIGN */
.tdl-ms-wrapper {
    background: #050505 !important;
    border: 1px solid #1a1a1a !important;
    border-radius: 32px !important;
    padding: 50px 40px !important;
    max-width: 600px !important;
    margin: 40px auto !important;
    position: relative;
    box-shadow: 0 40px 80px rgba(0,0,0,0.8) !important;
}

/* Progress Bar */
.tdl-progress-container {
    position: absolute;
    top: 0; left: 0; width: 100%;
    height: 6px;
    background: #111;
    border-radius: 32px 32px 0 0;
    overflow: hidden;
}

.tdl-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, #00ffcc, #0099ff);
    width: 33%;
    transition: width 0.6s cubic-bezier(0.23, 1, 0.32, 1);
    box-shadow: 0 0 15px rgba(0, 255, 204, 0.5);
}

/* Steps */
.tdl-ms-step { display: none; }
.tdl-ms-step.active { display: block; animation: tdlStepIn 0.5s ease forwards; }

@keyframes tdlStepIn {
    from { opacity: 0; transform: translateX(20px); }
    to { opacity: 1; transform: translateX(0); }
}

.tdl-badge {
    color: #00ffcc !important;
    font-weight: 900 !important;
    text-transform: uppercase;
    letter-spacing: 3px;
    font-size: 10px;
    background: rgba(0, 255, 204, 0.1);
    padding: 5px 12px;
    border-radius: 50px;
}

.tdl-ms-header h2 {
    color: #fff !important;
    font-size: 28px !important;
    font-weight: 900 !important;
    margin: 15px 0 5px 0 !important;
    text-transform: uppercase;
}

/* Grid & Cards */
.tdl-ms-grid { display: grid; grid-template-columns: 1fr; gap: 12px; margin: 30px 0; }

.tdl-ms-card input { display: none !important; }
.card-box {
    background: #0d0d0d !important;
    border: 1px solid #222 !important;
    padding: 22px !important;
    border-radius: 18px !important;
    color: #888 !important;
    transition: all 0.3s ease;
    cursor: pointer;
    font-weight: 600;
}

.tdl-ms-card:hover .card-box { border-color: #333; color: #fff; }
.tdl-ms-card input:checked + .card-box {
    background: rgba(0, 255, 204, 0.05) !important;
    border-color: #00ffcc !important;
    color: #00ffcc !important;
    box-shadow: 0 0 20px rgba(0, 255, 204, 0.1);
}

/* Inputs Level 3 */
.tdl-ms-field { position: relative; margin-bottom: 35px; }
.tdl-ms-field input {
    width: 100% !important;
    background: transparent !important;
    border: none !important;
    border-bottom: 2px solid #222 !important;
    color: #fff !important;
    padding: 15px 0 !important;
    font-size: 18px !important;
    outline: none !important;
    box-shadow: none !important;
}

.tdl-ms-field label {
    position: absolute; top: 15px; left: 0;
    color: #555; transition: 0.3s; pointer-events: none;
}

.tdl-ms-field input:focus ~ label,
.tdl-ms-field input:not(:placeholder-shown) ~ label {
    top: -20px; font-size: 12px; color: #00ffcc;
}

/* Footer & Buttons */
.tdl-ms-footer { margin-top: 30px; }
.tdl-ms-footer.split { display: flex; gap: 15px; }

.tdl-ms-btn, .tdl-ms-btn-submit {
    flex: 1;
    background: #fff !important;
    color: #000 !important;
    padding: 20px !important;
    border-radius: 14px !important;
    border: none !important;
    font-weight: 900 !important;
    cursor: pointer;
    transition: 0.3s;
    text-transform: uppercase;
}

.tdl-ms-btn.secondary { background: #111 !important; color: #666 !important; border: 1px solid #222 !important; }
.tdl-ms-btn:hover, .tdl-ms-btn-submit:hover { background: #00ffcc !important; transform: translateY(-2px); }

/* Checkbox */
.tdl-ms-check { display: flex; gap: 15px; cursor: pointer; color: #666; font-size: 13px; }
.tdl-ms-check input { display: none !important; }
.box { min-width: 20px; height: 20px; border: 2px solid #222; border-radius: 5px; position: relative; }
.tdl-ms-check input:checked + .box { background: #00ffcc; border-color: #00ffcc; }
.tdl-ms-check input:checked + .box:after { content: '✓'; position: absolute; color: #000; left: 4px; top: -2px; font-weight: bold; }